IBM Informix 4GL Reference Manual
IBM Informix 4GL Reference Manual
IBM Informix 4GL Reference Manual
Reference Manual
Note: Before using this information and the product it supports, read the information in the appendix entitled Notices.
This document contains proprietary information of IBM. It is provided under a license agreement and is protected by copyright law. The information contained in this publication does not include any product warranties, and any statements provided in this manual should not be interpreted as such. When you send information to IBM, you grant IBM a nonexclusive right to use or distribute the information in any way it believes appropriate without incurring any obligation to you. Copyright International Business Machines Corporation 1996, 2002. All rights reserved. US Government User Restricted RightsUse, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
Table of Contents
Table of Contents
Introduction
In This Introduction . . . . . . . . About This Manual . . . . . . . . . Organization of This Manual . . . . Types of Readers . . . . . . . . Software Dependencies . . . . . . Assumptions About Your Locale. . . Demonstration Database and Examples Accessing Databases from Within 4GL. Enhancements to Version 7.31 . . . . . Documentation Conventions . . . . . Typographical Conventions . . . . Icon Conventions . . . . . . . . Example-Code Conventions . . . . Syntax Conventions . . . . . . . Additional Documentation . . . . . . Documentation Included with 4GL . . On-Line Manuals . . . . . . . . On-Line Help . . . . . . . . . On-Line Error Messages. . . . . . Related Reading . . . . . . . . Informix Developer Network . . . . Informix Welcomes Your Comments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 3 3 5 5 6 6 7 8 8 9 10 11 12 16 17 18 18 18 20 20 21
Chapter 1
Chapter 2
iv
Chapter 3
Table of Contents
Number Expressions . . . . . . . . . . . . . . . Character Expressions . . . . . . . . . . . . . . . Time Expressions. . . . . . . . . . . . . . . . . Field Clause . . . . . . . . . . . . . . . . . . Table Qualiers . . . . . . . . . . . . . . . . . THRU or THROUGH Keywords and .* Notation . . . . . ATTRIBUTE Clause . . . . . . . . . . . . . . . .
Chapter 4
INFORMIX-4GL Statements
In This Chapter . . . . . . . The 4GL Statement Set . . . . Types of SQL Statements . . Other Types of 4GL Statements Statement Descriptions . . . . CALL . . . . . . . . . CASE . . . . . . . . . CLEAR . . . . . . . . CLOSE FORM . . . . . . CLOSE WINDOW . . . . CONSTRUCT . . . . . . CONTINUE . . . . . . CURRENT WINDOW . . . DATABASE. . . . . . . DEFER . . . . . . . . DEFINE . . . . . . . . DISPLAY . . . . . . . DISPLAY ARRAY . . . . DISPLAY FORM . . . . . END . . . . . . . . . ERROR . . . . . . . . EXIT . . . . . . . . . FINISH REPORT . . . . . FOR . . . . . . . . . FOREACH . . . . . . . FUNCTION . . . . . . GLOBALS . . . . . . . GOTO . . . . . . . . IF . . . . . . . . . . INITIALIZE . . . . . . INPUT . . . . . . . . INPUT ARRAY . . . . . LABEL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-9 4-9 4-9 4-13 4-15 4-16 4-22 4-28 4-31 4-32 4-34 4-66 4-68 4-71 4-78 4-81 4-90 4-102 4-113 4-116 4-118 4-121 4-125 4-128 4-131 4-140 4-145 4-151 4-153 4-155 4-159 4-187 4-224
vi
LET . . . . . . . LOAD . . . . . . LOCATE . . . . . MAIN . . . . . . MENU . . . . . . MESSAGE . . . . NEED . . . . . . OPEN FORM . . . OPEN WINDOW . . OPTIONS . . . . . OUTPUT TO REPORT PAUSE . . . . . . PREPARE . . . . . PRINT . . . . . . PROMPT . . . . . REPORT . . . . . RETURN . . . . . RUN . . . . . . SCROLL . . . . . SKIP . . . . . . SLEEP . . . . . . SQL . . . . . . . START REPORT . . TERMINATE REPORT UNLOAD . . . . . VALIDATE . . . . WHENEVER. . . . WHILE. . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
4-226 4-230 4-239 4-245 4-248 4-273 4-276 4-278 4-280 4-291 4-308 4-311 4-312 4-324 4-325 4-332 4-337 4-340 4-344 4-346 4-348 4-349 4-354 4-364 4-367 4-372 4-376 4-382
Chapter 5
Syntax of Built-In Functions and Operators Aggregate Report Functions . . . . ARG_VAL( ) . . . . . . . . . Arithmetic Operators . . . . . . ARR_COUNT( ) . . . . . . . . ARR_CURR( ) . . . . . . . . . ASCII . . . . . . . . . . . Boolean Operators . . . . . . . CLIPPED . . . . . . . . . . COLUMN . . . . . . . . . . Concatenation ( || ) Operator . . . CURRENT . . . . . . . . . . CURSOR_NAME( ) . . . . . . . DATE . . . . . . . . . . . . DAY( ) . . . . . . . . . . . DOWNSHIFT( ) . . . . . . . . ERR_GET( ) . . . . . . . . . ERR_PRINT( ) . . . . . . . . ERR_QUIT( ) . . . . . . . . . ERRORLOG( ) . . . . . . . . . EXTEND( ) . . . . . . . . . . FGL_DRAWBOX( ) . . . . . . . FGL_GETENV( ) . . . . . . . . FGL_GETKEY( ) . . . . . . . . FGL_KEYVAL( ) . . . . . . . . FGL_LASTKEY( ) . . . . . . . FGL_SCR_SIZE( ) . . . . . . . FGL_SETCURRLINE ( ) . . . . . FIELD_TOUCHED( ) . . . . . . GET_FLDBUF( ) . . . . . . . . INFIELD( ) . . . . . . . . . . LENGTH( ) . . . . . . . . . LINENO. . . . . . . . . . . MDY( ) . . . . . . . . . . . Membership ( . ) Operator. . . . . MONTH( ) . . . . . . . . . . NUM_ARGS( ) . . . . . . . . ORD( ) . . . . . . . . . . . PAGENO . . . . . . . . . . SCR_LINE( ) . . . . . . . . . SET_COUNT( ) . . . . . . . . SHOWHELP( ) . . . . . . . . SPACE . . . . . . . . . . . viii IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5-13 5-14 5-18 5-20 5-27 5-29 5-31 5-33 5-45 5-47 5-50 5-51 5-53 5-56 5-58 5-59 5-61 5-63 5-64 5-65 5-67 5-70 5-73 5-75 5-76 5-78 5-81 5-83 5-84 5-87 5-90 5-92 5-94 5-95 5-97 5-98 5-99 5-100 5-101 5-102 5-104 5-106 5-108
STARTLOG( ) . . . . Substring ( [ ] ) Operator. TIME . . . . . . . TODAY . . . . . . UNITS . . . . . . . UPSHIFT( ) . . . . . USING . . . . . . WEEKDAY( ) . . . . WORDWRAP . . . . YEAR( ) . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
5-110 5-113 5-116 5-117 5-119 5-121 5-123 5-133 5-135 5-138
Chapter 6
Screen Forms
In This Chapter . . . . . . . . . . . . . 4GL Forms . . . . . . . . . . . . . . . Form Drivers . . . . . . . . . . . . Form Fields . . . . . . . . . . . . . Structure of a Form Specication File . . . . . . DATABASE Section . . . . . . . . . . . . Database References in the DATABASE Section. The FORMONLY Option . . . . . . . . The WITHOUT NULL INPUT Option . . . . SCREEN Section . . . . . . . . . . . . . The SIZE Option . . . . . . . . . . . The Screen Layout . . . . . . . . . . . Display Fields . . . . . . . . . . . . Literal Characters in Forms. . . . . . . . TABLES Section . . . . . . . . . . . . . Table Aliases . . . . . . . . . . . . . ATTRIBUTES Section . . . . . . . . . . . FORMONLY Fields . . . . . . . . . . Multiple-Segment Fields . . . . . . . . Field Attributes . . . . . . . . . . . Field Attribute Syntax . . . . . . . . . AUTONEXT . . . . . . . . . . . . . CENTURY . . . . . . . . . . . . . COLOR . . . . . . . . . . . . . . COMMENTS . . . . . . . . . . . . DEFAULT . . . . . . . . . . . . . DISPLAY LIKE . . . . . . . . . . . . DOWNSHIFT . . . . . . . . . . . . FORMAT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-5 6-5 6-5 6-7 6-9 6-12 6-13 6-14 6-14 6-15 6-16 6-17 6-17 6-19 6-23 6-24 6-25 6-29 6-31 6-32 6-33 6-34 6-35 6-37 6-43 6-45 6-48 6-49 6-50
Table of Contents ix
INCLUDE . . . . . . . . . . . . . . . . . . . INVISIBLE . . . . . . . . . . . . . . . . . . . NOENTRY . . . . . . . . . . . . . . . . . . . PICTURE . . . . . . . . . . . . . . . . . . . PROGRAM . . . . . . . . . . . . . . . . . . REQUIRED . . . . . . . . . . . . . . . . . . REVERSE . . . . . . . . . . . . . . . . . . . UPSHIFT . . . . . . . . . . . . . . . . . . . VALIDATE LIKE . . . . . . . . . . . . . . . . . VERIFY . . . . . . . . . . . . . . . . . . . . WORDWRAP . . . . . . . . . . . . . . . . . . INSTRUCTIONS Section . . . . . . . . . . . . . . . Screen Records . . . . . . . . . . . . . . . . . Screen Arrays . . . . . . . . . . . . . . . . . . Field Delimiters . . . . . . . . . . . . . . . . . Default Attributes . . . . . . . . . . . . . . . . . . Precedence of Field Attribute Specications . . . . . . . Default Attributes in an ANSI-Compliant Database . . . . . Creating and Compiling a Form . . . . . . . . . . . . . Compiling a Form Through the Programmers Environment . Compiling a Form at the Command Line . . . . . . . . Default Forms . . . . . . . . . . . . . . . . . . Using PERFORM Forms in 4GL . . . . . . . . . . . . .
6-53 6-56 6-57 6-58 6-60 6-62 6-63 6-64 6-65 6-66 6-67 6-74 6-74 6-77 6-79 6-80 6-83 6-84 6-85 6-85 6-87 6-89 6-91
Chapter 7
INFORMIX-4GL Reports
In This Chapter . . . . . . . . . . . . . . . . . Features of 4GL Reports . . . . . . . . . . . . . . Producing 4GL Reports . . . . . . . . . . . . . . The Report Driver . . . . . . . . . . . . . . The Report Denition . . . . . . . . . . . . . DEFINE Section . . . . . . . . . . . . . . . . OUTPUT Section . . . . . . . . . . . . . . . . ORDER BY Section . . . . . . . . . . . . . . . FORMAT Section . . . . . . . . . . . . . . . . EVERY ROW . . . . . . . . . . . . . . . . FORMAT Section Control Blocks . . . . . . . . . . Statements Prohibited in FORMAT Section Control Blocks AFTER GROUP OF . . . . . . . . . . . . . . BEFORE GROUP OF . . . . . . . . . . . . . FIRST PAGE HEADER . . . . . . . . . . . . . ON EVERY ROW. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-3 7-4 7-5 7-5 7-7 7-10 7-12 7-23 7-28 7-29 7-32 7-33 7-34 7-37 7-40 7-42
ON LAST ROW. . . . . . . . . . . PAGE HEADER . . . . . . . . . . PAGE TRAILER . . . . . . . . . . Statements in REPORT Control Blocks . . . . Statements Valid Only in the FORMAT Section EXIT REPORT . . . . . . . . . . . NEED . . . . . . . . . . . . . . PAUSE . . . . . . . . . . . . . . PRINT . . . . . . . . . . . . . . SKIP . . . . . . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
. . . . . . . . . .
7-44 7-45 7-47 7-48 7-49 7-50 7-52 7-54 7-55 7-68
Appendix A Appendix B Appendix C Appendix D Appendix E Appendix F Appendix G Appendix H Appendix I Appendix J
The ASCII Character Set INFORMIX-4GL Utility Programs Using C with INFORMIX-4GL Environment Variables Developing Applications with Global Language Support Modifying termcap and terminfo Reserved Words The Demonstration Application SQL Statements That Can Be Embedded in 4GL Code Notices Glossary Index
Table of Contents xi
Introduction
Introduction
In This Introduction
. . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
3 3 3 5 5 6 6 7 8 8 9 10 10 10 11 12 13 15 16 17 18 18 18 20 20 21
About This Manual . . . . . . . . . Organization of This Manual . . . . Types of Readers . . . . . . . . Software Dependencies . . . . . . Assumptions About Your Locale . . . Demonstration Database and Examples Accessing Databases from Within 4GL . Enhancements to Version 7.31 . . . . .
Documentation Conventions . . . . . . Typographical Conventions . . . . . Icon Conventions . . . . . . . . . Feature, Product, and Platform Icons . Compliance Icons . . . . . . . Example-Code Conventions . . . . . Syntax Conventions . . . . . . . . Elements That Can Appear on the Path How to Read a Syntax Diagram . . . Additional Documentation . . . . Documentation Included with 4GL On-Line Manuals . . . . . . On-Line Help . . . . . . . On-Line Error Messages. . . . Related Reading . . . . . . Informix Developer Network . . Informix Welcomes Your Comments . . . . . . . . . . . . . . . . . . . . . . . . .
In This Introduction
This Introduction provides an overview of the information in this manual and describes the conventions it uses.
Chapter 1, Compiling INFORMIX-4GL Source Files, describes the C Compiler and Rapid Development System implementations of INFORMIX-4GL. It also explains how to create executable versions of 4GL source les, both from the Programmers Environment and from the command line. Chapter 2, The INFORMIX-4GL Language, provides an overview of 4GL language features and graphical features of the applications that you can create with INFORMIX-4GL. Chapter 3, Data Types and Expressions, describes 4GL data types, expressions, and other syntax topics that affect several statements.
Introduction 3
Chapter 4, INFORMIX-4GL Statements, describes the statements of 4GL in alphabetical order. Chapter 5, Built-In Functions and Operators, includes an overview of the predened functions and operators of 4GL and describes their individual syntax, with examples of usage. Chapter 6, Screen Forms, provides an overview of 4GL screen forms and form drivers and describes the syntax of 4GL form specication les. It also describes how to create forms with the form4gl form compiler and describes how the upscol utility can set default attributes. Chapter 7, INFORMIX-4GL Reports, offers an overview of 4GL reports and report drivers, and describes the syntax of 4GL report denitions. It also describes the syntax of statements and operators that can appear only in 4GL reports. Appendix A, The ASCII Character Set, lists the ASCII characters and their numeric codes. Appendix B, INFORMIX-4GL Utility Programs, describes the mkmessage and upscol utility programs. Appendix C, Using C with INFORMIX-4GL, describes how to call C functions from 4GL programs, and vice versa, and describes a function library for conversion between the DECIMAL data type of 4GL and the C data types. Appendix D, Environment Variables, describes the environment variables that are used by 4GL. Appendix E, Developing Applications with Global Language Support, describes the internationalization and localization features that are provided with 4GL, and shows how to develop 4GL applications that are world-ready and easy to localize. Appendix F, Modifying termcap and terminfo, describes the modications you can make to your termcap and terminfo les to extend function key denitions, to specify characters for window borders, and to enable 4GL programs to interact with terminals that support color displays. Appendix G, Reserved Words, lists words that you should not declare as identiers in 4GL programs. It also lists the ANSI reserved words of SQL.
Types of Readers
Appendix H, The Demonstration Application, lists the code of the demo4.4ge demonstration application. Appendix I, SQL Statements That Can Be Embedded in 4GL Code, lists SQL syntax that is directly supported in 4GL. A Notices appendix describes IBM products, features, and services. The Glossary denes terms used in the 4GL documentation set.
s s
Types of Readers
This manual is written for all 4GL developers. You do not need database management experience nor familiarity with relational database concepts to use this manual. A knowledge of SQL (structured query language), however, and experience using a high-level programming language would be useful.
Software Dependencies
This manual is written with the assumption that you are using an Informix database server, Version 7.x or later. Informix offers two implementations of the 4GL application development language:
s
The INFORMIX-4GL C Compiler uses a preprocessor to generate Informix ESQL/C source code. This code is preprocessed in turn to produce C source code, which is then compiled and linked as object code in an executable command le. The INFORMIX-4GL Rapid Development System (RDS) uses a compiler to produce pseudo-machine code (called p-code) in a single step. You then invoke a runner to execute the p-code version of your application.
Both versions of 4GL use the same 4GL statements. Chapter 1, Compiling INFORMIX-4GL Source Files, describes the differences between the two versions of 4GL and explains how to use both versions. You can easily use applications developed with an earlier version of 4GL, such as Version 4.x or 6.x or 7.2, with this version of 4GL. For RDS programs that use p-code, however, you must rst recompile your 4GL source code.
Introduction 5
stration database called stores7 that contains information about a ctitious wholesale sporting-goods distributor. You can create the stores7 database in the current directory by entering the following command:
dbaccessdemo7
Many (but not all) of the examples in the 4GL documentation set are based on the stores7 database. This database is described in detail in Appendix A of INFORMIX-4GL by Example. For more information on creating the demonstration database and using the examples, see the introduction to INFORMIX4GL by Example.
For most SQL syntax that was supported by Informix 4.1 database servers, you can directly embed SQL statements in 4GL source code. For SQL statements that can be prepared, you can use the PREPARE feature of SQL to include SQL statements as text in prepared objects. For all SQL statements that can be prepared, you can also use the SQL ... END SQL delimiters to enclose the SQL statement. Unlike PREPARE, these can include host variables for input and output.
You must use one of the last two methods for SQL statements that include syntax that was introduced later than Informix 4.1 database servers. Such embedded, prepared, or delimited SQL statements are passed on to the database server for execution, as in the following 4GL program fragment:
DEFINE bugfile, setdeb CHAR(255) DATABASE stores7 --Directly embedded SQL LET setdeb = "set debug file to /u/tanya/bugfile" PREPARE bugfile FROM setdeb --Prepared SQL (post-4.1) EXECUTE IMMEDIATE bugfile --Directly embedded SQL SQL SET PDQPRIORITY HIGH --Delimited SQL (post-4.1) END SQL
Appendix I, SQL Statements That Can Be Embedded in 4GL Code, lists the supported SQL syntax. If you are uncertain which method is needed, use SQLEND SQL delimiters, which generally offer wider functionality and greater ease of coding than PREPARE for SQL statements that cannot be directly embedded. For additional information on SQL statements, see Informix Guide to SQL: Syntax.
Introduction 7
The NCHAR and NVARCHAR data types are now recognized and supported. For information about the NCHAR and NVARCHAR data types, see Chapter 3, Data Types and Expressions, of this book. For database servers that support long SQL identiers, your 4GL applications can reference SQL identiers that are up to 128 bytes in length. For more information about IFX_LONGID, see Chapter 2, The INFORMIX-4GL Language, of this book.
IBM INFORMIX-4GL is compatible with IBM Informix Client SDK 2.70.xC3 and above. Client SDK components allow developers to write applications in the language they are familiar with, whether it be Java, C++, C, or ESQL. For more information about Client SDK, see the documentation set at www.informix.com/answers.
Documentation Conventions
This section describes certain conventions that this manual uses. These conventions make it easier to gather information from this and other volumes in the documentation set. The following conventions are discussed:
s s s s
Typographical Conventions
Typographical Conventions
This manual uses the following conventions to introduce new terms, illustrate screen displays, describe command syntax, and so forth.
Convention KEYWORD italics italics
italics
Meaning All primary elements in a programming language statement (keywords) appear in uppercase letters in a serif font. Within text, new terms and emphasized words appear in italics. Within syntax diagrams and code examples, identiers or values that you are to specify appear in italics. Names of program entities (such as classes, events, and tables), environment variables, le and pathnames, and interface elements (such as icons, menu items, and buttons) appear in boldface. Information that the product displays and information that you enter appear in a monospace typeface. Keys to press appear in uppercase letters in a sans serif font.
boldface boldface
Tip: When you are instructed to enter characters or to execute a command, immediately press RETURN after the entry. When you are instructed to type the text or to press other keys, no RETURN is required.
Introduction 9
Icon Conventions
Icon Conventions
Throughout the documentation, you will nd text that is identied by several different types of icons. This section describes these icons.
Description Identies information that relates to the Informix Global Language Support (GLS) feature. Identies information or syntax that is specic to Informix Dynamic Server. Identies information or syntax that is specic to INFORMIX-SE. Identies SQL statements that you must put in an SQL block or prepare statement.
IDS
SE
SQL
These icons can apply to a row in a table, one or more paragraphs, or an entire section. A symbol indicates the end of the feature-specic, productspecic, or platform-specic information.
Compliance Icons
Compliance icons indicate paragraphs that provide guidelines for complying with a standard.
Icon
ANSI
These icons can apply to a row in a table, one or more paragraphs, or an entire section. A symbol indicates the end of the compliance information.
10 IBM Informix 4GL Reference Manual
Example-Code Conventions
Example-Code Conventions
Examples of 4GL source code occur in several sections of this manual. For readability, 4GL or SQL keywords generally appear in uppercase characters in code examples, and identiers usually appear in lowercase or mixed case. For instance, you might see code as in the following example:
MENU "CUSTOMER" COMMAND "Query" "Search for a customer" CALL query_data( ) NEXT OPTION "Modify" ... COMMAND "Modify" "Modify a customer" ... END MENU
Ellipsis ( ) symbols in a code example indicate that more code would be added in a complete application, but for clarity and simplicity, the example omits code that is extraneous to the current topic. (In most contexts, a compile-time or runtime error occurs if literal ellipsis symbols appear in code, or if you omit code that is necessary to your program logic.) Ellipsis symbols do not begin or end code examples, however, even if additional code would be required for a complete program, or for a complete statement. Most 4GL code examples are fragments of programs, rather than complete programs that can be compiled and executed. Because most examples are provided to illustrate some specic topic, the examples sometimes do not strictly conform to good programming practice. For example, they might not check to verify that an operation successfully executed without error, or they might not include the comments that normally should be included to improve readability and simplify maintenance of your code.
Introduction 11
Syntax Conventions
Syntax Conventions
SQL statement syntax is described in the Informix Guide to SQL: Syntax. The syntax for 4GL statements is described in Chapter 4 of this manual. Most chapters of this book describe the syntax of some aspect of the 4GL language,
such as expressions, form specications, and reports. This section describes conventions for syntax diagrams. Each diagram displays the sequences of required and optional keywords, terms, and symbols that are valid in a given statement or segment. Figure 1 shows the syntax diagram of the OPEN FORM statement.
Figure 1 Example of a Simple Syntax Diagram
OPEN FORM form FROM "lename"
Each syntax diagram begins at the upper-left corner and ends at the upperright corner with a vertical terminator. Between these points, any path that does not stop or reverse direction describes a possible form of the statement. (For a few diagrams, however, notes in the text identify path segments that are mutually exclusive.) Syntax elements in a path represent terms, keywords, symbols, and segments that can appear in your statement. The path always approaches elements from the left and continues to the right, except in the case of separators in loops. For separators in loops, the path approaches counterclockwise. Unless otherwise noted, at least one blank character separates syntax elements.
12
Syntax Conventions
(.,;@+*-/)
SE
This path is valid only for INFORMIX-SE database servers. This path is valid only for Informix Dynamic Server. (1 of 2)
IDS
Introduction 13
Syntax Conventions
Element
Description
+
This path produces a warning (of a syntax extension to the ANSI/ISO standard for SQL) if DBANSIWARN is set, or if the program is compiled with the -ansi ag.
ALL
...
A syntax segment within a pair of arrows is a subdiagram. The vertical line terminates the syntax diagram.
NULL
A branch below the main path indicates an optional path. (Any term on the main path is required, unless a branch can circumvent it.) A set of multiple branches indicates that a choice among more than two different paths is available.
,
variable statement
A loop indicates a path that you can repeat. Punctuation along the top of the loop indicates the separator symbol for list items. If no symbol appears, a blank space is the separator, or (as here) the Linefeed that separates successive statements in a source module. A gate ( 3 ) on a path indicates that you can only use that path the indicated number of times, even if it is part of a larger loop. You can specify size no more than three times within this statement segment. (2 of 2)
,
3 size
14
Syntax Conventions
,
DISPLAY value TO
,
Field Clause
,
BY NAME variable
ATTRIBUTE Clause
The Case III label above the diagram implies that this statement can have at least two other syntax patterns. To use this diagram to construct a statement, start at the top left with the keyword DISPLAY. Then follow the diagram to the right, proceeding through the options that you want. Figure 2 illustrates the following steps:
1. 2.
Type the keyword DISPLAY. You can display the values of a list of variables to an explicit list of elds within the current screen form:
s
Type the name of a value. If you want to display several values, separate successive values by a comma. Type the keyword TO after the name of the last value. Type the name of a eld in the current form in which to display the rst value. To nd the syntax for specifying eld names, go to the Field Clause segment on the specied page.
s s
3.
If you are using a form whose elds have the same names as the values that you want to display, you can follow the lower path:
s s
Type the keywords BY NAME after DISPLAY. Type the name of a variable. If you want to display the values of several variables, separate successive variables by comma.
Introduction 15
Additional Documentation
4.
You can optionally set a screen attribute for the displayed values:
s
Use the syntax of the ATTRIBUTE Clause segment on the specied page to specify the screen attribute that you desire.
5.
Follow the diagram to the terminator. Your DISPLAY TO or DISPLAY BY NAME statement is now complete. A restriction on step 2 (that there must be as many elds as variables) appears in notes that follow the diagram, rather than in the diagram itself. If 4GL issues an error when you compile a statement that seems to follow the syntax diagram, it might be a good idea to also read the usage notes for that statement.
Additional Documentation
For additional information, you might want to refer to the following types of documentation:
s s s s s
Documentation included with 4GL On-line manuals On-line help On-line error messages Related reading
16
INFORMIX-4GL Installation Guide is a pamphlet that describes how to install the various 4GL products. INFORMIX-4GL Concepts and Use introduces 4GL and provides the
context needed to understand the other manuals in the documentation set. It covers 4GL goals (what kinds of programming the language is meant to facilitate), concepts and nomenclature (parts of a program, ideas of database access, screen form, and report generation), and methods (how groups of language features are used together to achieve particular effects).
s
programs. Each is introduced with an overview; then the program source code is shown with line-by-line notes. The program source les are distributed as text les with the product; scripts that create the demonstration database and copy the applications are also included.
s
Documentation notes, which contain additions and corrections to the manuals, and release notes are located in the directory where the product is installed. Please examine these les because they contain vital information about application and performance issues.
If you have also purchased the INFORMIX-4GL Interactive Debugger product (which requires the INFORMIX-4GL Rapid Development System), your 4GL documentation also includes the following manual:
s
Guide to the INFORMIX-4GL Interactive Debugger is both an introduction to the Debugger and a comprehensive reference of Debugger commands and features. The Debugger allows you view the source code and to interact with your 4GL programs while they are running. It helps you to analyze the logic of your 4GL program and to determine the source of runtime errors within your programs.
Introduction 17
On-Line Manuals
On-Line Manuals
The Informix Answers OnLine CD allows you to print chapters or entire books and perform full-text searches for information in specic books or throughout the documentation set. You can install the documentation or access it directly from the CD. For information about how to install, read, and print on-line manuals, see the installation insert that accompanies Answers OnLine. You can also access Answers OnLine on the Web at the following URL:
http://www.informix.com/answers
On-Line Help
The Programmers Environment of 4GL provides on-line help; you can invoke help by pressing CONTROL-W.
18
nderr
msg_num
msg_num
Indicates the number of the error message to display. Error message numbers range from -1 to -32000. Specifying the - sign is optional.
For example, to display the -359 error message, you can enter either of the following:
finderr -359
or, equivalently:
finderr 359
The following example demonstrates how to specify a list of error messages. The example also pipes the output to the UNIX more command to control the display. You can also direct the output to another le so that you can save or print the error messages:
finderr 233 107 113 134 143 144 154 | more
A few messages have positive numbers. These messages are used solely within the application tools. In the unlikely event that you want to display them, you must precede the message number with the + sign. The messages numbered -1 to -100 can be platform-dependent. If the message text for a message in this range does not apply to your platform, check the operating system documentation for the precise meaning of the message number.
Introduction 19
Related Reading
Related Reading
The following Informix database server publications provide additional information about the topics that this manual discusses:
s
Informix database servers and the SQL language are described in separate manuals, including Informix Guide to SQL: Tutorial, Informix Guide to SQL: Syntax, and Informix Guide to SQL: Reference. Information about setting up Informix database servers is provided in the Administrators Guide for your Informix database server.
Informix Press, in partnership with Prentice Hall, publishes books about Informix products. Authors include experts from Informix user groups, employees, consultants, and customers. Recent titles about INFORMIX-4GL include:
s s
Advanced INFORMIX-4GL Programming, by Art Taylor, 1995. Programming Informix SQL/4GL: A Step-by-Step Approach, by Cathy Kipp, 1998. Informix Basics, by Glenn Miller, 1998.
You can access Informix Press on the Web at the following URL:
http://www.informix.com/ipress
20
The name and version of the manual that you are using Any comments that you have about the manual Your name, address, and phone number
Write to us at the following address: Informix Software, Inc. Technical Publications Department 4100 Bohannon Drive Menlo Park, CA 94025 If you prefer to send electronic mail, our address is:
doc@informix.com
We appreciate your suggestions. Important: The doc alias is monitored only by the Informix departments that create and maintain manuals and on-line documentation les. It is not an appropriate channel for technical support issues, sales inquiries, or questions about the availability of Informix products.
Introduction 21
Chapter
Two Implementations of INFORMIX-4GL . . . . . . Runtime and Compile-Time Requirements . . . . Differences Between the C Compiler and RDS Versions Differences in the Programmers Environment . Differences in Commands . . . . . . . . Differences in Filename Extensions . . . . .
The C Compiler Version . . . . . . . . . . . . . . . The Five-Phase 4GL Compilation Process. . . . . . . . The Programmers Environment . . . . . . . . . . . The INFORMIX-4GL Menu . . . . . . . . . . . The MODULE Design Menu . . . . . . . . . . The FORM Design Menu . . . . . . . . . . . . The PROGRAM Design Menu . . . . . . . . . . The QUERY LANGUAGE Menu . . . . . . . . . Creating Programs in the Programmers Environment . . . Creating a New Source Module . . . . . . . . . . Revising an Existing Module . . . . . . . . . . . Compiling a Source Module . . . . . . . . . . . Linking Program Modules . . . . . . . . . . . Executing a Compiled Program . . . . . . . . . . Creating Programs at the Command Line. . . . . . . . Creating or Modifying a 4GL Source File . . . . . . Compiling a 4GL Module . . . . . . . . . . . . Compiling and Linking Multiple Source Files . . . . . Using the c4gl Script for Compilation . . . . . . . . The -globcurs and -localcurs Options . . . . . . . . Shared Libraries . . . . . . . . . . . . . . . Invoking a Compiled 4GL Program at the Command Line Program Filename Extensions . . . . . . . . . . .
The Rapid Development System . . . . . . . . . The Programmers Environment . . . . . . . . The INFORMIX-4GL Menu . . . . . . . . The MODULE Design Menu . . . . . . . . The FORM Design Menu . . . . . . . . . The PROGRAM Design Menu . . . . . . . The QUERY LANGUAGE Menu . . . . . . Creating Programs in the Programmers Environment Creating a New Source Module . . . . . . . Revising an Existing Module . . . . . . . . Compiling a Source Module . . . . . . . . Combining Program Modules . . . . . . . Executing a Compiled RDS Program . . . . . Invoking the Debugger . . . . . . . . . . Creating Programs at the Command Line . . . . . Creating or Modifying a 4GL Source File . . . . Compiling an RDS Source File . . . . . . . Concatenating Multi-Module Programs . . . . Running RDS Programs . . . . . . . . . Running Multi-Module Programs . . . . . . Running Programs with the Interactive Debugger RDS Programs That Call C Functions . . . . . Editing the fgiusr.c File . . . . . . . . . . Creating a Customized Runner . . . . . . . Running Programs That Call C Functions . . . Program Filename Extensions . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
1-49 1-49 1-49 1-50 1-56 1-61 1-68 1-69 1-69 1-70 1-71 1-72 1-74 1-75 1-75 1-77 1-77 1-79 1-80 1-82 1-82 1-83 1-84 1-87 1-90 1-90
1-2
In This Chapter
This chapter describes how to create INFORMIX-4GL source-code modules, and how to produce executable 4GL programs from these modules, both at the operating system prompt and in the Programmers Environment. Procedures to do this are shown for the INFORMIX-4GL C Compiler, as well as for the INFORMIX-4GL Rapid Development System. These two implementations of 4GL differ in how they process 4GL source-code modules. This chapter begins by identifying differences between the two implementations of 4GL. It then goes on to describe each implementation of 4GL. Except as otherwise noted, the other chapters and appendixes of this manual describe features that are identical in both the C Compiler and the Rapid Development System implementations of 4GL.
The INFORMIX-4GL C Compiler, whose preprocessor generates extended ESQL/C source code. This code is further processed in several steps to produce C source code, which is compiled and linked as object code in an executable command le. The INFORMIX-4GL Rapid Development System (RDS), which uses a compiler to produce pseudo-machine code (called p-code) in a single step. You then invoke a runner to execute the p-code version of your application. For more details, see Compiling and Linking Multiple Source Files on page 1-35.
Compiling INFORMIX-4GL Source Files 1-3
Important: This version of the runner or Debugger cannot interpret programs compiled to p-code by releases of 4GL earlier than Version 7.30. You must rst recompile your source les and form specications. Similarly, releases of the 4GL runner or Debugger earlier than Version 7.30 cannot interpret p-code that this release produces.
Important: On some platforms, LD_LIBRARY_PATH has a different name. Please see the machine-specic notes that are provided with 4GL for the name of this environment variable on your platform. Earlier releases of 4GL before Version 7.31 required a different setting.
1-4
The New and Modify options of the PROGRAM design menu display a different screen form in the two implementations. Both of these screen forms are illustrated later in this chapter. The Rapid Development System includes a Debug option on its MODULE design menu and PROGRAM design menu. This option does not appear in the C Compiler. (The Debugger is based on p-code, so it can execute only 4GL programs and modules that have been compiled by the Rapid Development System.) The INFORMIX-4GL Interactive Debugger is available as a separate product.
Differences in Commands
The commands you use to enter the Programmers Environments, compile and execute 4GL programs, and build or restore the stores7 demonstration database vary between implementations of 4GL.
C Compiler i4gl c4gl sle.4gl xle.4ge i4gldemo RDS r4gl fglpc sle fglgo xle r4gldemo Effect of Command Enter Programmers Environment Compile 4GL source le sle.4gl Execute compiled 4GL program xle Create the demonstration database
The C Compiler requires no equivalent command to the fglgo command, because its compiled object les are executable without a runner. The Rapid Development System also contains a command-le script to compile and execute 4GL programs that call C functions or INFORMIX-ESQL/C functions, as described in RDS Programs That Call C Functions on page 1-83.
1-5
The backup le extensions .4bo and .4be for compiled modules and programs have the same names in both implementations. These les are not interchangeable between the two 4GL implementations, however, because object code produced by a C compiler is different from p-code. Other lename extensions that are the same in both the C Compiler and the Rapid Development System designate interchangeable les, if you use both implementations of 4GL to process the same 4GL source-code module.
The ve steps of the compilation process All the menu options and screen form elds of the Programmers Environment The steps for compiling and executing 4GL programs from the Programmers Environment The equivalent command-line syntax for compiling and executing 4GL programs The lename extensions of 4GL source-code, object, error, and backup les
1-6
The i4glc1 preprocessor converts a 4GL source le with .4gl extension into a le with .4ec extension. It parses the 4GL language and generates C code to handle function and report denitions, computations, and function calls. It generates extended ESQL/C statements to handle forms, menus, input statements, and display statements, and pure ESQL/C to handle SQL statements and declarations of variables. i4glc1 is similar to Version 4.12 and earlier fglc, except that i4glc1 generates a .4ec le instead of a .ec le. The i4glc2 preprocessor translates the extended form, menu, input, and display statements to pure C code but leaves variable declarations and SQL statements unchanged. i4glc2 accepts a .4ec le generated by i4glc1 as input and produces a .ec le containing pure ESQL/C code.
2.
1-7
3.
The i4glc3 preprocessor is a copy of the ESQL/C compiler. The i4glc3 preprocessor accepts a .ec le (produced by i4glc2 or written as pure ESQL/C code), and produces a .c le. The declarations and the SQL statements are mapped to pure C language code.
Figure 1-1 Five-Phase Compilation Process
le.4gl i4glc1
le.ec
le.4ec
i4glc2 i4glc3
le.o or le.4ge
The i4glc4 preprocessor converts C code, which may contain nonASCII characters in variable names, into de-internationalized names. This step ensures that dening a record like table.* or a eld like table.column does not produce C code that contains non-ASCII character in identiers (because very few C compilers accept nonASCII characters in the names of variables). Informix uses the system C compiler to convert the C code generated by i4glc3 or i4glc4 into object les (a le with .o extension) and executable programs (a le with .4ge extension).
5.
1-8
This is the highest menu, from which you can reach any other menu of the Programmers Environment. You have ve options:
s s s s
Module. Work on a 4GL program module. Form. Work on a screen form. Program. Specify components of a multi-module program. Query-language. Use an SQL interactive interface, if you have either INFORMIX-SQL or DB-Access installed on your system. (See the documentation of these Informix products for details of their use.) Exit. Terminate i4gl and return to the operating system.
The rst three options display new menus that are described in the pages that follow. (You can also press CONTROL-W at any menu to display an on-line help message that describes your options.) As at any 4GL menu, you can choose an option in either of two ways:
s s
By typing the rst letter of the option By using the SPACEBAR or arrow keys to move the highlight to the option that you choose, and then pressing RETURN
Compiling INFORMIX-4GL Source Files 1-9
Use this menu to create and compile source-code modules of a 4GL application. (For information on creating and compiling 4GL screen forms, see The FORM Design Menu on page 1-15. For details of how to create and compile help messages, see the mkmessage utility in Appendix B, INFORMIX-4GL Utility Programs.) The MODULE design menu supports the following options:
s s s s s
Modify. Change an existing 4GL source-code module. New. Create a new source-code module. Compile. Compile a source-code module. Program_Compile. Compile a 4GL application program. Run. Execute a compiled 4GL program module or a multi-module application program. Exit. Return to the INFORMIX-4GL menu.
Within the Programmers Environment, the Exit option returns control to the higher menu from which you accessed the current menu (or, when you choose Exit from the INFORMIX-4GL menu, terminates the 4GL session and returns to the system prompt).
1-10
If you press RETURN or type c or C to choose the Compile option, 4GL displays the COMPILE MODULE menu:
COMPILE MODULE: Object Runable Exit Create object file only; no linking to occur. -------------------------------------------Press CTRL-W for Help------
The Object option creates a compiled le with the .o extension but makes no attempt to link the le with other les.
1-11
The Runable option creates a compiled le with the .4ge extension. 4GL assumes that the current module is a complete 4GL program, and that no other module needs to be linked to it. Choose the Runable option if the current program module is a stand-alone 4GL program. If this is not the case (that is, if the le is one of several 4GL source-code modules within a multimodule program), then you should use the Object option instead, and you must use the PROGRAM design menu to specify all the component modules. After you choose Object or Runable, a message near the bottom of the screen will advise you if 4GL issues a compile-time warning or error. If there are warnings (but no errors), an object le is produced. Choose the Exit option of the next menu, and then Save-and-exit at the MODIFY MODULE menu, if you wish to save the executable le without reading the warnings. Alternatively, you can examine the warning messages by choosing Correct at the next menu. When you nish editing the .err le that contains the warnings, you must choose Compile again from the MODIFY MODULE menu, because the Correct option deletes the executable le. If there are compilation errors, the following menu appears.
COMPILE MODULE: Correct Exit Correct errors in the 4GL module. -------------------------------------------Press CTRL-W for Help------
If you choose to correct the errors, an editing session begins on a copy of your source module with embedded error messages. You do not need to delete the error messages because 4GL does this for you. Correct your source le, save your changes, and exit from the editor. The MODIFY MODULE menu reappears, prompting you to recompile, save, or discard your changes without compiling. If you choose not to correct the errors, you are prompted to Save or Discard the le.
1-12
If there are no compilation errors, the MODIFY MODULE menu appears with the Save-and-Exit option highlighted. Choose this option to save the current source-code module as a le with extension .4gl, and create an object le with the same lename, but with the extension .o. If you specied Runable when you compiled, the executable version is saved with the extension .4ge. The Discard-and-Exit option discards any changes that were made to your le after you chose the Modify option.
This option resembles the Modify option, but NEW MODULE is the menu title, and you must enter a new module name, rather than choose it from a list. The lename of the module must be unique among source-code modules of the same 4GL program, and can include up to 10 characters, not including the .4gl le extension. If you have not designated an editor previously in this session or with DBEDIT, you are prompted for an editor. Then an editing session begins.
1-13
After you specify the name of a 4GL source-code module to compile, the screen displays the COMPILE MODULE menu. Its Object, Runable, and Exit options were described earlier in the discussion of the Modify option.
1-14
The RUN PROGRAM screen lists compiled modules and programs, with the highlight on the module corresponding to the current le, if any has been specied. Only compiled programs with extension .4ge are listed. If you compile a program outside the Programmers Environment and you want it to appear in this list, give it the extension .4ge. If no compiled programs exist, 4GL displays an error message and returns to the MODULE design menu. You can exit to the maine INFORMIX-4GL menu, and select the Program option to create the database.
1-15
You can use this menu to create, modify, and compile screen form specications. These dene visual displays that 4GL applications can use to query and modify the information in a database. 4GL form specication les are ASCII les that are described in Chapter 6, Screen Forms. The FORM design menu supports the following options:
s s s s s
Modify. Change an existing 4GL screen form specication. Generate. Create a default 4GL screen form specication. New. Create a new 4GL screen form specication. Compile. Compile an existing 4GL screen form specication. Exit. Return to the INFORMIX-4GL menu.
Readers familiar with INFORMIX-SQL may notice that this resembles the menu displayed by the Form option of the INFORMIX-SQL main menu.
If you choose this option, you are prompted to choose the name of a form specication le to modify. Source les created at the FORM design menu have the le extension .per. (If you use a text editor outside of the Programmers Environment to create form specication les, you must give them the extension .per before you can compile them with the FORM4GL screen form facility.)
1-16
If you have not already designated a text editor in this 4GL session or with DBEDIT, you are prompted for the name of an editor. Then an editing session begins, with the form specication source-code le that you specied as the current le. When you leave the editor, 4GL displays the MODIFY FORM menu with the Compile option highlighted. Now you can press RETURN to compile the revised form specication le.
MODIFY FORM: Compile Save-and-exit Compile the form specification. Discard-and-exit
If there are compilation errors, 4GL displays the COMPILE FORM menu.
COMPILE FORM: Correct Exit Correct errors in the form specification. -------------------------------------------Press CTRL-W for Help------
Press RETURN to choose Correct as your option. An editing session begins on a copy of the current form, with diagnostic error messages embedded where the compiler detected syntax errors. 4GL automatically deletes these messages when you save the le and exit from the editor. After you have corrected the errors, the MODIFY FORM menu appears again, with the Compile option highlighted. Press RETURN to recompile. Repeat these steps until the compiler reports no errors. (If you choose Exit instead of Correct, you are prompted to Save or Discard the le.) If there are no compilation errors, you are prompted to save the modied form specication le and the compiled form, or to discard the changes. (Discarding the changes restores the version of your form specications from before you chose the Modify option.)
1-17
When you choose this option, 4GL prompts you to select a database, to choose a lename for the form specication, and to identify the tables that the form will access. After you provide this information, 4GL creates and compiles a form specication le. (This is equivalent to running the -d (default) option of the form4gl command, as described in Compiling a Form at the Command Line on page 6-87.)
After prompting you for the name of your form specication le, 4GL places you in the editor where you can create a form specication le. When you leave the editor, 4GL transfers you to the NEW FORM menu that is like the MODIFY FORM menu. You can compile your form and correct it in the same way.
1-18 IBM Informix 4GL Reference Manual
4GL compiles the form specication le whose name you specify. If the compilation fails, 4GL displays the COMPILE FORM menu with the Correct
option highlighted.
1-19
You can use this menu to create or modify a multi-module 4GL program specication, to compile and link a program, or to execute a program.
1-20
Modify. Change an existing program specication. New. Create a new program specication. Compile. Compile an existing program. Planned_Compile. List the steps necessary to compile and link an existing program. Run. Execute an existing program. Drop. Delete an existing program specication. Exit. Return to the INFORMIX-4GL menu.
s s s
You must rst use the MODULE design menu and the FORM design menu to enter and edit the 4GL statements within the component source-code modules of a 4GL program. Then you can use the PROGRAM design menu to identify which modules are part of the same application program, and to link all the modules as an executable command le.
then displays a menu and form that you can use to update the information in the program specication database, as shown in Figure 1-2.
1-21
-------------------------------------------Press CTRL-W for Help-----Program [myprog ] 4gl Source [main [funct [rept [ [ 4gl Source Path [/u/john/appl/4GL [/u/john/appl/4GL [/u/john/appl/4GL [ [ Ext [c [ [ [ Other Source Path [/u/john/appl/C [ [ [ Compile Options [ [ ] ]
] ] ] ] ]
] ] ] ] ]
] ] ] ] ] ]
] ] ] ]
The name of the program appears in the Program eld. In Figure 1-2 the name is myprog. You can change this name by choosing the Rename option. 4GL assigns the program name, with the extension .4ge, to the executable program produced by compiling and linking all the source les and libraries. (Compiling and linking occurs when you choose the Compile_Options option, as described later in this section.) In this example, the resulting executable program would have the name myprog.4ge. Use the 4GL option to update the entries for the 4gl Source elds and the 4gl Source Path elds on the form. The ve rows of elds under these labels form a screen array. When you choose the 4GL option, 4GL executes an INPUT ARRAY statement so you can move and scroll through the array. See the INPUT ARRAY statement in Chapter 4, INFORMIX-4GL Statements, for information about how to use your function keys to scroll, delete rows, and insert new rows. (You cannot redene the function keys, however, as you can with a 4GL program.)
1-22
The 4GL source program that appears in Figure 1-2 on page 1-22 contains three modules:
s s s
One module contains the main program (main.4gl). One module contains functions (funct.4gl). One module contains REPORT statements (rept.4gl).
Each module is located in the directory /u/john/appl/4GL. If your program includes a module containing only global variables (for example, global.4gl), you must also list that module in this section. Use the Other option to include non-4GL source modules or object-code modules in your program. Enter this information into the three-column screen array with the headings Other Source, Ext, and Other Source Path. Enter the lename and location of each non-4GL source-code or object-code module in these elds. Enter the name of the module in the Other Source eld, the lename extension of the module (for example, ec for an INFORMIX-ESQL/C module, or c for a C module) in the Ext eld, and the full directory path of the module in the Other Source Path eld. The example in Figure 1-2 includes a le containing C function source-code (cfunc.c) located in /u/john/appl/C. You can list up to 100 les in this array. The Libraries option enables you to indicate the names of up to ten special libraries to link with your program. 4GL calls the C compiler to do the linking and adds the appropriate -l prex, so you should enter only what follows the prex. The example displayed in Figure 1-2 calls only the standard C math library. Use the Compile_Options option to indicate up to ten C compiler options. Enter this information in the Compile Options eld. Do not, however, specify the -e or -a options of c4gl in this eld, because they will cause the compilation to fail. (See Creating Programs at the Command Line on page 1-33 for more information about the options of the c4gl command.) The Exit option exits from the MODIFY PROGRAM menu and displays the PROGRAM design menu.
1-23
The submenu screen forms displayed by the New and the Modify options of the PROGRAM design menu are identical, except that you must rst supply a name for your program when you choose the New option. (4GL displays a blank form in the NEW PROGRAM menu.) The NEW PROGRAM menu has the same options as the MODIFY PROGRAM menu, as illustrated earlier.
example of these messages appears in the illustration of the Planned_Compile option, next.
1-24 IBM Informix 4GL Reference Manual
In this instance, changes were made to all the components of the 4GL program that were listed in Figure 1-2 on page 1-22. This display indicates that no source-code module has been compiled after the program was changed.
1-25
1-26
After a sign-on message is displayed, the INFORMIX-4GL menu appears. To create a 4GL application with the C Compiler version of 4GL
1. 2. 3. 4.
Create a new source module or revising an existing source module Compile the source module Link the program modules Execute the compiled program
1-27
Choose the Module option of the INFORMIX-4GL menu. The MODULE design menu is displayed. If you are creating a new .4gl source module, choose the New option of the MODULE design menu. Enter a name for the new module. The name must begin with a letter and can include letters, numbers, and underscores. No more than 10 characters are allowed in this name, which must be unique among the les in the same directory, and among any other modules of the same program. 4GL attaches the extension .4gl to this lename of your new module.
2. 3.
4.
Press RETURN.
Choose the Modify option of the MODULE design menu. The screen lists the names of all the .4gl source modules in the current directory and prompts you to choose a source le to edit.
2.
Use the arrow keys to highlight the name of a source module and press RETURN, or enter a lename (with no extension). If you specied the name of an editor with the DBEDIT environment variable, an editing session with that editor begins automatically. Otherwise, the screen prompts you to specify a text editor. Specify a text editor, or press RETURN for vi, the default editor. Now you can begin an editing session by entering 4GL statements.
3.
When you have nished entering or editing your 4GL code, use an appropriate editor command to save your source le and end the text editing session.
1-28
Choose the Compile option from the MODULE design menu. Choose the type of module that you are compiling, either Runable or Object. If the module is a complete 4GL program that requires no other modules, choose Runable. If the module is one module of a multi-module 4GL program, choose Object. This option creates a compiled object le module, with the same lename, but with extension .o. See also the next section, Linking Program Modules.
3.
If the compiler detects errors, no compiled le is created, and you are prompted to x the problem. Choose Correct to resume the previous text editing session, with the same 4GL source code, but with error messages in the le. Edit the le to correct the error, and choose Compile again. If an error message appears, repeat this process until the module compiles without error.
4.
After the module compiles successfully, choose Save-and-exit from the menu to save the compiled program. The MODULE design menu appears again on your screen. If your program requires screen forms, choose Form from the INFORMIX-4GL menu. The FORM design menu appears. For information about designing and creating screen forms, see Chapter 6.
5.
6.
If your program displays help messages, you must create and compile a help le. Use the mkmessage utility to compile the help le. For more information on this utility, see Appendix B.
1-29
Choose the Program option from the INFORMIX-4GL menu. The PROGRAM design menu appears. If you are creating a new multi-module 4GL program, choose the New option; if you are modifying an existing one, choose Modify. In either case, the screen prompts you for the name of a program.
2.
1-30
3.
Enter the name (without a le extension) of the program that you are modifying, or the name to be assigned to a new program. Names must begin with a letter, and can include letters, underscores ( _ ), and numbers. After you enter a valid name, the PROGRAM screen appears, with your program name in the rst eld. If you chose Modify, the names and pathnames of the source-code modules are also displayed. In that case, the PROGRAM screen appears below the MODIFY PROGRAM menu, rather than below the NEW PROGRAM menu. (Both menus list the same options.)
MODIFY PROGRAM: 4GL Other Edit the 4GL sources list. Libraries Compile_Options Rename Exit
] ] ] ] ]
] ] ] ] ] ]
] ] ] ] ] ]
1-31
4.
To specify new 4GL modules or edit the list of 4GL modules, choose the 4GL option. You can enter or edit the name of a module, without the .4gl le extension. Repeat this step for every module. If the module is not in the current directory or in a directory specied by the DBPATH environment variable, enter the pathname to the directory where the module resides.
To include any modules in your program that are not 4GL source les, choose the Other option. This option enables you to specify each lename in the Other Source eld, the lename extension in the Ext eld, and the pathname in the Other Source Path eld. These elds are part of an array that can specify up to 100 other modules, such as C language source les or object les. If you have INFORMIX-ESQL/C installed on your system, you can also specify ESQL/C source modules (with extension .ec) here.
To specify any function libraries that should be linked to your program (besides the 4GL library that is described in Chapter 5, Built-In Functions and Operators), choose the Libraries option. This option enables you to enter or edit the list of library names in the Libraries elds. To specify compiler ags, choose the Compile_Options option. These ags can be entered or edited in the Compile Options elds.
5. 6.
After you have correctly listed all of the modules of your program, choose the Exit option to return to the PROGRAM design menu. Choose the Compile option of the PROGRAM design menu. This option produces an executable le that contains all your 4GL program modules. Its lename is the program name that you specied, with extension .4ge. The screen lists the names of your .4gl source modules, and displays the PROGRAM design menu with the Run option highlighted.
1-32
.err error le
1-33
In Figure 1-3 the rectangles represent processes controlled by specic commands, and the circles represent les. Arrows indicate whether a le can serve as input or output (or both) for a process. This diagram is simplied and ignores the similar processes by which forms, help messages, and other components of 4GL applications are compiled, linked, and executed. The diagram outlines the following process:
s
The cycle begins in the upper-left corner with a text editor, such as vi, to produce a 4GL source module. A multi-module program can include additional 4GL source les (.4gl), ESQL/C source les (.ec), C language source les (.c), and object les (.o). The program module can then be compiled by invoking the c4gl preprocessor and compiler command. (If error messages result, nd them in the .err le and edit the source le to correct the errors. Then recompile the corrected source module.) The resulting compiled .4ge program le is an executable command le that you can run by entering its name at the system prompt:
filename.4ge
Here lename.4ge species your compiled 4GL le. The following table shows the correspondence between commands and menu options.
Menu Option Module New/Modify Compile Run Invokes UNIX System Editor 4GL Preprocessor/C Compiler 4GL Application Command vi c4gl lename.4ge
For information on the use of makeles to create 4GL applications, visit the Informix Developer Network (IDN) on the Web at the following URL:
http://www.informix.com/idn
1-34
The c4gl command compiles your 4GL source-code module (here called source.4gl) and produces an executable program called lename.4ge. The complete syntax of the c4gl command appears in the next section.
Invokes the i4glc1 preprocessor, which reads your 4GL source-code les (extension .4gl) and preprocesses them to produce extended ESQL/C code (extension .4ec). Invokes the i4glc2 preprocessor, which reads the extended ESQL/C code and preprocesses it to produce ESQL/C code (extension .ec). Invokes the i4glc3 preprocessor, which reads the ESQL/C code and preprocesses it to produce C code (extension .c). Invokes the i4glc4 preprocessor, which reads the C code and compiles it to produce an object le (extension .o). Links the object le to the ESQL/C libraries and to any additional libraries that you specify in the command line.
2. 3. 4. 5.
You must assign the lename extension .4gl to 4GL source-code modules that you compile. The resulting .4ge le is an executable version of your program.
1-35
Tip: The ESQL/C source les (with extension .ec), C source les (with extension .c), and C object les (with extension .o) are intermediate steps in producing an executable 4GL program. Besides .4gl source les, you can also include les of any or all of these types when you specify a c4gl command to compile and link the component modules of a 4GL program.
1-36
c4gl Command
c4gl Command
The c4gl command is a shell script that supports the following syntax.
c4gl
-linenos -ansi -nokeep -keep -nolinenos -static -shared -z -a -anyerr -localcurs -globcurs
esqlc.ec src.c obj.o yourlib
-c -phase -e
1 2 3 4 5
-o outle -args
source.4gl
-V
Description are other arguments for your C compiler. is an ESQL/C source le to compile and link. is an object le to link with your 4GL program. is a name that you assign to the compiled 4GL program. is the name of a 4GL source module and its .4gl extension. is a C language source le to compile and link. is a function library other than the 4GL or ESQL/C libraries.
The c4gl command passes all C compiler arguments (args) and other C source and object les (src.c, obj.o) directly to the C compiler (typically cc). If you omit the -o outle option, the default lename is a.out.
1-37
c4gl Command
You can compile 4GL modules separately from your MAIN program block. If there is no MAIN program block in source.4gl, your code is compiled to source.o but is not linked with other modules or libraries. You can use c4gl to link your code with a module that includes the MAIN program block at another time. (For more information, see MAIN on page 4-245.) If you typically compile with the same options, you can set the C4GLFLAGS environment variable to supply those options implicitly. See the section C4GLFLAGS on page D-10 for details of this feature. To display the release version number of your SQL software, use the -V option. If you specify the -V option, all other arguments are ignored, and no output les are produced.
ANSI Compliance
To instruct the compiler to check all SQL statements for compliance with the ANSI/ISO standard for SQL syntax, include the -ansi option. If you specify the -ansi option, it must appear rst in your list of c4gl command arguments. The -ansi option asks for compile-time and runtime warning messages if your source code includes Informix extensions to the ANSI/ISO standard for SQL. Compiler warnings and error messages are saved in a le called source.err.
ANSI C compilers generate a warning if line numbers generated from the compilation are greater than 32767. Line numbers greater than 32767 can occur in compiled 4GL when the underlying ESQL/C compiler works on a large program. You can suppress these warnings with the -nolinenos option of c4gl. You can also explicitly set the default ANSI warnings with the -linenos option. 1-38 IBM Informix 4GL Reference Manual
c4gl Command
Array Bounds
To have your compiled program check array bounds at runtime, include the -a option, which must appear on the command line before the source.4gl lename. The -a option requires additional runtime processing, so you might prefer to use this option only during development to debug your program.
Error Scope
If you specify the -anyerr option, 4GL sets the status variable after evaluating expressions. The -anyerr option overrides any WHENEVER ERROR statements in your program.
Intermediate Files
When the compilation completes successfully, c4gl automatically removes the intermediate les with extensions .c, .ec, and .4ec, which are generated during the rst four phases of compilation. (Some earlier versions of 4GL did not delete these les.) If the compilation fails or is interrupted, however, all the intermediate les are left intact. The -keep option explicitly species that the intermediate les be retained. The default is the -nokeep option, which species that the intermediate les be removed. The .o le is retained if you specify the -c ag, but if an executable is produced, whether the .o le is kept or removed depends on the C compiler in use. Some compilers keep the .o le, and others remove it depending on what else you specify on the command line. If you direct c4gl to do -phase 1234, the .c le is no longer an intermediate le and it is retained. Similarly, if you request -phase 1, the .4ec les are no longer intermediate les, and so they are kept.
1-39
c4gl Command
Informal Functions
The -z option enables c4gl to compile a program that invokes a single function with a variable number of arguments without i4glc1 giving an error at compile time. Although fglc supports the -z option, some earlier releases of c4gl ignore the option, so it is not possible to use the standard script to compile programs that include such functions. (Most developers should not use this option, because it suppresses error messages for all functions with variable numbers of arguments.)
1-40
c4gl Command
1-41
c4gl Command
You can use i4glc4 on its own. It takes the following arguments: -V -D -s ext -o prints version information (does not process any les). emits #define SQLCA_INCL as the rst line of output. creates backup le with the extension .ext. overwrites input les.
By default, i4glc4 writes the converted le or les to standard output, but you can overwrite the original le using the -o option; you can back up the original le with any extension you choose; there is no default le extension. The i4glc4 compiler automatically inserts a period ( . ) between the name and the extension. The -o and -s options are mutually exclusive and require a lename argument. Otherwise, i4glc4 processes any les specied, or processes standard input if no lenames are provided.
Shared Libraries
Effective with INFORMIX-4GL C Compiler Version 6.0, Informix provides a shared-library implementation of the 4GL program libraries on many platforms. The shared library provides reduced memory consumption, faster program start-up, and substantially reduced program le sizes (thereby saving le system space). Shared-library support exists for compiled 4GL only. RDS runners (fglgo or customized runners) are inherently shared because all active users run the same executable le. This feature is most useful for those installations that have a variety of compiled 4GL applications. The 4GL library code exists in only one place in memory and does not have to be added to each 4GL executable le. On a system with a large number of 4GL programs, the disk space and memory savings can be substantial. Informix does not provide a shared-library implementation on all platforms. On some platforms, shared libraries are not available and on others the operating system implementation of shared libraries is not compatible with the Informix code stream.
1-42
c4gl Command
To determine if your platform has a shared-library implementation of 4GL, look at the C4GL help messages. You can display these messages by running c4gl with no arguments. A help line for the shared option contains one of these messages:
-shared Use dynamic linking and shared libraries
or:
-shared (Not available on this platform)
If the former message is the one given for your platform, a 4GL shared-library implementation is provided, and the -shared option is available for your use. You can demonstrate the memory and le-size savings for your platform by compiling the 4GL demonstration program (demo4) with and without the -shared ag, and comparing the outputs of ls and size for each of the following programs:
s s s s s
i4gldemo c4gl -shared d4_*.4gl -o demo4.shared c4gl d4_*.c -o demo4 ls -l demo4* size demo4*
Some platforms provide commands that show the dependencies of a compiled program on the shared libraries. For instance, on current Sun platforms, the command is ldd. For more technical information about shared-library concepts, refer to your operating system documentation. If your system has man pages (on-line manuals), the man page for ld might direct you to the appropriate area of your system documentation.
1-43
c4gl Command
You must set the -shared parameter explicitly, because the default is -static, specifying not to use shared libraries. If you attempt to use the -shared option on a platform for which no shared-library support exists, a warning message is displayed to standard error, and compilation continues with the normal static libraries. Many platforms require that dynamically linked (shared-library) programs be compiled with position-independent code production from the C compiler. The c4gl script automatically takes care of this for you. Mixing normal and position-independent code can produce errors. When you compile with the -shared ag, be sure to recompile all modules from the .4gl source if you had previously compiled any without the -shared ag. Consider the following example:
c4gl myprog.4gl myutil1.4gl myutil2.4gl -o myprog c4gl -shared myprog.o myutil1.o myutil2.o -o myprog.shared
Executing this code can produce errors because the objects have not been compiled with the position-independent option. Alternatively, the following code is perfectly acceptable, as the myutil objects have been compiled with position-independent code (if applicable to your platform):
c4gl -shared myprog.4gl myutil1.4gl myutil2.4gl -o myprog.shared <change myprog.4gl> c4gl -shared myprog.4gl myutil1.o myutil2.o -o myprog.shared
Important: For some platforms, the system linker (ld) enforces much stricter namecollision constraints when you use shared libraries. If you have multiple functions in your program with the same name, you might get errors when compiling with shared libraries even if the program links successfully with the static libraries. In such a case, to eliminate the name collision you need to rename one of the functions.
1-44
c4gl Command
Technical Details
The name and location of the 4GL shared library varies depending on the version of 4GL you are using, the naming convention for shared libraries on your platform, and the ability of the linker on your platform to locate shared libraries in nonstandard directories. The name of the shared library begins with lib4gsh and continues with a three-digit version indicator (for example, 604 for the 6.04 release). The sufx is platform dependent; common values are .so and .a. In most cases, the 4GL shared library resides with the other 4GL libraries in the $INFORMIXDIR/lib/tools directory. If your platform does not allow shared libraries in nonstandard directories, your system administrator might have to copy the library to a standard system directory such as /lib or /usr/lib. Look in the machine-specic notes for your platform to see if this is necessary. Most, if not all, platforms require that any programs that change their user ID dynamically while running (often referred to as setuid programs) and use shared libraries can only access those shared libraries in standard system directories. Therefore, if you have a setuid 4GL program that uses the 4GL shared library, your system administrator must copy or link the 4GL shared library to a standard directory.
Runtime Requirements
Unlike static-linked 4GL programs, 4GL programs that use the shared library must have access to that library at runtime. Most platforms provide an environment variable that instructs the linking program loader of the operating system to add one or more nonstandard directories to its sharedlibrary search list. Common examples of names for this variable are LD_LIBRARY_PATH, LPATH, or SHLIB_PATH. The machine-specic notes provided with 4GL contain the appropriate variable name for your platform. To run your shared-library 4GL applications, you must have this variable set properly in its shell environments. See the following examples.
Shell Bourne or Korn Command
LD_LIBRARY_PATH=$INFORMIXDIR/lib: $INFORMIXDIR/lib/esql:$INFORMIXDIR/lib/tools export LD_LIBRARY_PATH setenv LD_LIBRARY_PATH ${INFORMIXDIR}/lib/tools
C variants
1-45
c4gl Command
Releases of 4GL earlier than Version 7.31 required a different setting. Be sure that all potential users set their environments accordingly or update global environment scripts as applicable for their site. If you develop 4GL applications that are sent out to other systems, the shared library must be available to those systems also. All platforms that have 4GL shared-library support also have the 4GL shared library included in corresponding runtime versions of 4GL. Be sure to notify your remote users and runtime customers of these environment variable needs.
In the next example, the object les mod1.o, mod2.o, and mod3.o are previously compiled 4GL modules, and mod4.4gl is a source-code module. Suppose that you wish to compile and link mod4.4gl with the three object modules to create an executable program called myappl.4ge. To do so, enter the following command line:
c4gl mod1.o mod2.o mod3.o mod4.4gl -o myappl.4ge
Some 4GL programs might require additional command-line arguments, such as arguments or lenames, depending on the logic of your application. See the descriptions of the built-in functions ARG_VAL( ) on page 5-18 and NUM_ARGS( ) on page 5-99, which can return individual command-line arguments (and the number of command-line arguments) to a calling context within the 4GL application.
1-46 IBM Informix 4GL Reference Manual
No special procedures are needed to create, compile, or execute programs that call C or ESQL/C functions when you use the C Compiler implementation of 4GL. For more information, see Appendix C, Using C with INFORMIX-4GL.
The last three les do not exist unless you create or modify a screen form specication le, as described in Chapter 6, Screen Forms. Under normal conditions, 4GL also creates certain backup les and intermediate les as necessary and deletes them when a compilation is successful. If something interrupts a compilation, however, you might nd one or more of these backup or intermediate les in your current directory. For more information, see Intermediate Files on page 1-39. Warning: INFORMIX-4GL is not designed to support two or more programmers working concurrently in the same directory. If several developers are working on the same 4GL application, make sure that they do their work in different directories.
1-47
The following table identies some backup and intermediate les that can be produced when you compile 4GL code to C code from the Programmers Environment.
File le.4bl le.4bo le.4be le.err Description 4GL source backup le, created during modication and compilation of .4gl program modules Object backup le, created during compilation of .o program modules Object backup le, created during compilation of .4ge program modules 4GL source error le, created when an attempt to compile a module fails. The le contains 4GL source code, as well as any compiler syntax error or warning messages. Intermediate source le, created during the normal course of compiling a 4GL module. Intermediate C le, created during the normal course of compiling a 4GL module. 4GL object error le, created when an attempt to compile or to link a non-4GL source-code or object module fails. The le contains 4GL source code and annotated compiler errors. Intermediate output of the i4glc1 preprocessor, containing extended ESQL/C statements as input for the i4glc2 preprocessor. FORM4GL source backup le FORM4GL object backup le
During the compilation process, 4GL stores a backup copy of the le.4gl source le in le.4bl. The time stamp is modied on the (original) le.4gl source le, but not on the backup le.4bl le. In the event of a system crash, you might need to replace the modied le.4gl le with the backup copy contained in the le.4bl le. The Programmers Environment does not allow you to begin modifying a .4gl or .per source le if the corresponding backup le already exists in the same directory. After an editing session terminates abnormally, for example, you must delete or rename any backup le before you can resume editing your 4GL module or form from the Programmers Environment.
1-48 IBM Informix 4GL Reference Manual
All the menu options and screen form elds of the RDS Programmers Environment The steps for compiling and executing 4GL programs from the menus of the Programmers Environment The equivalent command-line syntax The lename extensions of 4GL source-code, object, error, and backup les
s s
1-49
This is the highest menu, from which you can reach any other menu of the Programmers Environment. You have ve options:
s s s s
Module. Work on an INFORMIX-4GL program module. Form. Work on a screen form. Program. Specify components of a multi-module program. Query-language. Use an SQL interactive interface, if you have either INFORMIX-SQL or DB-Access installed on your system. (See the documentation of these Informix products for details of their use.) Exit. Return to the operating system.
The rst three options display new menus that are described in the pages that follow. (You can also press CONTROL-W at any menu to display an on-line help message that describes your options.) As at any 4GL menu, you can choose an option in either of two ways:
s s
By typing the rst letter of the option. By using the SPACEBAR or arrow keys to move the highlight to the option that you choose, and then pressing RETURN.
1-50
Modify. Change an existing 4GL source-code module. New. Create a new 4GL source-code module. Compile. Compile an existing 4GL source-code module. Program_Compile. Compile a 4GL application program. Run. Execute a compiled 4GL module or multi-module application program. Debug. Invoke the INFORMIX-4GL Interactive Debugger to examine an existing 4GL program module or application program (if you have the Debugger product installed on your system). Exit. Return to the INFORMIX-4GL menu.
As in all of the menus of the Programmers Environment except for the INFORMIX-4GL menu, the Exit option returns control to the higher menu from which you accessed the current menu (or, when you choose Exit from the INFORMIX-4GL menu, terminates the 4GL session and returns to the system prompt). You can use these options to create and compile source-code modules of a 4GL application. (For information on creating 4GL screen forms, see The FORM Design Menu on page 1-56. For information on creating and compiling programmer-dened help messages for a 4GL application, see the description of the mkmessage utility in Appendix B.)
1-51
When you leave the editor, 4GL displays the MODIFY MODULE menu, with the Compile option highlighted.
MODIFY MODULE: Compile Save-and-exit Compile the 4GL module specification. Discard-and-exit
If you press RETURN or type c or C to choose the Compile option, 4GL displays the COMPILE MODULE menu.
COMPILE MODULE: Object Runable Exit Create object file (.4go suffix). -------------------------------------------Press CTRL-W for Help------
The Object option creates a le with a .4go extension. The Runable option creates a le with a .4gi extension. Choose the Runable option if the current program module is a stand-alone 4GL program. If this is not the case (that is, if the le is one of several 4GL source-code modules within a multi-module program), you should use the Object option instead, and you must use the PROGRAM design menu to specify all the component modules. After you choose Object or Runable, a message near the bottom of the screen advises you if 4GL issues a compile-time warning or error. If there are warnings (but no errors), a p-code le is produced. Choose the Exit option of the next menu, and then Save-and-exit at the MODIFY MODULE menu, if you prefer to save the p-code le without reading the warnings. Alternatively, you can examine the warning messages by choosing Correct at the next menu. When you nish editing the .err le that contains the warnings, you must choose Compile again from the MODIFY MODULE menu, because the Correct option deletes the p-code le.
1-52 IBM Informix 4GL Reference Manual
If you choose to correct the errors, an editing session begins on a copy of your source module with embedded error messages. (You do not need to delete error messages, because 4GL does this for you.) Correct your source le, save your changes, and exit from the editor. The MODIFY MODULE menu reappears, prompting you to recompile, save, or discard your changes without compiling. If there are no compilation errors, the MODIFY MODULE menu appears with the Save-and-Exit option highlighted. If you choose this option, 4GL saves the current source-code module as a disk le with the lename extension .4gl, and saves the compiled version as a le with the same lename, but with the extension .4go or .4gi. If you choose the Discard-and-Exit option, 4GL discards any changes that were made to your le after you chose the Modify option.
1-53
The New option resembles the Modify option, but NEW MODULE is the menu title, and you must enter a new module name, rather than choose it from a list. If you have not designated an editor previously in this session or with DBEDIT, you are prompted for the name of an editor. Then an editing session begins.
After you specify the name of a 4GL source-code module to compile, the screen displays the COMPILE MODULE menu. For information on the COMPILE MODULE menu options, see The Modify Option on page 1-51.
1-54
The RUN PROGRAM screen presents a list of compiled modules and programs, with the highlight on the module corresponding to the current le, if any has been specied. Compiled programs must have the extension .4gi to be included in the list. If you compile a module with the extension .4go, you can run it by typing the lename and extension at the prompt. If no compiled programs exist, 4GL displays an error message and restores the MODULE design menu.
If you have the Debugger product, refer to the Guide to the INFORMIX-4GL Interactive Debugger for more information about this option.
1-55
You can use this menu to create, modify, and compile screen form specications. These specications dene visual displays that 4GL applications can use to query and modify the information in a database. 4GL screen form specications are ASCII les that are described in Chapter 6.
1-56
Modify. Change an existing 4GL screen form specication. Generate. Create a default 4GL screen form specication. New. Create a new 4GL screen form specication. Compile. Compile an existing 4GL screen form specication. Exit. Return to the INFORMIX-4GL menu.
If you are familiar with the menu system of INFORMIX-SQL, you might notice that this menu resembles the menu displayed by the Form option of the INFORMIX-SQL main menu. For descriptions of the usage and statement syntax of 4GL screen form specications, see Chapter 6.
If you choose this option, you are prompted to choose the name of a form specication le to modify. Source les created at the FORM design menu (or at the command line by the form4gl screen form facility) have the le extension .per.
1-57
If you have not already designated a text editor in this 4GL session or with DBEDIT, you are prompted for the name of an editor. Then an editing session begins, with the form specication source-code le that you specied as the current le. When you leave the editor, 4GL displays the MODIFY FORM menu with the Compile option highlighted.
MODIFY FORM: Compile Save-and-exit Compile the form specification. Discard-and-exit
Now you can press RETURN to compile the revised form specication le. If the compiler nds errors, the COMPILE FORM menu appears.
COMPILE FORM: Correct Exit Correct errors in the form specification. -------------------------------------------Press CTRL-W for Help------
Press RETURN to choose Correct as your option. An editing session begins on a copy of the current form, with diagnostic error messages embedded where the compiler detected errors. 4GL deletes these messages when you save the edited le and exit from the editor. After you correct the errors, the MODIFY FORM menu appears again, with the Compile option highlighted. Press RETURN to recompile. If there are no compilation errors, you are prompted to either save the modied form specication le and the compiled form, or discard the changes. (Discarding the changes restores the version of your form specications from immediately before you chose the Modify option.)
1-58
When you choose this option, 4GL prompts you to choose a database, to choose a lename for the form specication, and to identify the tables that the form will access. After you provide this information, 4GL creates and compiles a form specication le. This process is equivalent to running the -d (default) option of the form4gl command, as described in Compiling a Form at the Command Line on page 6-87.
After prompting you for the name of your form specication le, 4GL places you in the editor where you can create a form specication le. When you leave the editor, 4GL transfers you to the NEW FORM menu that is like the MODIFY FORM menu. You can compile your form and correct it in the same way.
Compiling INFORMIX-4GL Source Files 1-59
4GL prompts you for the name of the form specication le and then performs the compilation. If the compilation is not successful, 4GL displays the COMPILE FORM menu with the Correct option highlighted.
1-60
You can use this menu to create or modify a multi-module 4GL program specication, or to compile, execute, or analyze a program.
Compiling INFORMIX-4GL Source Files 1-61
Modify. Change an existing program specication. New. Create a new program specication. Compile. Compile an existing program. Planned_Compile. Display the steps to compile an existing program. Run. Execute an existing program. Debug. Invoke the Debugger. Undene. Delete an existing program specication. Exit. Return to the INFORMIX-4GL menu.
s s s s
You must rst use the MODULE design menu and FORM design menu to enter and edit the 4GL statements within the component source-code modules of a 4GL program. Then you can use the PROGRAM design menu to identify which modules are part of the same application program, and to combine all the 4GL modules in an executable program.
1-62
-------------------------------------------Press CTRL-W for Help-----Program [myprog ] Runner [fglgo ] Runner Path [ ] Debugger [fgldb ] Debugger Path [ ] 4gl Source [main [funct [rept [ [ 4gl Source Path [/u/john/appl/4GL [/u/john/appl/4GL [/u/john/appl/4GL [ [ Global Source Path [ [ Other .4go Path [ [
] ] ] ] ]
] ] ] ] ]
] ]
] ]
The name of the program appears in the Program eld. In Figure 1-4 this name is myprog. You can change the name by choosing the Rename option. The program name, with extension .4gi, is assigned to the program produced by compiling and combining all the source les. (Compiling and combining occurs when you choose the Compile option, as described in The Compile Option on page 1-66, or the Program_Compile option of the MODULE design menu.) In this case, the runable program would have the name myprog.4gi.
1-63
The 4GL option enables you to update the entries for the 4gl Source and 4gl Source Path elds. The ve rows of elds under these labels form a screen array. If you choose the 4GL option, 4GL executes an INPUT ARRAY statement so that you can move through the array and scroll for up to a maximum of 100 entries. The INPUT ARRAY statement description in Chapter 4 explains how to use function keys to scroll, delete rows, and insert new rows. (You cannot redene function keys, however, as you can with a 4GL program.) In the example shown in Figure 1-4, the 4GL source program has been broken into three modules:
s s s
One module contains the main program (main.4gl). One module contains functions (funct.4gl). One module contains REPORT statements (rept.4gl).
These modules are all located in the directory /u/john/appl/4GL. If a module contains only global variables, you can list it here or in the Global Source array. The Globals option enables you to update the Global Source array. If you use the Global Source array to store a globals module, any modication of the globals module le causes all 4GL modules to be recompiled when you choose the Compile option. The Other option enables you to update the entries for the Other .4go and Other .4go Path elds. This is where you specify the name and location of other 4GL object les (.4go les) to include in your program. Do not specify the lename extensions. You can list up to 100 les in this array. The Program_Runner option enables you to specify the name and location of the p-code runner to execute your program. You can run 4GL programs with fglgo (the default) or with a customized p-code runner. A customized p-code runner is an executable program that you create to run 4GL programs that call C functions. (See RDS Programs That Call C Functions on page 1-83.) If you do not modify the Runner eld, your program is executed by fglgo when you choose the Run option from the PROGRAM design menu.
1-64
The MODIFY PROGRAM screen form contains two additional elds labeled Debugger and Debugger Path. If you have the Debugger, you can also use the Program_Runner option to enter the name of a customized debugger. See RDS Programs That Call C Functions on page 1-83 for information about the use of a customized debugger. For the procedures to create a customized debugger, refer to Appendix C of the Guide to the INFORMIX-4GL Interactive Debugger, which includes an example. The Exit option of the MODIFY PROGRAM menu returns you to the PROGRAM design menu.
The lename of the module must be unique among source-code modules of the same 4GL program, and can include up to ten characters, not including the .4gl le extension. The New option is identical to the Modify option, except that you must rst supply a name for your program. 4GL then displays a blank form with a NEW PROGRAM menu that has the same options as the MODIFY PROGRAM menu.
1-65
The Compile option produces a runable p-code le with a .4gi extension. 4GL lists each step of the compilation as it occurs.
------------------------------------------------Press CTRL-W for Help-----Compiling INFORMIX-4GL sources: /u/john/appl/4GL/main.4gl /u/john/appl/4GL/funct.4gl /u/john/appl/4GL/rept.4gl Linking other objects: /u/john/appl/Com/obj.4go
If you have made changes in all the components of the program listed in Figure 1-4 on page 1-63 since the last time that they were compiled, 4GL displays the previous screen.
1-66
The screen lists any compiled programs (les with the extension .4gi) and highlights the current program, if one has been specied. This option resembles the Run option of the MODULE design menu. Although .4go les are not displayed, you can also enter the name and extension of a .4go le. Whatever compiled program you choose is executed by fglgo or by the runner that you specied in the Runner eld of the Program Specication screen. This screen was illustrated earlier, in the description of the MODIFY PROGRAM menu.
1-67
1-68
After a sign-on message, the INFORMIX-4GL menu appears. Creating a 4GL application with the Rapid Development System requires the following steps:
1. 2. 3. 4.
Creating a new source module or revising an existing source module Compiling the source module Linking the program modules Executing the compiled program
Choose the Module option of the INFORMIX-4GL menu by pressing M or by pressing RETURN. The MODULE design menu is displayed. If you are creating a new .4gl source module, press N to choose the New option of the MODULE design menu. Enter a name for the new module. The name must begin with a letter, and can include letters, numbers, and underscores. The name must be unique among the les in the same directory, and among the other program modules, if it will be part of a multi-module program. 4GL attaches the extension .4gl to this identier, as the lename of your new source module.
2. 3.
4.
Press RETURN.
1-69
Choose the Modify option of the MODULE design menu. The screen lists the names of all the .4gl source modules in the current directory and prompts you to choose a source le to edit.
2.
Use the arrow keys to highlight the name of a source module and press RETURN, or enter a lename (with no extension). If you specied a default editor with the DBEDIT environment variable, an editing session begins automatically. Otherwise, the screen prompts you to specify a text editor. Specify the name of a text editor, or press RETURN for vi, the default editor. Now you can begin an editing session by entering 4GL statements. (Chapters that follow describe 4GL statements and expressions, as well as built-in functions and operators.)
3.
When you have nished entering or editing your 4GL code, use an appropriate editor command to save your source le and end the text editing session.
1-70
Choose the Compile option from the MODULE design menu. Select the type of module that you are compiling, either Object or Runable. If the module is a complete 4GL program that requires no other modules, choose Runable. This option creates a compiled p-code version of your program module, with the same lename, but with the extension .4gi. If the module is one module of a multi-module 4GL program, choose Object. This creates a compiled p-code version of your program module, with the same lename, but with the extension .4go. For more information, see Combining Program Modules on page 1-72.
3.
If the compiler detects errors, no compiled le is created, and you are prompted to x the problem. Choose Correct to resume the previous text editing session, with the same 4GL source code, but with error messages in the le. Edit the le to correct the error, and choose Compile again. If an error message appears, repeat this process until the module compiles without error.
4.
After the module compiles successfully, choose Save-and-exit from the menu to save the compiled program. The MODULE design menu appears again on your screen. If your program requires screen forms, choose Form from the INFORMIX-4GL menu to display the FORM design menu. For information about designing and creating screen forms, see Chapter 6. If your program displays help messages, you must create and compile a help le. Use the mkmessage utility to compile the le. For more information about this utility, see Appendix B.
5.
6.
1-71
Important: This version of the runner or Debugger cannot interpret programs compiled to p-code by releases of 4GL earlier than Version 7.30. You must rst recompile your source les and form specications. Similarly, releases of the 4GL runner or Debugger earlier than Version 7.30 cannot interpret p-code that this release produces.
1-72
To combine modules
1.
Choose the Program option from the INFORMIX-4GL menu. The PROGRAM design menu appears. If you are creating a new multi-module 4GL program, choose the New option; if you are modifying an existing one, choose Modify. In either case, the screen prompts you for the name of a program. Enter the name (without a le extension) of the program that you are modifying, or the name to be assigned to a new program. Names must begin with a letter, and can include letters, underscores ( _ ) symbols, and numbers. After you enter a valid name, the PROGRAM screen appears, with your program name in the rst eld. If you chose Modify, the names and pathnames of the source-code modules are also displayed. The PROGRAM screen appears below the MODIFY PROGRAM menu, rather than below the NEW PROGRAM menu. (Both menus list the same options.)
NEW PROGRAM: 4GL Globals Edit the 4GL sources list. Other Program_Runner Rename Exit
2.
3.
---------------------------------------- Press CTRL-W for Help ------Program [ ] Runner [fglgo ] Runner Path [ ] Debugger[fgldb ] Debugger Path [ ] 4gl Source [ ] [ ] [ ] [ ] [ ] 4gl Source Path [ [ [ [ [
] ] ] ] ]
Global Source Global Source Path [ ] [ [ ] [ Other .4go [ ] [ ] Other .4go Path [ [
] ]
] ]
1-73
4.
To specify new 4GL modules or edit the list of 4GL modules, choose the 4GL option. You can enter or edit the name of a module under the heading 4GL Source; the .4gl le extension is optional. Repeat this step for every module. If the module is not in the current directory or in a directory specied by the DBPATH environment variable, enter the pathname to the directory where the module resides. The name of the runner (and of the Debugger, if you have the Debugger) are usually as illustrated in the PROGRAM screen, unless your 4GL program calls C functions. For information on calling C functions, see RDS Programs That Call C Functions on page 1-83.
To enter or edit the name or pathname of a Globals module, choose the Globals option and provide the corresponding information. To enter or edit the le or pathname of any .4go modules that you have already compiled, choose the Other option.
5. 6.
After you correctly list all of the modules of your 4GL program, choose the Exit option to return to the PROGRAM design menu. Choose the Compile option of the PROGRAM design menu. This option produces a le that combines all of your .4gl source les into an executable program. Its lename is the program name that you specied, with extension .4gi. The screen lists the names of your .4gl source modules and displays the PROGRAM design menu with the Run option highlighted.
1-74
In Figure 1-5, the rectangles represent processes controlled by specic commands, and the circles represent les. Arrows indicate whether a le serves as input or output for a process. (For the sequence of operating system commands to create multi-module 4GL programs, see Figure 1-6 on page 1-79.)
Compiling INFORMIX-4GL Source Files 1-75
This diagram is simplied and ignores the similar processes by which forms, help messages, and any other components of 4GL applications are compiled and executed. The diagram outlines the following process:
s
The cycle begins in the upper-left corner with a text editor, such as vi, to produce a 4GL source module. The program module can then be compiled, using the fglpc p-code compiler. (If error messages are produced by the compiler, nd them in the .err le, and edit the .4gl le to correct the errors. Then recompile the corrected .4gl le.) The following command line invokes the p-code runner:
fglgo filename
where lename species a compiled 4GL le to be executed. Executing a program that is undergoing development or modication sometimes reveals the existence of runtime errors. If you have licensed the Debugger, you can invoke it to analyze and identify runtime errors in your program by entering the command:
fgldb filename
where lename species your compiled 4GL le. You can then recompile and retest the program. When it is ready for use by others, they can use the fglgo runner to execute the compiled program. A correspondence between commands and menu options of the RDS Programmers Environment is summarized by the following list.
Command Invokes UNIX System Editor 4GL P-Code Compiler 4GL P-Code Runner 4GL Interactive Debugger Menu Option Module New/Modify Compile Run Debug
Subsequent sections of this chapter describe how to use the Rapid Development System to compile and execute 4GL programs that call C functions. (This requires a C language compiler and linker, which are unnecessary for 4GL applications in p-code that do not call programmer-dened C functions.)
1-76 IBM Informix 4GL Reference Manual
fglpc Command
The fglpc command supports the following syntax.
fglpc
source
.4gl -p pathname
-V
Element pathname source Description is the pathname of a directory to hold object and error les. is the name of a 4GL source module. The .4gl extension is optional.
The fglpc command reads source.4gl les and creates a compiled version of each, with the lename source.4go. You can specify any number of source les, in any order, with or without their .4gl lename extensions.
1-77
To instruct the compiler to check all SQL statements for compliance with the ANSI/ISO standard for SQL, use the -ansi option. If you specify the -ansi option, it must appear rst among fglpc command arguments. Including the -ansi option asks for compile-time and runtime warning messages if your source code includes Informix extensions to the ANSI/ISO standard for SQL. If an error or warning occurs during compilation, 4GL creates a le called source.err. Look in source.err to nd where the error or warning occurred in your code. If you specify the -anyerr option, 4GL sets the status variable after evaluating expressions (in addition to setting it after each SQL statement executes, and after errors in 4GL screen I/O or validation statements. The -anyerr option overrides any WHENEVER ERROR directives in your program. You can use the -p pathname option to specify a nondefault directory for the object (.4go) and error (.err) les. Otherwise, any les produced by fglpc are stored in your current working directory. To have your compiled program check array bounds at runtime, specify the -a option. The -a option requires additional processing, so you might prefer to use this option only for debugging during development. If you typically compile with the same options, you can set the FGLPCFLAGS environment variable to supply those options implicitly. See the section FGLPCFLAGS on page D-43 for details of this feature. The -globcurs option lets you make the names of cursors and of prepared objects global to the entire program. The compilers still require you to declare the cursor before using it for any other purpose in the module, so this option is seldom useful. This option might help in debugging, however, because the cursor names are not modied. See the section The -globcurs and -localcurs Options on page 1-40 for more information about the scope of cursor names. The -localcurs option can override the -globcurs option if that was set in the C4GLFLAGS environment variable, and makes the names of cursors and prepared objects local to the module in which they were declared. To display the version number of the software, specify the -V option. The version number of your SQL and p-code compiler software appears on the screen. Any other command options are ignored. After displaying this information, the program terminates without compiling.
1-78
Examples
The following command compiles a 4GL source le single.4gl, and creates a le called single.4go in the current directory:
fglpc single.4gl
This command generates two compiled les, leone.4go and letwo.4go, and stores them in subdirectory /u/ken. Any compiler error messages are saved in le leone.err or letwo.err in the same directory.
1-79
The UNIX cat command combines the listed les into the le specied after the redirect ( > ) symbol. For example, the following command combines a list of .4go les into a new le called new.4gi:
cat file1.4go file2.4go ... fileN.4go new.4gi
The new lename of the combined le must have either a .4go or a .4gi extension. The extension .4gi designates runable les that have been compiled (and concatenated, if several source modules make up the program). You might wish to follow this convention in naming les, because only .4gi les are displayed from within the Programmers Environment. This convention is also a convenient way to distinguish complete program les from object les that are individual modules of a multi-module program. If your 4GL program calls C functions or ESQL/C functions, you must follow the procedures described in RDS Programs That Call C Functions on page 1-83 before you can run your application.
fglgo Command
The fglgo command supports the following syntax.
fglgo -anyerr
argument
Description is the name of a compiled 4GL le. The lename must have a .4go or .4gi extension. You do not need to enter this extension. are any arguments required by your 4GL program.
1-80
If you do not specify a lename extension, fglgo looks rst for the lename with a .4gi extension, and then for the lename with a .4go extension. Unlike fglpc, the fglgo command needs no -a option to check array bounds at runtime, because array bounds are always checked. If you specify the -anyerr option, 4GL sets the status variable after evaluating expressions. This option overrides any WHENEVER ERROR statements. To display the version number of the software, specify the -V option. The version number of your SQL and p-code software appears on the screen. Any other command options are ignored. After displaying this information, the program terminates without invoking the p-code runner. 4GL runners earlier than Version 7.3 cannot run programs that use 7.3 or later compilers, and you must recompile programs compiled with earlier versions of the 4GL compiler before a 7.3 or later runner can interpret them. Important: To run a 4GL program that calls programmer-dened C functions, you cannot use fglgo. You must instead use a customized p-code runner. RDS Programs That Call C Functions on page 1-83 describes how to create a customized runner.
Examples
To run a compiled program named myprog.4go, enter the following command line at the operating system prompt:
fglgo myprog
or:
fglgo myprog.4go
1-81
You can then run the mods.4gi program by using the command line:
fglgo mods
or:
fglgo mods.4gi
where lename is any runable 4GL le that you produced by an fglpc command. For the complete syntax of the fgldb command, see the Guide to the
INFORMIX-4GL Interactive Debugger.
1-82
Edit a structure denition le to contain information about your C functions. This le is named fgiusr.c and is supplied with 4GL. Compile and link the fgiusr.c le with the les that contain your C functions. To do this, use the cfglgo command.
2.
You can then use the runner produced by the cfglgo command to run the 4GL program that calls your C functions. Both the fgiusr.c le and the cfglgo command are described in the sections that follow. For an example of how to call C functions from a 4GL program, see INFORMIX-4GL by Example. Important: To create a customized runner, you must have a C compiler installed on your system. If the only functions that your Rapid Development System program calls are 4GL or ESQL/C library functions, or functions written in the 4GL language, you do not need a C compiler and you do not need to follow the procedures described in this section.
1-83
1-84
The fgiusr.c le is a C language le that you can edit to declare any number of programmer-dened C functions. To edit fgiusr.c, you can copy the le to any directory. (Unless this is your working directory at compile time, you must specify the full pathname of the edited fgiusr.c le when you compile.) Edit fgiusr.c to specify the following:
s
In the declaration of the function, the parenthesis symbols ( ) must follow the function-name. The rst initializer is the function name between double quotation marks and is a character pointer. The second initializer is the function name (without quotation marks) and is a function pointer. It cannot include a parentheses. The third initializer is an integer representing the number of arguments expected by the function. If the number of arguments expected by the function can vary, you must make the third argument the maximum number of arguments, prexed with a minus ( - ) sign. You must use a comma ( , ) symbol to separate each of the three initializers. Insert a set of initializers for each C function that you declare. A line of three zeroes indicates the end of the structure. Here is an example of an edited fgiusr.c le:
#include "fgicfunc.h" int function-name(); cfunc_t usrcfuncs[] = { {"function-name",function-name,1}, { 0,0,0 } };
Here the 4GL program will be able to call a single C function called function-name that has one argument.
1-85
If you have several 4GL programs that call C functions, you can use fgiusr.c in either of two ways:
s
You can create one customized p-code runner. In this case, you can edit fgiusr.c to specify all the C functions called from all your 4GL programs. After you create one comprehensive runner, you can use it to execute all your 4GL applications.
You can create several application-specic runners. In this case, you can either make a copy of the fgiusr.c le (with a new name) for each customized runner, or you can re-edit fgiusr.c to contain information on the C functions for a specic application before you compile and link. If you create several runners, you must know which customized runner to use with each 4GL application.
In some situations the rst method is more convenient, because users do not need to keep track of which runner supports each 4GL application.
1-86
cfglgo Command
The cfglgo command supports the following syntax.
cfglgo
fgiusr.c
cle
.ec .c .o -V
-o newfglgo
Element
Description is the name of a source le containing ESQL/C or C functions to be compiled and linked with the new runner, or the name of an object le previously compiled from a .c or .ec le. species the name of the customized runner.
cle
newfglgo
You need the ESQL/C product to compile .ec les with cfglgo. The cfglgo command compiles and links the edited fgiusr.c le with your C program les into an executable program that can run your 4GL application. Here fgiusr.c is the name of the le that you edited to declare C or ESQL/C functions. If the fgiusr.c le to be linked is not in the current directory, you must specify a full pathname. You can also rename the fgiusr.c le. You can specify any number of uncompiled or compiled C or ESQL/C les in a cfglgo command line. When you create a customized runner with cfglgo, however, you cannot include among the cle.o object les any le that was compiled from a 4GL program. (The cfglgo script has no syntax for linking the 4GL libraries that would be required in this context.)
1-87
If you do not specify the -o newfglgo option, the new runner is given the default name a.out. To display the version number of the software, specify the -V option. The version number of your SQL and p-code software appears on the screen. Any other command options are ignored. After displaying this information, the program terminates without creating a customized p-code runner.
Examples
The following example 4GL program calls the C function prdate( ): prog.4gl:
main . . . call prdate() . . . end main
1-88
The C function is declared and initialized in the following fgiusr.c le: fgiusr.c:
1 #include "fgicfunc.h" 2 3 int prdate(); 4 cfunc_t usrcfuncs[] = 5 { 6 { "prdate", prdate, 0 }, 7 { 0, 0, 0 } 8 };
In this example, you can use the following commands to compile the 4GL program, to compile the new runner, and to run the program:
s
1-89
le.erc
1-90
The last three les do not exist unless you create or modify a screen form specication le, as described in Chapter 6. The following table lists backup les that are produced when you use 4GL from the Programmers Environment.
File le.4bl le.4bo le.4be le.pbr le.fbm Description 4GL source backup le, created during the modication and compilation of a .4gl program module Object backup le, created during the compilation of a .4go program module Object backup le, created during the compilation of a .4gi program module FORM4GL source backup le FORM4GL object backup le
Under normal conditions, 4GL creates the backup les and intermediate les as necessary, and deletes them when a compilation is successful. If you interrupt a compilation, you might nd one or more of the les in your current directory. If you compile with a fglpc command line that includes the p pathname option, 4GL creates the .4gi, .4go, .err, and corresponding backup les in the directory specied by pathname, rather than in your current directory. During the compilation process, 4GL stores a backup copy of the le.4gl source le in le.4bl. The time stamp is modied on the (original) le.4gl source le, but not on the backup le.4bl le. In the event of a system crash, you might need to replace the modied le.4gl le with the backup copy contained in the le.4bl le.
Compiling INFORMIX-4GL Source Files 1-91
The Programmers Environment does not allow you to begin modifying a .4gl or .per source le if the corresponding backup le already exists in the same directory. After an editing session terminates abnormally, for example, you must delete or rename any backup le before you can resume editing your 4GL module or form specication from the Programmers Environment. Warning: INFORMIX-4GL is not designed to support two or more programmers working concurrently in the same directory. If several developers are working on the same 4GL application, make sure that they do their work in different directories.
1-92
Chapter
2
2-3 2-3 2-3 2-4 2-5 2-5 2-8 2-8 2-8 2-9 2-10 2-12 2-13 2-14 2-14 2-15 2-17 2-19 2-19 2-22 2-23 2-24 2-24 2-24 2-25 2-25
In This Chapter .
. . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . .
Language Features . . . . . . . . . . . . . . . . . Lettercase Insensitivity . . . . . . . . . . . . . . Whitespace, Quotation Marks, Escape Symbols, and Delimiters Character Set . . . . . . . . . . . . . . . . . 4GL Statements. . . . . . . . . . . . . . . . . Comments . . . . . . . . . . . . . . . . . . Comment Indicators. . . . . . . . . . . . . . Restrictions on Comments . . . . . . . . . . . Conditional Comments. . . . . . . . . . . . . Source-Code Modules and Program Blocks . . . . . . . Statement Blocks . . . . . . . . . . . . . . . . Statement Segments . . . . . . . . . . . . . . . 4GL Identiers . . . . . . . . . . . . . . . . . Naming Rules for 4GL Identiers . . . . . . . . . Naming Rules for SQL Identiers . . . . . . . . . Scope of Reference of 4GL Identiers . . . . . . . . Scope and Visibility of SQL Identiers . . . . . . . Visibility of Identical Identiers . . . . . . . . . . Interacting with Users . . . . . . . . . Ring Menus . . . . . . . . . . . Selecting Menu Options . . . . . Ambiguous Keyboard Selections . . Hidden Options and Invisible Options Disabled Menus . . . . . . . . Reserved Lines for Menus. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Screen Forms. . . . . . . . . . . . . . . Visual Cursors . . . . . . . . . . . . . Field Attributes . . . . . . . . . . . . Reserved Lines. . . . . . . . . . . . . 4GL Windows . . . . . . . . . . . . . . The Current Window . . . . . . . . . . On-Line Help . . . . . . . . . . . . . . The Help Key and the Message Compiler . . . The Help Window . . . . . . . . . . . Nested and Recursive Statements . . . . . . . Early Exits from Nested and Recursive Operations Exception Handling. . . . . . . . . . . . . Compile-Time Errors and Warnings . . . . . . Runtime Errors and Warnings . . . . . . . . Normal and AnyError Scope . . . . . . . A Taxonomy of Runtime Errors . . . . . . Default Error Behavior and ANSI Compliance . Changes to 4GL Error Handling . . . . . . . Error Handling with SQLCA . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . .
2-25 2-26 2-27 2-27 2-28 2-28 2-29 2-30 2-30 2-31 2-36 2-40 2-40 2-40 2-41 2-42 2-43 2-44 2-45
2-2
In This Chapter
An INFORMIX-4GL program consists of at least one source le that contains a series of English-like statements. These obey a well-dened syntax that this book describes. This chapter presents a brief overview of the 4GL language. Its theory, application, constructs, and semantics are described in detail in INFORMIX-4GL Concepts and Use, a companion volume to this manual. This manual assumes that you are using Informix Dynamic Server as your database server. Features specic to INFORMIX-SE are noted.
Language Features
4GL is an English-like C or COBOL-replacement programming language that Informix Software, Inc., introduced in 1986 as a tool for creating relational database applications. Its statement set (see Chapter 4, INFORMIX-4GL Statements) includes the industry-standard SQL language for accessing and manipulating a relational database. The 4GL development environment provides a complete environment for writing 4GL programs.
Lettercase Insensitivity
4GL is case insensitive, making no distinction between uppercase and
lowercase letters, except within quoted strings. Use pairs of double ( " ) or single ( ' ) quotation marks in 4GL code to preserve the lettercase of character literals, lenames, and names of database entities, such as cursor names. You can mix uppercase and lowercase letters in the identiers that you assign to 4GL entities, but any uppercase letters in 4GL identiers are automatically shifted to lowercase during compilation.
The INFORMIX-4GL Language 2-3
characters, comments, and extra blank spaces between statements or statement elements. You can freely use these whitespace characters to make your 4GL source code easier to read.
LINEFEED
Blank (ASCII 32) characters act as delimiters in some contexts. Blank spaces must separate successive keywords or identiers, but cannot appear within a keyword or identier. Pairs of double ( " ) or single ( ' ) quotation marks must delimit any character string that contains a blank (ASCII 32) or other whitespace character, such as LINEFEED or RETURN. Do not mix double and single quotation marks as delimiters of the same string. For example, the following is not a valid character string:
'Not A valid character string"
If you are using Informix DRDA software to access a non-Informix relational database, such as a DB2 database from IBM, double quotation marks might not be recognized as delimiters by the non-Informix database. Similarly, most 4GL statements require single quotation marks if the database supports delimited SQL identiers, and in this special case cannot use double quotation marks in most contexts, because when the DELIMIDENT environment variable is set, double quotation marks are reserved for SQL identiers. To include literal quotation marks within a quoted string, precede each literal quotation mark with the backslash (\), or else enclose the string between a pair of the opposite type of quotation marks:
DISPLAY "Type 'Y' if you want to reformat your disk." DISPLAY 'Type "Y" if you want to reformat your disk.' DISPLAY 'Type \'Y\' if you want to reformat your disk.'
The 4GL compiler treats a backslash as the default escape symbol, and treats the immediately following symbol as a literal, rather than as having special signicance. To specify anything that includes a literal backslash, enter double ( \\ ) backslashes wherever a single backslash is required. Similarly, use \\\\ to represent a literal double backslash.
2-4
Character Set
Except in some PREPARE and PRINT statements, and the END SQL keywords in SQL blocks, 4GL requires no statement terminators, but you can use the semicolon (; ) as a statement terminator. Statements of the SQL language, however, that include syntax later than what Informix 4.10 database servers support require SQLEND SQL delimiters, unless the post-4.10 SQL statement appears as text in a PREPARE statement.
Character Set
4GL requires the ASCII character set, but also supports characters from the
client locale in data values, identiers, form specications, and reports. For more information, see Naming Rules for 4GL Identiers on page 2-14.
4GL Statements
4GL source-code modules can contain statements and comments:
s
A statement is a logical unit of code within 4GL programs. See Chapter 4 for a list of the statements in the 4GL statement set. A comment is a specication that 4GL disregards. For more information, see Comment Indicators on page 2-8.
A compilation error occurs if a program (or one of its modules or statement blocks) includes part of a statement but not all of the required elements. Statements of 4GL can contain identiers, keywords, literal values, constants, operators, parentheses, and expressions. These terms are described in subsequent sections of this chapter, and in Chapter 4. For the purposes of this manual, 4GL supports two types of statements:
s s
This distinction among statements reects whether they provide instructions to the database server (SQL statements) or instructions to the client application (other 4GL statements). INFORMIX-4GL Concepts and Use describes the process architecture of 4GL applications. See the documentation of your Informix database server for the syntax of SQL statements. Chapter 4 of this manual describes the syntax of 4GL statements that are not SQL statements.
The INFORMIX-4GL Language 2-5
4GL Statements
Where a given statement can appear within a 4GL program, how the Interactive Debugger treats it, and whether the statement has its effect at compile time or at runtime all depend on whether the statement is executable. The following statements of 4GL are non-executable. They dene program blocks, declare 4GL identiers, or act as compiler directives.
DEFER DEFINE FUNCTION GLOBALS LABEL MAIN REPORT WHENEVER
4GL statements (individually described in Chapter 4) begin with keywords. Some statements can include delimiters (as described earlier in this section) and expressions (as described in Chapter 3, Data Types and Expressions).
2-6
4GL Statements
Within the broad division into SQL statements and other statements, the 4GL statement set can be further classied into functional categories, whose component statements are listed in The 4GL Statement Set on page 4-9.
Types of SQL Statements Data denition statements Data manipulation statements Cursor manipulation statements Dynamic management statements Query optimization statements Data access statements Data integrity statements Stored procedure statements Optical statements Other Types of 4GL Statements Denition and declaration statements Program ow control statements Compiler directives Storage manipulation statements Screen interaction statements Report execution statements
The 4GL Statement Set on page 4-9 identies the SQL statements and other 4GL statements that make up these functional categories. Some statements, called compound statements (described in Statement Blocks on page 2-12), can contain other 4GL statements. A set of nested statements within a compound statement is called a statement block. When necessary, 4GL uses END (with another keyword to indicate a specic statement) to terminate a compound statement. Except in a few special cases, like multiple-statement prepared entities, 4GL requires no statement terminators, but you can use the semicolon as a statement terminator. If you have difculty interpreting a compilation error, you might want to insert semicolons to separate the statements that precede the error message, to indicate to the 4GL compiler where each statement ends. (The PRINT statement in 4GL reports can use semicolons to control the format of output from a report by suppressing LINEFEED.) Screen forms of 4GL are manipulated by form drivers but are dened in form specication les. These ASCII les use a syntax that is distinct from the syntax of other 4GL features. See Chapter 6, Screen Forms, for details of the syntax of 4GL form specication les.
Comments
Comments
A comment is text in 4GL source code to assist human readers, but which 4GL ignores. (This meaning of comment is unrelated to the COMMENTS attribute in a form, or to the OPTIONSCOMMENT LINE statement, both of which control on-screen text displays to assist users of the 4GL application.)
Comment Indicators
You can indicate comments in any of several ways:
s
A comment can begin with the left-brace ( { ) and end with the rightbrace ( } ) symbol. These can be on the same line or on different lines. The pound ( # ) symbol (sometimes called the sharp symbol) can begin a comment that terminates at the end of the same line. You can use a pair of hyphens or minus signs ( -- ) to begin a comment that terminates at the end of the current line. (This comment indicator conforms to the ANSI standard for SQL.)
4GL ignores all text between braces (or from the # or -- comment indicator to the end of the same line).
For clarity and to simplify program maintenance, it is recommended that you document your 4GL code by including comments in your source les. You can also use comment indicators during program development to disable statements without deleting them from your source-code modules.
Restrictions on Comments
When using comments, keep the following restrictions in mind:
s
Within a quoted string, 4GL interprets comment indicators as literal characters, rather than as comment indicators. Comments cannot appear in the SCREEN section of a form specication le. The # symbol cannot indicate comments in a form specication, in an SQL statement block, nor in the text of a prepared statement. You cannot use braces ( { } ) to nest comments within comments.
2-8
Comments
You cannot specify consecutive minus signs ( -- ) in arithmetic expressions, because 4GL interprets what follows as a comment. Instead, use a blank space or parentheses to separate consecutive arithmetic minus signs. For example:
LET x = y --3 # Now variable x evaluates as y # because 4GL ignores text after -LET x = y -(-3) # Now variable x evaluates as (y + 3).
The symbol that immediately follows the -- comment indicator must not be the sharp (#) or at (@) symbols, unless you intend to compile the same 4GL source le with the Dynamic 4GL product. For details of the special signicance of the # or @ symbol after the -symbols, see the next section, Conditional Comments on page 2-9.
Conditional Comments
Another Informix product, Informix Dynamic 4GL, treats the --# characters as a whitespace character, rather than as the beginning of a comment. This feature provides backward compatibility for source-code modules that begin lines containing Dynamic 4GL extensions to 4GL syntax with those symbols. When compiled by Dynamic 4GL, lines so marked are treated as statements in a graphical user interface (GUI) environment. 4GL, however, interprets --# as a comment symbol so that Dynamic 4GL syntax extensions (or anything else) that follow in the same line are ignored. Conversely, the --@ symbols act as a conditional comment indicator. The 4GL compiler interprets this indicator as a single whitespace character and reads the rest of the line. In contrast, the Dynamic 4GL compiler interprets this as a comment and ignores the rest of the line. These symbols are called conditional comment indicators because their interpretation depends on which compiler you use. Together, these features enable the same source le to support different features, depending on whether you compile with Dynamic 4GL or with 4GL. Conditional comments are supported both in source (.4gl) les, in form specication (.per) les, and in INFORMIX-SQL report (.ace) les. For example, you could use conditional comments to specify a Help le:
--# OPTIONS HELP FILE "d4gl_help.42h" --@ OPTIONS HELP FILE "i4gl_help.iem" --Line is ignored by I-4GL --Line is ignored by D-4GL
Conditional comments are also valid within SQL statement blocks, but not within the text of a PREPARE statement. Do not put both forms of conditional comments in the same line.
Each block begins with the keyword after which it is named, and ends with the corresponding END statement keywords (END MAIN, END FUNCTION, or END REPORT). Program blocks can support 4GL applications in several ways:
s s s
As part of a complete 4GL program (one that includes a MAIN block) As a FUNCTION or REPORT block that is invoked by a 4GL program As a 4GL FUNCTION block called by a C or ESQL/C program (INFORMIX-ESQL/C requires a separate license.)
2-10
Every 4GL program must contain exactly one MAIN block. This must be the rst program block of the module in which it appears. Except for certain declarations (DATABASE, DEFINE, GLOBALS), no 4GL statement can appear outside a program block. Variables that you declare within a program block have a scope of reference (described in Scope of Reference of 4GL Identiers on page 2-17) that is local to the same program block. They cannot be referenced from other program blocks. (Variables that you declare outside any program block have a scope of reference extending from their declaration until the end of the same source module.) The GO TO or GOTO keywords cannot reference a statement label in a different program block. (For more information about statement labels, see the GOTO and LABEL statements in Chapter 4.) Program blocks cannot be nested; neither can any program block be divided among more than one source-code module. The DATABASE statement (described in Chapter 4) has a compiletime effect when it appears before the rst program block of a source module. Within a program block, it has a runtime effect. The scope of the WHENEVER statement extends from its occurrence to the next WHENEVER statement that species the same exceptional condition, or to the end of the same module (whichever comes rst), but WHENEVER cannot occur outside a program block.
CALL, RETURN, EXIT REPORT, START REPORT, OUTPUT TO REPORT, FINISH REPORT, and TERMINATE REPORT statements, and any 4GL expression that
includes a programmer-dened function as an operand, can transfer control of program execution between program blocks. These statements are all described in Chapter 4, INFORMIX-4GL Statements; expressions of 4GL are described in Chapter 3, Data Types and Expressions.. Chapter 5, Built-In Functions and Operators, describes FUNCTION blocks, and Chapter 7, INFORMIX-4GL Reports, describes REPORT blocks. (See Chapter 1, Compiling INFORMIX-4GL Source Files, for details of how source-code modules are compiled and linked to create applications, and for details about the naming conventions for lenames and for le extensions of 4GL modules.)
Statement Blocks
Statement Blocks
The MAIN, FUNCTION, and REPORT statements are special cases of compound statements, the 4GL statements that can contain other statements.
CASE CONSTRUCT DISPLAY ARRAY FOR FOREACH FUNCTION GLOBALS IF INPUT INPUT ARRAY MAIN MENU PROMPT REPORT SQL WHILE
Every compound statement of 4GL supports the END keyword to mark the end of the compound statement construct within the source-code module. Most compound statements also support the EXIT statement keywords, to transfer control of execution to the statement that follows the END statement keywords, where statement is the name of the compound statement. By denition, every compound statement can contain at least one statement block, a group of one or more consecutive SQL statements or other 4GL statements. In the syntax diagram of a compound statement, a statement block always includes this element.
statement
(Some contexts permit or require semicolon ( ; ) delimiters. Any SQL statement that is not prepared but includes syntax later than what Informix 4.10 database servers support must be enclosed between SQL and END SQL keywords.) These are examples of statement blocks within compound 4GL statements:
s
The WHEN, OTHERWISE, THEN, or ELSE blocks of CASE and IF statements Statements within FOR, FOREACH, or WHILE loops
CONSTRUCT, DISPLAY ARRAY, INPUT, or INPUT ARRAY control
s s
blocks
s s s s
Statements following the COMMAND clauses of MENU statements Statements within the ON KEY blocks of PROMPT statements
FORMAT section control blocks of REPORT statements
2-12
Statement Segments
element in its syntax diagram. This feature enables you to compile and execute applications that contain empty (or dummy) functions or reports, to test the behavior of a not-yet-complete program. Unlike program blocks, which cannot be nested, 4GL statement blocks can contain other statement blocks. This recursion can be static, as when a function includes a FOREACH loop that contains an IF statement. Blocks can also be recursive in a dynamic sense, as when a CALL statement invokes a function only if some specied condition occurs. Although most 4GL statements can appear within statement blocks, and most compound statements can be nested, some restrictions apply. In some cases, you can circumvent these restrictions by invoking a function to execute a statement that cannot appear directly within a given compound statement. The GLOBALS lename statement can incorporate statement blocks indirectly by referencing a le. The statements in the specied le are incorporated into the current module during compilation.
Statement Segments
Any subset of a 4GL statement, including the entire statement, is called a statement segment. For clarity, many syntax diagrams in this book use rectangles to represent statement segments (for example, MAIN, FUNCTION, and REPORT in Source-Code Modules and Program Blocks on page 2-10). These are expanded into syntax diagrams on the page referenced in the rectangle, or elsewhere on the same page, if the rectangle indicates no page number. For your convenience, the diagrams of a few important segments are repeated on different pages. Chapter 4 describes certain statement segments that can appear as elements of various 4GL statements.
4GL Identiers
4GL Identiers
Statements and form specications can reference some 4GL program entities by name. To create a named program entity, you must declare a 4GL identier. When you create any of the following program entities, you must follow the guidelines in Naming Rules for 4GL Identiers on page 2-14 and adhere to the declaration procedures of 4GL to declare a valid identier.
Named Program Entity 4GL function or its argument 4GL program variable 4GL report or its argument 4GL screen array 4GL screen form 4GL screen record 4GL statement label 4GL table alias 4GL window How Name Is Declared FUNCTION statement DEFINE and GLOBAL statements REPORT statement ATTRIBUTES section of form specication OPEN FORM statement INSTRUCTIONS section of form specication LABEL statement TABLES section of form specication OPEN WINDOW statement
This list excludes columns, constraints, cursors, databases, indexes, prepared statements, stored procedures, synonyms, tables, triggers, views, and other database objects, because those are SQL entities, not 4GL entities. It also omits lenames, pathnames, and user names, which must conform to the naming rules of your operating system or network.
It must include at least one character, but no more than 128. Only ASCII letters, digits, and underscore ( _ ) symbols are valid. Blanks, hyphens, and other non-alphanumerics are not allowed. The initial character must be a letter or an underscore.
4GL identiers are not case sensitive, so my_Var and MY_vaR both
s s
4GL Identiers
GLS
Within non-English locales, however, 4GL identiers can include non-ASCII characters in identiers, if those characters are dened in the code set of the locale that CLIENT_LOCALE species. In multibyte East Asian locales that support languages whose written form is not alphabet-based, such as Chinese, Japanese, or Korean, a 4GL identier need not begin with a letter, but the storage length of a 4GL identier cannot exceed 128 bytes. Important: You might get unexpected results if you declare as an identier certain keywords of SQL, the C and C++ languages, or your operating system or network. (Appendix G, Reserved Words, lists some keywords and predened identiers of 4GL that should not be declared as identiers of programmer-dened entities.) If you receive an error message that seems unrelated to the SQL or other 4GL statement that elicits the error, see if the statement references a reserved word as an identier. In releases of 4GL earlier than 7.3, the total length of all names of functions, reports, and variables in an 4GL program that was compiled to p-code could not exceed 65,535 bytes. This release is not subject to that restriction; the upper limit on what is called your global string space is now two gigabytes (unless some smaller limit is imposed by the memory capacity of the system on which the 4GL program is running). If you are using the C Compiler version of 4GL, your C compiler might only recognize the rst 31 characters (or the rst 69) of a 4GL identier. In this case, or if your application must be portable to all C compilers, keep the rst 31 characters unique among similar program entities that have the same scope of reference. (Scope of reference is explained later in this section.)
For most Informix database servers, SQL identiers are limited to no more than 18 characters. (But database names might be limited to 8, 10, or 14 characters, depending on the database server and operating system environment.) Informix 9.2 and later databases can have a limit of 128-bytes.
SQL identiers within quoted strings are case-sensitive.
s s s
You can use reserved words as SQL identiers (but such usage might require qualiers, and can make your code difcult to maintain).
4GL Identiers
The 4GL identiers can be the same as SQL identiers, but this might require special attention within the scope of the 4GL identier. For more information, see Scope and Visibility of SQL Identiers on page 2-19. If your 4GL application is the client of an Informix database server on which the IFX_LONGID environment variable has been set to 1, then 4GL code can reference database objects with SQL identiers up to 128 bytes in length.
GLS
If the database and its connectivity software accept non-ASCII characters, 4GL can recognize characters valid for the locale in these SQL identiers.
Column name Connection name Constraint name Database name Index name Log le name Role name Stored procedure name Synonym Table name Trigger name View name
For INFORMIX-SE database servers, whether non-English characters are permitted in the names of databases, tables, or log les depends on whether the operating system permits such characters in lenames. What characters are valid in SQL identiers depends on the database locale. See the Informix Guide to GLS Functionality for additional details of SQL identiers. When the client locale and the database locale are different, 4GL does not support use of the LIKE keyword in declarations of 4GL records that assign default names to record members, if LIKE references a table or column whose name includes any characters outside the code set of the client locale. Warning: Informix database servers (Version 7.0 and later) support DELIMIDENT, an environment variable that can extend the character set of SQL. 4GL cannot, however, reference database objects whose names include any non-alphanumeric characters (such as blank spaces) outside the character set of 4GL identiers.
ANSI
The ANSI standard for SQL requires that all identiers, including user names, be in uppercase letters. Before passing to the database server a user name that includes any lowercase letters, 4GL converts the name to uppercase letters, if the compile-time database is ANSI/ISO-compliant, or if the DBANSIWARN variable is set, or if the -ansi compilation ag is used.
2-16
4GL Identiers
To specify a user name that is all lowercase or a combination of uppercase and lowercase letters, you must enclose the name in quotation marks. 4GL passes to the database server any user name enclosed in quotation marks with the case of the letters intact. When a user species this name, quotation marks must be placed around the name. The only situations in which 4GL does not convert an unquoted, lowercase user name to uppercase is when the user name is informix or public. The following example species the name james as the owner of the table custnotes:
CREATE TABLE "james".custnotes (customer_num INTEGER, notes CHAR(240))
Identiers of Variables
The scope of reference of a variable is determined by where in the .4gl source module the DEFINE statement appears that declares the identier. Identiers of variables can be local, module, or (in some cases) global in their scope:
s
Local 4GL variables are declared within a program block. These variables cannot be referenced by statements outside the same program block. Module variables (sometimes called modular or static) must be declared outside any MAIN, REPORT, or FUNCTION program block. These identiers cannot be referenced outside the same .4gl module.
If the GLOBALSEND GLOBALS statement declares variables in one module, you can extend the scope of those variables to any other module that includes a GLOBALS lename statement, where lename species the le that contains the GLOBALSEND GLOBALS statement.
The INFORMIX-4GL Language 2-17
4GL Identiers
Module identiers whose scope has been extended to additional modules by this mechanism are sometimes said to have global scope, even if they are out of scope in some modules. Truly global in scope, however, are the names of the constants NOTFOUND, TRUE and FALSE, and built-in variables like status, int_ag, quit_ag, and the SQLCA record. These predened identiers do not need to be declared. Unless you declare a conicting identier, they are visible in any 4GL statement, and can be referenced from any 4GL module, as can the names of the built-in functions and operators like LENGTH( ) and INFIELD( ) that Chapter 4 describes.
2-18
4GL Identiers
Here each line represents a separate name space. With each name space, 4GL identiers that have the same scope of reference must be unique. (In addition to these restrictions, a formal argument cannot have the same identier as its own function or report.) For details of how 4GL resolves conicts between non-unique identiers within the same name space, see Visibility of Identical Identiers on page 2-19. In C, global variables and functions share the same name space. Unless you compile your 4GL source code to p-code, a compilation error results if a global variable has the same identier as a 4GL function or report.
4GL Identiers
The shaded area indicates where the global identier called var is visible. This is superseded in the MAIN statement and in the rst FUNCTION program block by local variables that have the same name. Only the last DISPLAY statement references the global variable; the rst two display local variables.
2-20
4GL Identiers
DEFINE var INT MAIN DEFINE var INT LET var = 2 DISPLAY var AT 2,2 SLEEP 2 CALL first3() END MAIN FUNCTION first3() DEFINE var INT LET var = 3 DISPLAY var AT 3,3 CALL final4() SLEEP 2 END FUNCTION FUNCTION final4() LET var = 4 DISPLAY var AT 4,4 SLEEP 2 END FUNCTION
The shaded area indicates where the module variable called var is visible. This is superseded in the MAIN block and in the rst FUNCTION program block by the identiers of local variables called var. The rst two DISPLAY statements show values of local variables; the last displays the module variable. In the portion of a program where more than one variable has the same identier, 4GL gives precedence to a module identier over a global one, and to a local identier over one with any other scope. Assign unique names to variables if you wish to avoid masking part of the scope of non-unique module identiers.
Help messages Reports based on data retrieved from an SQL database (described in Chapter 7, INFORMIX-4GL Reports)
2-22
Ring Menus
Ring Menus
You can use the MENU statement of 4GL to create and display a ring menu of command options, so that users can perform the tasks that you specify. The menu of a typical 4GL program, for example, might look like Figure 2-3.
Figure 2-3 The Format of a Typical 4GL Ring Menu
Options: Customer Order Customer Calls Clients State ... Display information about current customers.
Current option
Menu options
Option names are not 4GL identiers, and can include embedded blank characters and other printable characters. By default, an option is chosen when the user types its initial character, but you can specify additional activation keys. Different menus can have the same option names. If a menu has more options than can t on one line, ellipsis points automatically indicate that more options appear on another page of the menu. In this example, the ellipsis indicates that additional menu options are on one or more pages to the right. Similarly, an ellipsis on the left means that additional menu options are on one or more menu pages to the left. The user can scroll to the right to display the next page of options by using the RIGHT ARROW or SPACEBAR, or scroll to the left with the LEFT ARROW. You can nest MENU statements within other MENU statements, so that the menus form a hierarchy. A nested MENU statement can appear directly within a menu control block, or else in a function that is called directly or indirectly when the user chooses an option of the enclosing menu.
The INFORMIX-4GL Language 2-23
Ring Menus
Pressing the key that matches the initial character of a menu option, such as (for Order) in the preceding illustration, selects the corresponding option.
All other options are disabled until the associated COMMAND block completes its execution. Disabled menu options cannot be selected.
Screen Forms
Disabled Menus
Menus themselves are not always accessible. During screen interaction statements like INPUT, CONSTRUCT, INPUT ARRAY, and DISPLAY ARRAY, errors would be likely to result if the user could interrupt the interaction with menu choices. 4GL prevents these errors by disabling the entire menu during the execution of these statements. The menu does not change its appearance when it is disabled.
Screen Forms
A screen form is a 4GL display in which the user can view, enter, or edit data. Chapter 6, Screen Forms, describes how to create screen forms. The following visual elements (described in greater detail in Chapter 6) can appear in a 4GL screen form:
s
Fields. Also called form elds or screen elds, these areas are where the user enters or edits data, or the 4GL program displays a value. Field delimiters. Fields are usually enclosed within brackets. Screen records. These are logically related sets of elds. Screen arrays. These are scrollable arrays of elds or records. Decorative rectangles. These can ornament the form. Text. Anything else in the form is called text. Text always appears while the form is visible.
s s s s s
Screen Forms
ORDER FORM ------------------------------------------------------------------------Customer Number: [ ] [ ] Last Name: [Grant|Miller ] [ ] [ ] City: [ ] State: [ ] Zip: [ ] Telephone: [ ] ------------------------------------------------------------------------Order No: [ ] Order Date: [>06/05/89 ] Ship Date: [ ] Item No. Stock No. Code Description Quantity Price Total First Name: Address:
[ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] [ ] --------------------------------------------------------------------------
Visual Cursors
4GL marks the users current location (if any) in the current menu, form, or
eld with a visual cursor. Usually, each of these is simply called the cursor:
s
Menu cursor. Reverse video marks the option chosen if you press RETURN. Field cursor. This pipe symbol ( | ) marks the current character position in the current eld.
2-26
Screen Forms
Field Attributes
Several 4GL statements can set display attributes (as described in ATTRIBUTE Clause on page 3-96). A form specication le can also specify eld attributes. These optional descriptors can control the display when the cursor is in the eld, or can supply or restrict eld values during data entry. Field attributes can have effects like these:
s s s
They control cursor movement among elds. They set validation and default value eld attributes. They set formatting attributes or automatically invoke a multipleline editor for character data, or an external editor to view or modify TEXT or BYTE data. They set screen display color and intensity attributes.
Reserved Lines
On the 4GL screen, certain lines are reserved for output from specic 4GL statements or from other sources. By default, these reserved lines appear in the following positions on the 4GL screen:
s
Menu line. Line 1 displays the menu title and options list from MENU. Prompt line. Line 1 also displays text specied by the PROMPT statement. Menu Help line. Line 2 displays text describing MENU options. You cannot reposition this line independently of the Menu line. Message line. Line 2 also displays text from the MESSAGE statement. You can reposition this line with the OPTIONS statement. Form line. Line 3 begins a form display when DISPLAY FORM executes. Comment line. The next-to-last line of the 4GL screen (or the last line in a 4GL window) displays COMMENTS attribute messages. Error line. The last line of the 4GL screen displays output from the ERROR statement.
4GL Windows
If you display the form in a named 4GL window, these default values apply to that window, rather than to the 4GL screen, except for the Error line. (The position of the Error line is dened relative to the entire screen, rather than to any 4GL window.) The OPTIONS statement can change these default positions for all the 4GL windows of your application. The OPEN WINDOW statement can reposition all of these reserved lines (except the Error line) within the specied 4GL window. (These 4GL statements are described in detail in Chapter 4.)
4GL Windows
A 4GL window is a named rectangular area on the 4GL screen. When a 4GL program starts, the entire 4GL screen is the current window. Some 4GL statements can reference this default window as SCREEN. The OPEN WINDOW statement can create additional 4GL windows, dimensions, position, and attributes of each window. In DBMS applications that perform various tasks, displaying distinct activities in different 4GL windows is a good design strategy. No 4GL window can display more than one 4GL form. The CURRENT WINDOW statement can transfer control from one 4GL window to another.
at the top of the stack is the current window. The current 4GL window is always completely visible, and can obscure all or part of other windows. When you specify a new current window, 4GL adjusts the window stack by moving that window to the top, and closing any gap in the stack left by the window. When you close a window, 4GL removes that window from the window stack. The top-most window among those that remain on the screen becomes the current window. All this takes place within the 4GL screen.
2-28
On-Line Help
All input and output is done in the current window. If that window contains a screen form, the form becomes the current form. The DISPLAY ARRAY, INPUT, INPUT ARRAY, and MENU statements all run in the current window. If a user displays a form in another window from within one of these statements (for example, by activating an ON KEY block), the window containing the new form becomes the current window. When the enclosing statement resumes execution, the original window is restored as the current window. Programs with multiple windows might need to switch to a different current window unconditionally, so that input and output occur in the appropriate window. The CURRENT WINDOW statement makes a specied window (or SCREEN) the current window. When a window becomes the current window, 4GL restores its values for the positions of the Prompt, Menu, Message, Form, and Comment lines.
On-Line Help
4GL includes two distinct facilities for displaying help messages:
s
Development help. The developer can request help from the Programmers Environment regarding features of the 4GL language. Use the Help key (typically CONTROL-W) to display help on the currently selected menu option. Runtime help. The user of a 4GL application can display programmer-dened help messages.
Runtime help is displayed when the user presses a designated Help key (CONTROL-W). The 4GL statements that can include a HELP clause are these:
s s s s
CONSTRUCT (during a query by example) INPUT and INPUT ARRAY (during data entry) MENU (for each menu option) PROMPT (when the user must supply keyboard input)
The HELP clause species a single help message for the entire 4GL statement. To provide eld-level help in these interactive statements, you can use an ON KEY clause with the INFIELD( ) operator and the SHOW_HELP( ) function, which are described in Chapter 5, Built-In Functions and Operators.
On-Line Help
When the user presses the Help key in a context for which you have prepared a help message, that message appears in a Help window. The 4GL screen is hidden while this window is open. The Help window has a 4GL ring menu containing Screen and Resume menu options. Screen displays the next page of help text. Resume closes the Help window and redisplays the 4GL screen.
2-30
You must create these help messages and store them in an ASCII le. Each message begins with a unique whole number that has an absolute value no greater than 32,767 and is prexed by a period ( . ). Statements of 4GL can reference a help message by specifying its number in a HELP clause. You must compile help messages from the ASCII source le to a runtime format by using the mkmessage utility. For more information about creating help messages, see The mkmessage Utility on page B-2. The Help window persists until the user closes it. The user can dismiss the Help window by using the Resume menu option or by pressing RETURN.
Nested input occurs when two ICB statements (such as INPUT, INPUT ARRAY, DISPLAY ARRAY, or CONSTRUCT) operate concurrently on the same elds of the same screen form. Concurrently, in this context, means that one ICB statement is suspended while using the same form eld that another ICB statement is using. Recursive input occurs when two instances of the same ICB statement operate concurrently, and a BEFORE or AFTER or ON KEY control block is activated that invokes a function that executes the same ICB statement recursively, re-executing that ICB statement. It does not matter whether the recursion is direct (the function calls itself) or indirect (the function calls another function, which in turn calls the rst function again).
Opening and closing screen forms precludes nesting and recursion of ICB statements, which can only occur when forms are not being opened and closed while the outer ICB statement is still processing. Recursive and nested input imply the use of the same 4GL window. Changing the current window inherently changes the form (or the instance of the form) that is currently in use.
The INFORMIX-4GL Language 2-31
4GL supports both direct and indirect nesting of the ICB statements; the level
of nesting is limited only by the availability of the resources. Direct nesting involves embedding the child ICB statement in a control block, such as ON KEY, BEFORE FIELD, AFTER FIELD, and so forth, of the parent ICB statement. The following code example illustrates direct nesting of INPUT statements:
MAIN DEFINE r1, r2 RECORD f1, f2, f3 CHAR(30) END RECORD DATABASE nestedinputDB DEFER INTERRUPT OPEN FORM nest_form FROM "nested_input" DISPLAY FORM nest_form LET INT_FLAG = FALSE IF NOT INT_FLAG THEN INPUT BY NAME r1.* WITHOUT DEFAULTS --Parent INPUT stmt BEFORE INPUT MESSAGE "BEFORE INPUT STATEMENT 1" SLEEP 1 BEFORE FIELD f1 MESSAGE "Input Statement 1 -- BF1" SLEEP 1 AFTER FIELD f2 MESSAGE "Input Statement 1 -- AF1" SLEEP 1 --Child INPUT Statement INPUT BY NAME r2.* WITHOUT DEFAULTS --Child INPUT stmt BEFORE INPUT MESSAGE "BEFORE INPUT STATEMENT 2" SLEEP 1 AFTER INPUT MESSAGE "AFTER INPUT STATEMENT 2" SLEEP 1 ON KEY (CONTROL-W) MESSAGE "IP2: HELP IS NOT AVAILABLE" SLEEP 1 END INPUT --End of Child INPUT stmt LET r2.f1 = "Child INPUT Statement -- ", r2.f1 CLIPPED INSERT INTO table_2 VALUES(r2.*) AFTER INPUT MESSAGE "AFTER INPUT STATEMENT 1" SLEEP 1 ON KEY (CONTROL-W) MESSAGE "IP1: HELP IS NOT AVAILABLE" SLEEP 1 END INPUT --End of Parent INPUT stmt END IF LET r.f1 = "Parent INPUT Statement -- ", r1.f1 CLIPPED INSERT INTO table_1 VALUES(r1.*) MESSAGE "Input Statement -- complete" SLEEP 1 END MAIN
2-32
In this example of nested INPUT statements, the parent and the child statements use the same form for entering data. After the user enters data in elds f1 and f2 for the parent INPUT statement, control transfers to the child INPUT statement. Once the child INPUT statement is executed, data entered for the child is inserted in table_2. Then control returns to the parent and elds f1 and f2 are restored to their original values. Indirect nesting invokes a function that contains the child ICB statement, from the parent ICB statement. Once again, the parent and the child ICB statements use the same form for data entry.
Performing heterogeneous nesting is valid where the parent and the child statements are entirely different. For example, where CONSTRUCT is the parent statement, INPUT can be the child statement.
2-34
The recursive ICB statements feature provides extra exibility to 4GL programmers. The following example illustrates the use of the recursive INPUT statement:
MAIN DEFINE r RECORD f1, f2, f3 CHAR(30) END RECORD DEFINE z INTEGER DATABASE recinputDB DEFER INTERRUPT OPEN FORM recurs_form FROM "recursive_input" DISPLAY FORM recurs_form LET z = 0 CALL recursive_input(z, r) END MAIN FUNCTION recursive_input(z1, r1) DEFINE r1 RECORD f1, f2, f3 CHAR(30) END RECORD DEFINE z1 INTEGER LET INT_FLAG = FALSE LET z1 = z1 + 1 IF z1 > 3 THEN RETURN END IF MESSAGE "Recursive Cycle: ", z1 SLEEP 1 IF NOT INT_FLAG THEN INPUT BY NAME r1.* WITHOUT DEFAULTS BEFORE INPUT MESSAGE "BEFORE INPUT STATEMENT 1" SLEEP 1 BEFORE FIELD f1 MESSAGE "Input Statement 1 -- BF1" SLEEP 1 AFTER FIELD f2 MESSAGE "Input Statement 1 -- AF1" SLEEP 1 CALL recursive_input(z1, r1) --Recursive call AFTER INPUT MESSAGE "AFTER INPUT STATEMENT 1" SLEEP 1 ON KEY (CONTROL-W) MESSAGE "IP1: HELP IS NOT AVAILABLE" SLEEP 1 END INPUT END IF LET r.f1 = "Recursive Cycle -- ", z1, r1.f1 CLIPPED INSERT INTO table_1 VALUES(r1.*) MESSAGE "Input Statement -- complete" SLEEP 1 END FUNCTION
For every recursive invocation of the function recursive_input( ), the same form is used for data entry. A recursive call is made after you enter data in elds f1 and f2 for each invocation. Before making a recursive call, the context is stored in dynamically allocated variables and pushed onto a stack. After the terminating condition for recursion is satised, the context is popped out of the stack, and the buffers for elds f1 and f2 revert to their original values. It is valid to combine all the different types of nesting, such as direct, indirect, heterogeneous, and homogeneous, with recursive ICB statements. To avoid anomalous behavior, it is advisable to recompile and relink pre-6.x 4GL applications that use ICB-related statements with current 4GL software.
2-36
The following code example, though of no practical use, illustrates nested INPUT statements. There are nine levels of nested statements in the code.
MAIN CALL f() END MAIN FUNCTION f() DEFINE s CHAR(300) DEFINE y INTEGER DEFINE i INTEGER DEFINE t INTEGER DEFINE a ARRAY[10] OF INTEGER DECLARE c CURSOR FOR SELECT Tabid FROM Systables OPEN WINDOW w AT 1, 1 WITH FORM "xxx" LET y = 0 FOREACH c INTO t FOR i = 1 TO 10 WHILE y < 1000 MENU "ABCDEF" BEFORE MENU HIDE OPTION "B" COMMAND "A" "Absolutely" SHOW OPTION "B" IF a[1] THEN EXIT MENU END IF IF a[1] THEN CONTINUE MENU END IF NEXT OPTION "E" COMMAND "B" "Beautiful" MESSAGE "Thank you" COMMAND "C" "Colourful" MESSAGE "Thank you" COMMAND "D" "Delicious" MESSAGE "Thank you" COMMAND "E" "Exit" EXIT MENU COMMAND "F" MENU "XYZ" COMMAND "X" EXIT MENU COMMAND "Y" INPUT BY NAME y WITHOUT DEFAULTS AFTER FIELD y IF a[1] THEN EXIT FOR END IF a[1] THEN CONTINUE FOR END IF a[1] THEN EXIT FOREACH END IF a[1] THEN CONTINUE FOREACH END IF a[1] THEN EXIT WHILE END IF a[1] THEN CONTINUE WHILE END IF a[1] THEN RETURN END IF a[1] THEN EXIT MENU END IF a[1] THEN CONTINUE MENU END IF a[1] THEN EXIT INPUT END IF a[1] THEN CONTINUE INPUT END IF a[1] THEN GOTO End_Label END
IF IF IF IF IF IF IF IF IF IF IF IF
------
IF
--------------
IF a[1] THEN GOTO Mid_Label END IF CONSTRUCT BY NAME s ON y AFTER FIELD y IF a[1] THEN EXIT FOR END IF IF a[1] THEN CONTINUE FOR END IF IF a[1] THEN EXIT FOREACH END IF IF a[1] THEN CONTINUE FOREACH END IF IF a[1] THEN EXIT WHILE END IF IF a[1] THEN CONTINUE WHILE END IF IF a[1] THEN RETURN END IF IF a[1] THEN EXIT MENU END IF IF a[1] THEN CONTINUE MENU END IF EXIT INPUT is not allowed by the compiler (error 4488) IF a[1] THEN EXIT INPUT END IF CONTINUE INPUT is not allowed by the compiler (error 4488) IF a[1] THEN CONTINUE INPUT END IF IF a[1] THEN EXIT CONSTRUCT END IF IF a[1] THEN CONTINUE CONSTRUCT END IF IF a[1] THEN GOTO End_Label END IF a[1] THEN GOTO Mid_Label END IF CALL SET_COUNT(3) DISPLAY ARRAY a TO a.* ON KEY (F3) IF a[1] THEN EXIT FOR END IF IF a[1] THEN CONTINUE FOR END IF IF a[1] THEN EXIT FOREACH END IF IF a[1] THEN CONTINUE FOREACH END IF IF a[1] THEN EXIT WHILE END IF IF a[1] THEN CONTINUE WHILE END IF IF a[1] THEN RETURN END IF IF a[1] THEN EXIT MENU END IF IF a[1] THEN CONTINUE MENU END IF IF a[1] THEN EXIT DISPLAY END IF CONTINUE DISPLAY is not allowed by the compiler IF a[1] THEN CONTINUE DISPLAY END IF EXIT INPUT is not allowed by the compiler (error 4488) IF a[1] THEN EXIT INPUT END IF CONTINUE INPUT is not allowed by the compiler (error 4488) IF a[1] THEN CONTINUE INPUT END IF EXIT CONSTRUCT is not allowed by the compiler (error 4488) IF a[1] THEN EXIT CONSTRUCT END IF CONTINUE CONSTRUCT is not allowed by the compiler (error 4488) IF a[1] THEN CONTINUE CONSTRUCT END IF IF a[1] THEN GOTO End_Label END IF IF a[1] THEN GOTO Mid_Label END IF INPUT ARRAY a FROM a.* AFTER FIELD y IF a[1] THEN EXIT FOR END IF IF a[1] THEN CONTINUE FOR END IF IF a[1] THEN EXIT FOREACH END IF
2-38
IF a[1] THEN CONTINUE FOREACH END IF IF a[1] THEN EXIT WHILE END IF IF a[1] THEN CONTINUE WHILE END IF IF a[1] THEN RETURN END IF IF a[1] THEN EXIT MENU END IF IF a[1] THEN CONTINUE MENU END IF IF a[1] THEN EXIT INPUT END IF IF a[1] THEN CONTINUE INPUT END IF -- EXIT DISPLAY *is* allowed by the compiler (despite -- error 4488) IF a[1] THEN EXIT DISPLAY END IF -- CONTINUE DISPLAY is not allowed by the compiler -- IF a[1] THEN CONTINUE DISPLAY END IF -- EXIT CONSTRUCT is not allowed by the compiler (error -- 4488) -- IF a[1] THEN EXIT CONSTRUCT END IF -- CONTINUE CONSTRUCT is not allowed by the compiler -- (error 4488) -- IF a[1] THEN CONTINUE CONSTRUCT END IF IF a[1] THEN GOTO End_Label END IF IF a[1] THEN GOTO Mid_Label END IF LABEL Mid_label: MESSAGE "You got here? How?" NEXT FIELD y END INPUT END DISPLAY END CONSTRUCT END INPUT COMMAND "Z" MESSAGE "Sucker!" CONTINUE MENU END MENU END MENU END WHILE END FOR END FOREACH LET y = 0 LABEL End_label: CLOSE WINDOW w END FUNCTION
This example illustrates some problems that early exits from nested ICB and MENU statements can cause. For example, when EXIT FOREACH executes from within an INPUT statement that itself is nested within two MENU statements, a FOR loop, and a WHILE loop (as in the rst EXIT FOREACH statement of the previous example), then the intervening menus (ABCDEF and XYZ) are not cleaned up correctly. Here the INPUT statement itself is handled correctly, however, and the database cursor in the FOREACH loop closes correctly.
Exception Handling
Jump statements, including GOTO and WHENEVERGOTO also are not dealt with properly. If this is a concern, do not use GOTO in contexts like this.
Exception Handling
4GL provides facilities for issuing compile-time and link-time detection of
compilation errors, and for detection and handling of warnings and runtime errors and that occur during program execution.
Operators,of the present manual; these can support automatic or explicit logging of runtime errors in a le.) By default, runtime errors and warnings are written to stderr. (Versions of 4GL earlier than 6.0 wrote runtime errors and warnings to stdout.)
2-40
SQL errors, warnings, or NOTFOUND conditions that the database server detects and records in the SQLCA area; see Error Handling
reports during execution of a stored procedure; see Informix Guide to SQL: Syntax
s s
Interrupt, Quit, or other signals from the user or from other sources Runtime errors and warnings that 4GL issues
For errors that occur in stored procedures, you can use the ON EXCEPTION statement of SPL to trap errors within the procedure. You can use the DEFER statement of 4GL to trap and handle Interrupt and Quit signals, and you can use WHENEVER to trap and handle SQL and 4GL errors and warnings. The WHENEVER statement can control the processing of exceptional conditions of several kinds: SQL warnings, SQL end-of-data errors, errors in SQL or screen I/O operations, or errors in evaluating 4GL expressions. The DEFER statement can instruct 4GL not to terminate the program when a user presses the Interrupt or Quit key. The DEFER statement has dynamic scope, as opposed to the lexical scope of WHENEVER. When Quit or Interrupt is deferred, the signal is ignored globally (that is, in all modules). See the descriptions of DEFER and WHENEVER in Chapter 4 for details of how to use these statements to handle signals, errors, and warnings.
In contrast, AnyError error scope means that expression errors also activate error logic, and status is set to an appropriate negative value after the statement that produced the expression error. This was the only error scope available with Version 4.0 of 4GL. In the current release, however, you must request it explicitly with the WHENEVER ANY ERROR directive or with the anyerr ag when you compile or in the RDS runner or Debugger command line. For maximum ease in preventing, locating, and correcting expression errors, Informix recommends that you write all new 4GL code to work under AnyError error scope. With 4GL programs that you compile to C, you can achieve this automatically by setting the C4GLFLAGS environment variable to include -anyerr. With RDS, you can achieve this by setting the FGLPCFLAGS environment variable to include -anyerr.
SQL errors
Validation errors
Evaluation errors
Here errors of type 1 occur on the database server, and reset the built-in
SQLCA.SQLCODE variable to a negative value. (See Error Handling with SQLCA on page 2-45 for a description of SQLCA.SQLCODE.)
To trap errors of types 1, 2, and 3, which correspond to Normal error scope, specify WHENEVER ERROR. As Figure 2-5 indicates, Normal error scope is a logical subset of AnyError error scope.
2-42
To use AnyError error scope, which can also trap errors of type 4, you must specify WHENEVER ANY ERROR, or else compile with the -anyerr option. Errors of type 4 can include arithmetic, Boolean, or conversion errors that occur when 4GL evaluates an expression. Important: Earlier releases of 4GL supported fatal (or untrappable) runtime errors, which could not be trapped by WHENEVER statements, but such errors are not a feature of this release. There are no 4GL errors outside AnyError error scope.
4GL runtime errors are included in Informix Error Messages in Answers
OnLine.
ANSI
If ANSI compliance is requested and no WHENEVER statement is in effect, the default action after an error is CONTINUE.
ANSI compliance is in effect if any of the following conditions exists:
s s s
There is a default compile-time database that is ANSI-compliant. The -ansi compilation ag is specied. The DBANSIWARN environment variable is set.
In releases of RDS earlier than 6.0, the default error action was STOP (rather than CONTINUE) for the last two of these three conditions.
2.
If neither ANSI compliance nor any WHENEVER statement is in effect, the following factors determine the default error action:
s s
If the -anyerr ag is used, the default action is STOP. If the -anyerr ag is not used, the default action after an expression or data type conversion error is CONTINUE. After other categories of errors, it is STOP.
The error behavior depends on the database that the nonprocedural DATABASE statement references when you compile the program. If you compile with a non-ANSI-compliant default database, but run with an ANSIcompliant current database, the error behavior is as if the database were not an ANSI-compliant database. The converse also applies: if you compile against an ANSI-compliant database but run against a non-ANSI-compliant database, then the error behavior is the same as if the runtime database were ANSI-compliant. If you compile part of the application against an ANSI-compliant database and part of it against a non-ANSI-compliant database, then those parts of the application compiled against the ANSI-compliant database have the default error action of CONTINUE and those parts compiled against the non-ANSIcompliant database have the default error action of STOP.
The status variable is set for expression errors only if AnyError error scope is in effect. AnyError behavior is no longer the default for RDS. This is a signicant backward-compatibility concern for RDS users who do not explicitly use AnyError error scope. Use the -anyerr ag when compiling your p-code modules to prevent unexpected failure of expression errors to set status (and recompile other p-code modules in the same program, for consistency within each program).
Error and warning messages are no longer written to the UNIX standard error le. They are written to the 4GL error log le only.
This change primarily affects 4GL programs that are compiled to C and that use Normal error scope (because most RDS expression or conversion errors have used -anyerr behavior, regardless of the requested error scope). Use 4GL error logs in order to recognize and isolate errors.
2-44
The global variable status, which can indicate errors, both from SQL statements and from other 4GL statements The global record SQLCA, which indicates the success of SQL statements, and provides other information about actions of the database server
Compared to status, the SQLCA.SQLCODE variable is typically easier to use for monitoring the success or failure of SQL statements because it ignores exceptional conditions that might be encountered in other 4GL statements.
4GL returns a result code into the SQLCA record after executing every SQL
statement. Because it is automatically dened, you do not need to (and must not) declare the SQLCA record, which has this structure:
DEFINE SQLCA RECORD SQLCODE INTEGER, SQLERRM CHAR(71), SQLERRP CHAR(8), SQLERRD ARRAY [6] OF SQLAWARN CHAR (8) END RECORD
INTEGER,
indicates the result of any SQL statement. It is set to zero for a successful execution, and to NOTFOUND ( = 100 ) for a successfully executed query that returns zero rows, or for a FETCH that seeks beyond the end of the current active set. SQLCODE is negative after an unsuccessful SQL operation. At runtime, 4GL sets the variable status equal to SQLCODE after each SQL statement. (See also the description of the ANY keyword of WHENEVER in A Taxonomy of Runtime Errors on page 2-42.) The nderr utility can provide explanations of SQL and 4GL error codes.
is not used at this time. is not used at this time. is an array of six variables of data type INTEGER:
SQLERRD[1] SQLERRD[2] SQLERRD[3] SQLERRD[4] SQLERRD[5] SQLERRD[6]
is not used at this time. is a SERIAL value returned or ISAM error code. is the number of rows inserted or updated. is the estimated CPU cost for query. is the offset of the error into the SQL statement. is the row ID of the last row that was processed; whether it was returned is server dependent.
SQLAWARN
is an 8-byte string whose characters signal any warnings (as opposed to errors) after any SQL statement executes. All characters are blank if no problems were detected.
SQLAWARN[1]
is set to W if any of the other warning characters were set to W. If SQLAWARN[1] is blank, you do not have to check the other warning characters.
2-46
SQLAWARN[2]
is set to W if one or more values were truncated to t into a CHAR variable, or if a DATABASE statement selected a database with transactions. is set to W if an aggregate like SUM( ), AVG( ), MAX( ), or MIN( ) encountered a null value in its evaluation, or if the DATABASE statement specied an ANSI/ISO-compliant database. is set to W if a DATABASE statement selected an Informix Dynamic Server database, or when the number of items in the select-list of a SELECT clause is not the same as the number of program variables in the INTO clause. (The number of values returned by 4GL is the smaller of these two numbers.) is set to W if oat-to-decimal conversion is used. is set to W if your program executes an Informix extension to the ANSI/ISO standard for SQL syntax while the DBASIWARN variable is set, or after the -ansi compilation ag was used. is set to W if a query skips a table fragment, or if the database and client have different locales. is not used at present.
SQLAWARN[3]
SQLAWARN[4]
SQLAWARN[5] SQLAWARN[6]
SQLAWARN[7]
SQLAWARN[8]
If a multi-row INSERT or UPDATE statement of SQL fails, then SQLERRD[3] is set to the number of rows that were processed before the error was detected. If a LOAD operation fails with error -846, however, SQLERRD[3] is always set to 1, regardless of how many rows (if any) were successfully inserted. For a complete description of SQLCA, see the Informix Guide to SQL: Tutorial in your Informix database server documentation.
Chapter
3
. . . . . . . . . . . . . . . . . . . . . . . . . . . 3-5 3-5 3-6 3-9 3-10 3-11 3-11 3-12 3-12 3-12 3-13 3-14 3-16 3-17 3-17 3-18 3-23 3-23 3-24 3-25 3-25 3-26 3-26 3-27 3-32 3-33 3-34
In This Chapter .
. .
. .
. .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . .
Data Types of 4GL . . . . . . . . Simple Data Types. . . . . . . Number Data Types . . . . Character Data Types . . . Time Data Types . . . . . Structured Data Types . . . . . Large Data Types . . . . . . . Descriptions of the 4GL Data Types . ARRAY . . . . . . . . . . BYTE . . . . . . . . . . . CHAR . . . . . . . . . . . CHARACTER . . . . . . . . DATE . . . . . . . . . . . DATETIME . . . . . . . . . DEC . . . . . . . . . . . DECIMAL (p, s) . . . . . . . DECIMAL (p) . . . . . . . . DOUBLE PRECISION . . . . . FLOAT. . . . . . . . . . . INT . . . . . . . . . . . . INTEGER . . . . . . . . . . INTERVAL . . . . . . . . . MONEY . . . . . . . . . . NCHAR . . . . . . . . . . NVARCHAR . . . . . . . .
NUMERIC . . . . . . . . . . . . . . . . . . REAL . . . . . . . . . . . . . . . . . . . . RECORD . . . . . . . . . . . . . . . . . . . SMALLFLOAT . . . . . . . . . . . . . . . . . SMALLINT . . . . . . . . . . . . . . . . . . TEXT . . . . . . . . . . . . . . . . . . . . VARCHAR . . . . . . . . . . . . . . . . . . Data Type Conversion . . . . . . . . . . . . . . Converting from Number to Number . . . . . . . . Converting Numbers in Arithmetic Operations . . . . Converting Between DATE and DATETIME . . . . . Converting CHAR to DATETIME or INTERVAL Data Types Converting Between Number and Character Data Types . Converting Large Data Types. . . . . . . . . . . Summary of Compatible 4GL Data Types . . . . . . . . Notes on Automatic Data Type Conversion . . . . . . Expressions of 4GL . . . . . . . . . . . . . . . Differences Between 4GL and SQL Expressions . . . . . . Components of 4GL Expressions . . . . . . . . . . . Parentheses in 4GL Expressions . . . . . . . . . . Operators in 4GL Expressions . . . . . . . . . . Operands in 4GL Expressions . . . . . . . . . . Named Values as Operands . . . . . . . . . . . Function Calls as Operands . . . . . . . . . . . Expressions as Operands . . . . . . . . . . . . Boolean Expressions . . . . . . . . . . . . . . . Logical Operators and Boolean Comparisons . . . . . Data Type Compatibility . . . . . . . . . . . . Evaluating Boolean Expressions . . . . . . . . . . Integer Expressions . . . . . . . . . . . . . . . Binary Arithmetic Operators . . . . . . . . . . . Unary Arithmetic Operators . . . . . . . . . . . Literal Integers . . . . . . . . . . . . . . . Number Expressions . . . . . . . . . . . . . . . Arithmetic Operators . . . . . . . . . . . . . Literal Numbers . . . . . . . . . . . . . . . Character Expressions . . . . . . . . . . . . . . Arrays and Substrings . . . . . . . . . . . . . String Operators . . . . . . . . . . . . . . . Non-Printable Characters . . . . . . . . . . . .
3-2 IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3-34 3-34 3-35 3-37 3-38 3-39 3-40 3-42 3-42 3-43 3-44 3-45 3-46 3-46 3-46 3-48 3-49 3-51 3-52 3-52 3-53 3-56 3-57 3-58 3-59 3-60 3-61 3-61 3-62 3-63 3-64 3-65 3-65 3-66 3-66 3-67 3-69 3-70 3-70 3-71
Time Expressions . . . . . . . . . . . . Numeric Date . . . . . . . . . . . DATETIME Qualier . . . . . . . . . DATETIME Literal . . . . . . . . . . INTERVAL Qualier . . . . . . . . . INTERVAL Literal . . . . . . . . . . Arithmetic Operations on Time Values . . . Relational Operators and Time Values . . . Field Clause . . . . . . . . . . . . . Table Qualiers . . . . . . . . . . . . Owner Naming . . . . . . . . . . . Database References . . . . . . . . . THRU or THROUGH Keywords and .* Notation ATTRIBUTE Clause . . . . . . . . . . . Color and Monochrome Attributes . . . . Precedence of Attributes . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
3-72 3-75 3-76 3-78 3-80 3-82 3-83 3-85 3-86 3-89 3-89 3-90 3-92 3-96 3-97 3-98
3-4
In This Chapter
This chapter describes how 4GL programs represent data values. The rst part of this chapter describes the 4GL data types; the latter part describes 4GL expressions, which can return specic values of these data types.
DOUBLE PRECISION These keywords are a synonym for FLOAT FLOAT INT INTEGER INTERVAL MONEY NCHAR(size) NUMERIC NVARCHAR(size) Floating-point numbers, of up to 32-digit precision This keyword is a synonym for INTEGER Whole numbers, from -2,147,483,647 to +2,147,483,647 Spans of time in years and months, or in smaller time units Currency amounts, with denable scale and precision Character strings, of size up to 32,767 bytes in length This keyword is a synonym for DECIMAL Character strings of varying length, for size 255 bytes (1 of 2)
3-6
Kinds of Values Stored This keyword is a synonym for SMALLFLOAT Ordered sets of values, of any combination of data types Floating-point numbers, of up to 16-digit precision Whole numbers, from -32,767 to +32,767 Character strings of up to 231 bytes Character strings of varying length, for size 255 bytes (2 of 2)
Except for ARRAY and RECORD, the 4GL data types correspond to built-in SQL data types of Informix database servers. The data types of 4GL approximate a superset of the SQL data types that 7.x Informix database servers recognize, but with the following restrictions:
s
The SERIAL data type of SQL is not a 4GL data type. (Use the INTEGER data type to store SERIAL values from a database.) You cannot use the SERIAL keyword in 4GL statements that are not SQL statements.
4GL does not recognize the BITFIXED, BITVARYING, BLOB, BOOLEAN, CLOB, DISTINCT, INT8, LIST, LVARCHAR, MULTISET, OPAQUE, REFERENCE, ROW, SERIAL8, SET, or user-dened data types of
Informix database servers. Declarations of 4GL variables, formal arguments, and returned values use the following syntax to specify data types directly.
4GL Data Type Simple Data Type p. 3-9 Structured Data Type p. 4-86 Large Data Type p. 4-86
Declarations of variables can also use the LIKE keyword, as described in Indirect Typing on page 4-83. TEXT and BYTE are called the large data types; ARRAY and RECORD are called the structured data types. All other 4GL data types are simple data types. Sections that follow describe the 4GL data types in each of these categories.
3-8
SMALLINT
Number DECIMAL DEC NUMERIC MONEY FLOAT DOUBLE PRECISION
(16) ( precision
, scale )
(16, 2) ( precision ,
REAL
,2 )
scale
( precision )
SMALLFLOAT DATE Time DATETIME INTERVAL CHARACTER Character CHAR NCHAR VARCHAR NVARCHAR DATETIME Qualier p. 3-76 INTERVAL Qualier p. 3-80
Description is the number of signicant digits. For FLOAT, 1 precision 14. For DECIMAL and MONEY, the range is 1 precision 32. is an SQL parameter not used by 4GL; 0 reserved size 255. is the number of digits ( 32) in the fractional part of the number, where 0 scale precision. The actual scale may be less than 32. is the maximum number of bytes that the data type can store. For CHAR: 1 size 32,767; for VARCHAR: 1 size 255.
All parameters in data type declarations must be specied as literal integers. (For more information, see Literal Integers on page 3-65.) The precision of FLOAT and DOUBLE PRECISION data type declarations, and reserved in VARCHAR data type declarations, are accepted by 4GL but are ignored. Each simple data type can be classied as a number, time, or character type. (Numeric, chronological, and string are synonyms for these categories.)
Currency values, of scale s and precision p Floating-point numbers of precision p (but see DECIMAL (p) on page 3-24 for information about ANSI-compliant databases) Floating-point, double-precision numbers Floating-point, single-precision numbers
3-10
The TEXT data type (see TEXT on page 3-39) can store text strings of up to two gigabytes ( = 231 bytes). However, TEXT is not classied here as a character data type, because 4GL manipulates TEXT values in a different way from how CHAR, VARCHAR, NCHAR, or NVARCHAR values are processed.
store points in time, and the third stores spans of time (positive or negative).
Time Types DATE DATETIME INTERVAL Description Calendar dates (month, day, year) with a xed scale of days, in the range from January 1 of the year 1 up to December 31, 9999 Calendar dates (year, month, day) and time-of-day (hour, minute, second, and fraction of second), in the range of years 1 to 9999 Spans of time, in years and months, or in smaller units
Unless otherwise noted, descriptions of formats for data entry and display are for the default (U.S. English) locale. Some locales support other character sets and different entry and display formats for number, currency, and date values, as specied in the locale les and in environment variables.
3-12
ARRAY
ARRAY
This structured data type stores a one-, two-, or three-dimensional array of variables, all of the same data type. These variables can be any 4GL data type except ARRAY. This is the syntax for declaring an array of variables:
ARRAY Data Type ARRAY
, [
3 size
OF
Element size
Description is a positive integer number (ranging from 1 to 32,767) of elements within a dimension. Each dimension can have a different size.
Array Elements
Data types are here a subset of those listed in Data Types of 4GL on page 3-6, because ARRAY is not valid. A variable in an array is called an element. You can use bracket ( [ ] ) symbols and comma-separated integers to reference a single element of an array. For example, if xray is the identier of an ARRAY variable:
s s s
xray [i] is the ith element of a one-dimensional array. xray [i, j] is the jth element in the ith row of a two-dimensional array. xray [i, j, k] is the kth element in the jth column of the ith row of a three-dimensional array.
Here the coordinates i, j, and k can be variables or other integer expressions that return positive whole numbers in the range 1 to 32,767. Within an SQL statement delimited by SQLEND SQL, an ARRAY host variable needs the dollar sign ($) prex, but a variable used as an index to an array requires no prex. Some C compilers impose a limit lower than 32,767 on the number of array elements in a dimension, or on the total number. (For an array of two or more dimensions, this total is the product of all the declared size specications.)
BYTE
Because you cannot manipulate an array as a single unit, statements must refer to individual elements of an array. You reference a single array element by specifying its coordinates in each dimension of the array. For an array with two dimensions, for example, you must specify two coordinates to reference any element. In expressions, 4GL expands the identier of a record to a list of its members but 4GL does not expand the name of an array to its elements. You cannot pass an array to (or from) a function or report. You can, however, pass individual array elements. If these elements are records, 4GL expands each element to its members in the ordinary way. Similarly, if record is a RECORD having an ARRAY member, record.* is not a valid argument to a function or to a report, nor (in this case) is record.* a valid specication in a list of returned values.
BYTE
The BYTE data type stores any kind of binary data in a structureless byte stream. Binary data typically consists of saved spreadsheets, program load modules, digitized voice patterns, or anything that can be stored as digits. The DEFINE statement can use the LIKE keyword to declare a 4GL variable like a BYTE column in an Informix database. The INFORMIX-SE database server does not support BYTE columns, but the 4GL application program can declare program variables of the BYTE data type. The data type BYTE has no maximum size; the theoretical limit is 231 bytes, but the practical limit is determined by the storage capacity of your system.
3-14
BYTE
You can use a BYTE variable to store, retrieve, or update the contents of a BYTE database column, or to reference a le that you wish to display to users of the 4GL program through an external editor. After you declare a BYTE data type, you must use the LOCATE statement to specify the storage location. When you select a BYTE column, you can assign all or part of it to a variable of type BYTE. You can use brackets ( [ ] ) and subscripts to reference only part of a BYTE value, as shown in the following example:
SELECT cat_picture [1,75] INTO cat_nip FROM catalog WHERE catalog_num = 10001
This statement reads the rst 75 bytes of the cat_picture column of the row with the catalog number 10001, and stores this data in the cat_nip variable. (Before running this query, the LOCATE statement must rst be executed to allocate memory for the cat_nip BYTE variable.)
CHAR
CHAR
The CHAR data type of 4GL can store a character string, up to a number of bytes specied between parentheses in the size parameter of the data type declaration. These can be printable or non-printable characters (see NonPrintable Characters on page 3-71), as dened for the locale. The size can range from 1 to 32,767 bytes. For example, the variable keystrokes in the following declaration can hold a character string of up to 78 bytes:
DEFINE keystrokes CHAR(78)
If the size is not specied, the resulting default CHAR data type can store only a single byte. In a form, you cannot specify the size of a FORMONLY CHAR eld; the size defaults to the eld length from the screen layout. A character string returned by a function can contain up to 32,767 bytes. On INFORMIX-SE servers, the maximum data string length that a CHAR column can store is 32,511 bytes, but CHAR variables are not constrained by this. When a value is passed between a CHAR variable and a CHAR database column, or between two CHAR variables, exactly size bytes of data are transferred, where size is the declared length of the 4GL variable or the database column that receives the string. If the length of the data string is shorter than size, the string is padded with trailing blanks (ASCII 32) to ll the declared size. If the string is longer than size, the stored value is truncated. The ASCII 0 end-of-data character terminates every CHAR value; in most contexts, any subsequent characters in a data string cannot be retrieved from or entered into CHAR database columns. Use the CLIPPED operator of 4GL if you wish to convert CHAR variables with NULL values to empty strings. To perform arithmetic on numbers stored in variables, use a number data type. CHAR variables can store digits, but you might not be able to use them in some calculations. Conversely, leading zeros (in some postal codes, for example) are stripped from values stored as number data types INTEGER or SMALLINT. To preserve leading zeros, store such values as CHAR data types.
GLS
In most locales, CHAR data types require one byte of storage per character, or size bytes for size characters. In some East Asian locales, however, more than one byte may be required to store an individual logical character, and some white space characters can occupy more than one byte of storage.
IBM Informix 4GL Reference Manual
3-16
CHARACTER
By default, when character strings (whether of data type CHAR or VARCHAR) are sorted by 4GL in a nondefault client locale, collation is in code-set order. If the COLLATION setting in the locale les denes a localized collation order, 4GL uses this order to sort CHAR and VARCHAR values, provided that the DBNLS environment variable is set to 1. (Even if the database locale denes a nondefault collation sequence, in most contexts the database server uses the code-set order to sort CHAR and VARCHAR column values.) The database server generally sorts strings by code-set order, even if the COLLATION category of the locale denes a nondefault order, except for values in NCHAR or NVARCHAR columns. (COLLATION functionally replaces the XPG3 category LC_COLLATE in earlier Informix GLS products.) If the database and 4GL client have different locales, the order of collation can depend on whether 4GL or the database server performs the sort operation. If the database has NCHAR or NVARCHAR columns, you must set the DBNLS environment variable to 1 if you want to store values from such columns in CHAR or VARCHAR variables of 4GL, or if you want to insert values of CHAR or VARCHAR variables into NCHAR or NVARCHAR database columns. For more information on using non-ASCII values in CHAR columns, see Appendix E, Developing Applications with Global Language Support.
CHARACTER
The CHARACTER keyword is a synonym for CHAR.
DATE
The DATE data type stores calendar dates. The date value is stored internally as an integer that evaluates to the count of days since December 31, 1899. The default display format of a DATE value depends on the locale. In the default (U.S. English) locale, the default format is
mm/dd/yyyy
where mm is a month (1 to 12), dd is a day of the month (1 to 31 or less), and yyyy is a year (0001 to 9999). The DBDATE environment variable can change the separator or the default order of time units for data entry and display.
DATETIME
GLS
In some East-Asian locales, the GL_DATE environment variable can specify Japanese or Taiwanese eras for the entry and display of DATE values. (In any locale, GL_DATE can specify formats beyond what DBDATE can specify.) By default, if the user of a 4GL application enters from the keyboard a singledigit or double-digit value for the year, as in 3 or 03, 4GL uses the setting of the DBCENTURY environment variable to supply the rst two digits of the year. (Users must pad the year value with one or two leading zeros to specify years in the First Century; for example, 093 or 0093 for the year 93 A.D.) Dates that are stored as CHAR or VARCHAR strings are not affected by DBCENTURY; see Appendix D, Environment Variables. You can also set the CENTURY attribute for individual DATE elds to override the global DBCENTURY expansion rule in that eld; see CENTURY on page 6-35 for details of setting this eld attribute. Because DATE values are stored as integers, you can use them in arithmetic expressions, such as the difference between two DATE values. The result, a positive or negative INT value, is the number of days that have elapsed between the two dates. The UNITS DAY operator can convert this to an INTERVAL data type. (DATE operands in division, multiplication, or exponentiation operations generally cannot produce meaningful results.) The FORMAT attribute species DATE display formats in forms. For month, 4GL accepts the value 1 or 01 for January, 2 or 02 for February, and so on. For days, it accepts a value 1 or 01 for the rst day of the month, 2 or 02 for the second, and so on, up to the maximum number of days in a given month.
DATETIME
The DATETIME data type stores an instance in time, expressed as a calendar date and time-of-day. You specify the time units that the DATETIME value stores; the precision can range from a year through a fraction of a second. Data values are stored as DECIMAL formats representing a contiguous sequence of values for units of time.
DATETIME Qualier p. 3-76
DATETIME
3-18
DATETIME
GLS
In some East-Asian locales, the GL_DATETIME environment variable can specify Japanese or Taiwanese eras for the entry and display of DATETIME values. (In any locale, however, GL_DATETIME can specify nondefault data entry and data display formats for DATETIME values.) The scale and precision specication is called the DATETIME qualier. It uses a rst TO last format to declare variables and screen elds. You must substitute one or two of these keywords for the rst and last terms.
Keyword YEAR MONTH DAY HOUR MINUTE SECOND FRACTION (scale) or FRACTION Corresponding Time Unit and Range of Values A year, numbered from 0001 (A.D.) to 9999 A month, numbered from 1 to 12 A day, numbered from 1 to 31, as appropriate for its month An hour, numbered from 0 (midnight) to 23 A minute, numbered from 0 to 59 A second, numbered from 0 to 59 A decimal fraction of a second, with a scale of up to ve digits; the default scale is three digits (thousandth of a second)
The keyword specifying last in rst TO last cannot represent a larger unit of time than rst. Thus, YEAR TO SECOND or HOUR TO HOUR are valid, but DAY TO MONTH results in a compiler error, because the value for last (here MONTH) species a larger unit of time than DAY, the rst keyword. Unlike INTERVAL qualiers, DATETIME qualiers cannot specify nondefault precision (except for FRACTION, if that is the last keyword in the qualier). The following are examples of valid DATETIME qualiers:
s s s s
Operations with DATETIME values that do not include YEAR in their qualier use the system date to supply any additional precision. If the rst term is DAY and the current month has fewer than 31 days, unexpected results can occur.
Data Types and Expressions 3-19
DATETIME
For example, assume that it is February, and you wish to store data from January 31 in the sometime variable that is declared in this statement:
DEFINE sometime DATETIME DAY TO MINUTE CREATE TABLE mytable (mytime DATETIME DAY TO MINUTE) LET sometime = DATETIME(31 12:30) DAY TO MINUTE INSERT INTO mytable VALUES (sometime)
Because the column mytime does not store the month or year, the current month and year are used to evaluate whether the inserted value is within acceptable bounds. February has only 28 (or 29) days, so no value for DAY can be larger than 29. The INSERT statement in this case would fail, because the value 31 for day is out of range for February. To avoid this problem, qualify DATETIME data types with YEAR or MONTH as the rst keyword, and do not enter data values with DAY as the largest time unit.
The DATETIME literal format begins with the DATETIME keyword, followed by
a pair of parentheses that enclose unsigned whole numbers (separated by delimiters) to represent a consecutive sequence of year through fraction values, or a subset thereof. This must be followed by a DATETIME qualier, specifying the rst TO last keywords for the set of time units within the numeric DATETIME value.
3-20
DATETIME
The required delimiters must separate every time unit value in a literal. DATETIME YEAR TO FRACTION(3) values, for example, require six delimiters, as shown in Figure 3-1.
Hyphen Space Colon Decimal point Figure 3-1 Numeric Date and Time
98-08-15 12:42:06.011
Year Month Day Hour Minute Second Fraction
These are the delimiters that are required for separating successive units of time within DATETIME literal values.
Delimiter Hyphen (- ) Blank space Colon (: ) Decimal point (. ) Position Within Numeric DATETIME Value Between the year, month, and day portions of the value Between the day and hour portions Between the hour, minute, and second portions Between the second and fraction portions
DATETIME literals can specify every time unit from the data type declaration,
or only the units of time that you need. For example, you can assign a value qualied as MONTH TO HOUR to a variable declared as YEAR TO MINUTE if the value contains information for a contiguous sequence of time units. You cannot, however, assign a value for just month and hour; in this case, the DATETIME literal must also include a value (and delimiters) for day. A DATETIME literal that species fewer units of time than in the declaration is automatically expanded to ll all the declared time units. If the omitted value is for the rst unit of time, or for this and for other time units larger than the largest unit that is supplied, the missing units are automatically supplied from the system clock-calendar. If the value omits any smaller time units, their values each default to zero (or to 1 for month and day) in the entry. To specify a year between 1 and 99, you must pad the year value with leading zeros.
Data Types and Expressions 3-21
DATETIME
The DBCENTURY environment variable determines how single-digit and double-digit year values are expanded; see Appendix D, Environment Variables. The CENTURY attribute for an individual DATETIME eld can override the global DBCENTURY expansion rule within that eld.
In this case, the call_dtime variable was declared as DATETIME YEAR TO MINUTE, so the character string must specify values for year, month, day, hour, and minute time units. If the character string does not contain information for all the declared time units, an error results. Similarly, an error results if a delimiter is omitted, or if extraneous blanks appear within the string. When a user of the 4GL program enters data in a DATETIME eld of a screen form, or during a PROMPT statement that expects a DATETIME value, the only valid format is a numeric DATETIME value, entered as an unquoted string. Any entry in a DATETIME eld must be a contiguous sequence of values for units of time and delimiters, in the following format (or in some subset of it):
year-month-day hour:minute:second.fraction
Depending on the data type declaration of the DATETIME eld, each of these units of time can have values that combine traditional base-10, base-24, base60, and lunar calendar values from clocks and calendars. Values that users enter in a DATETIME eld of the 4GL form need not include all the declared time units, but users cannot enter data as DATETIME literals, a format that is valid only within 4GL statements and in the data type declarations of FORMONLY DATETIME elds of form specication les.
3-22
DEC
values (as described in DECIMAL (p, s) on page 3-23), but with sets of consecutive digits representing the declared time units. All time-unit values of a DATETIME data type are two-digit numbers, except for the year and fraction values. The year is stored as four digits. The fraction requires n digits, for 1 n 5, rounded up to an even number. You can use the following formula (rounded up to a whole number of bytes) to calculate the number of bytes required to store a DATETIME value:
( ( total_number_of_digits_for_all_time_units) /2)+1
For example, a YEAR TO DAY qualier requires a total of 8 digits (4 for year, 2 for month, and 2 for day), or ((8/2) + 1) = 5 bytes of storage. For information about DATETIME values in expressions, see Time Expressions on page 3-72.
DEC
The DEC keyword is a synonym for DECIMAL.
DECIMAL (p, s)
The DECIMAL(p,s) data type stores values as xed-point decimal numbers, of up to 30 (and for some data values, up to 32) signicant digits. As the syntax diagram in Simple Data Types on page 3-9 indicates, you can optionally specify precision (the number of signicant digits) and scale (the number of digits to the right of the decimal point). For example, DECIMAL (14,2) species a total of 14 signicant digits, 2 of which describe the fractional part of the value. The largest absolute value that a DECIMAL(p,s) data type can store without an error is 10 p-s -10 -s, where p is the precision and s is the scale. Values with an absolute value less than 0.5 10-s are stored as zero. You cannot specify p or s for a FORMONLY DECIMAL eld in a form; its precision is the smaller of 32 and (length - 2), where length is the eld width in the screen layout.
DECIMAL (p,s) data types are useful for storing numbers with fractional parts
that must be calculated exactly, such as rates or percentages. Unless you are developing a scientic or engineering application that explicitly controls for measurement error, store oating-point numbers as DECIMAL(p,s) values.
DECIMAL (p)
When a user enters data in a SMALLFLOAT or FLOAT eld, 4GL converts the base-10 value to binary format for storage. Likewise, to display a FLOAT or SMALLFLOAT number, 4GL reformats it from binary to base-10. Both conversions can lead to inaccuracy. Thus, if 10.7 is entered into a FLOAT eld, it might be stored as 10.699999 or as 10.700001, depending on the magnitude and the sign of the binary-to-decimal conversion error. This limitation is a feature of digital computers, rather than of 4GL, but it might motivate you to use DECIMAL(p,s) rather than FLOAT in contexts requiring high precision.
DECIMAL(p,s) values are stored internally with the rst byte representing a
sign bit and a 7-bit exponent in excess-65 format; the rest of the bytes express the mantissa as base-100 digits. This implies that DECIMAL(32,s) data types store only s-1 decimal digits to the right of the decimal point, if s is an odd number. The stored value can have up to 30 signicant decimal digits in its fractional part, or up to 32 digits to the left of the decimal point. The following formulae calculate storage (in bytes) needed for DECIMAL(p,s) values, with any fractional part of the result discarded: When scale is even: (precision + 3) /2) When scale is odd: (precision + 4) /2) For example, DECIMAL(14,2) requires ((14 + 3) / 2), or 8 bytes of storage.
DECIMAL (p)
When you specify both the precision and the scale, the 4GL program can manipulate the DECIMAL (p,s) value with xed-point arithmetic. If the data type declaration species no precision or scale, however, the default is DECIMAL(16), a oating-point number with a precision of 16 digits. If only one parameter is specied, this is interpreted as the precision of a oating-point number whose exponent can range from 10-130 to 10126. The range of absolute data values is approximately from 1.0E-130 to 9.99E+126.
3-24
DOUBLE PRECISION
In an ANSI-compliant database, declaring a column as DECIMAL(p) results in a xed-point data type with a precision of p and a scale of zero. If you declare a 4GL data type LIKE a DECIMAL(p) column in an ANSI-compliant Informix database, the resulting data type is restricted to a scale of zero, which is equivalent to an integer. For DECIMAL(p,0) data types, any signicant digits (within the declared precision) in the fractional part of a data value are stored internally, but are not displayed. For example, if a data value of 0.25 is stored in the DECIMAL(25,0) variable Q, the value of Q is displayed as zero, but the Boolean expression (Q > 0) evaluates as TRUE.
DOUBLE PRECISION
The DOUBLE PRECISION keywords are a synonym for FLOAT.
FLOAT
The FLOAT data type stores values as double-precision oating-point binary numbers with up to 16 signicant digits. FLOAT corresponds to the double data type in the C language. Values for the FLOAT data type have the same range of values as the C double data type on your C compiler. FLOAT data types usually require 8 bytes of memory storage. For compatibility with the ANSI standard for embedded SQL, you can declare a whole number between 1 and 14 as the precision of a FLOAT data type, but the actual precision is data-dependent and compiler-dependent.
A variable of the FLOAT data type typically stores scientic or engineering
data that can be calculated only approximately. Because oating-point numbers retain only their most signicant digits, a value that is entered into A FLOAT variable or database column can differ slightly from the numeric value that a 4GL form or report displays. This rounding error arises because of the way computers store oating-point numbers internally. For example, you might enter a value of 1.1 into a FLOAT eld. After processing the 4GL statement, the program might display this value as 1.09999999. This occurs in the typical case where the exact oatingpoint binary representation of a base-10 value requires an innite number of digits in the mantissa. The computer stores a nite number of digits, so it stores an approximate value, with the least signicant digits treated as zeros.
INT
-1234.56789e-3
You can use uppercase or lowercase E as the exponent symbol; omitted signs default to + (positive). If a number in another format (such as an integer or a xed-point decimal) is supplied in a .4gl le or from the keyboard when a FLOAT value is expected, 4GL attempts data type conversion. In reports and screen displays, the USING operator can format FLOAT values. Otherwise, the default scale in output is two decimal digits.
INT
The INT keyword is a synonym for INTEGER.
INTEGER
The INTEGER data type stores whole numbers in a range from -2,147,483,647 to +2,147,483,647. The negative number -2,147,483,648 is a reserved value that cannot be used. Values are stored as signed 4-byte binary integers, with a scale of zero, regardless of the word length of your system. INTEGER can stores counts, quantities, categories coded as natural numbers, and the like. Arithmetic operations on binary integers are typically without rounding error; these operations and sort comparisons are performed more efciently than on FLOAT or DECIMAL data. INTEGER values, however, can only store data whose absolute value is less than 2 31. Any fractional part of the value is discarded. If a value exceeds this numeric range, neither 4GL nor the database can store the data value as an INTEGER data type.
3-26
INTERVAL
INTEGER variables can store SERIAL values of the database. If a user inserts a new row into the database, 4GL automatically assigns the next whole number in sequence to any eld linked to a SERIAL column. Users do not need to enter data into such elds. Once assigned, a SERIAL value cannot be changed. (See the description of the SERIAL data type in the Informix Guide to SQL: Reference.)
INTERVAL
This data type stores spans of time, the differences between two points in time. You can also use it to store quantities that are naturally measured in units of time, such as age or sums of ages, estimated or actual time required for some activity, or person-hours or person-years of effort attributed to some task. An INTERVAL data value is stored as a DECIMAL number that includes a contiguous sequence of values representing units of time. The INTERVAL data types of 4GL fall into two classes, based on their declared precision:
s s
A year-month interval represents a span of years, months, or both. A day-time interval represents a span of days, hours, minutes, seconds, and fractions of a second, or a contiguous subset of those units.
Automatic data type conversion between these two categories of INTERVAL data types is not a feature of 4GL. Unlike DATETIME data types, which they somewhat resemble in their format, INTERVAL data types can assume zero or negative values. The declaration of an INTERVAL data type uses the following syntax.
INTERVAL Qualier p. 3-80
INTERVAL
INTERVAL
INTERVAL Qualiers
The INTERVAL qualier species the precision and scale of an INTERVAL data type, using a rst TO last format to declare 4GL variables, formal arguments of functions and reports, and screen elds. It has the same syntax in declarations of 4GL variables and FORMONLY elds as for INTERVAL columns of the database. You must substitute one or two keywords from only one the following lists for rst and last keywords of an INTERVAL qualier.
Year-Month INTERVAL Keywords YEAR, MONTH Day-Time INTERVAL Keywords DAY, HOUR, MINUTE, SECOND, FRACTION
As with DATETIME data types, you can declare INTERVAL data types to include only the units that you need. INTERVAL represents a span of time independent of an actual date, however, so you cannot mix keywords from both lists in the same INTERVAL qualier. Because the number of days in a month depends on the month, an INTERVAL data value cannot combine both months and days as units of time. For example, specifying MONTH TO MINUTE as an INTERVAL qualier produces a compile-time error. Arithmetic expressions that combine year-month INTERVAL values with DATE values (or with DATETIME values that include smaller time units than month) can return an invalid date, such as February 30. (In general, adding or subtracting an interval of months from any calendar date later than the 28th day of any month can produce similar errors in SQL and 4GL expressions.) For any keyword specifying rst except FRACTION, you have the option of specifying a precision of up to 9 digits; otherwise the default precision is 2 digits, except for YEAR, which defaults to 4 digits of precision. If an INTERVAL qualier species only a single unit of time, the keywords specifying rst and last are the same. When rst and last are both FRACTION, you can only specify the scale after the last keyword. When last is FRACTION, you can specify a scale of 1 to 5 digits; otherwise, the scale defaults to 3 digits (thousandth of a second). For example, the following are valid INTERVAL qualiers:
HOUR TO MINUTE MONTH(5) TO MONTH FRACTION TO FRACTION(4) HOUR(9) TO FRACTION(5)
3-28
INTERVAL
The keyword specifying the last term cannot represent a larger unit of time than that specifying rst term. Thus, YEAR TO MONTH and HOUR TO HOUR are valid, but HOUR TO DAY results in a compiler error, because the rst keyword (here HOUR) species a smaller unit of time than DAY, the last keyword. After you declare an INTERVAL data type, a 4GL statement can assign it the value of a time expression (as described in Time Expressions on page 3-72) that species an INTERVAL value. The simplest way to do this is as an INTERVAL literal or as a character string. Both formats require that you specify a numeric INTERVAL value.
A numeric INTERVAL uses the same delimiters as DATETIME values, except that month and day need no separator, because they cannot both appear in the same INTERVAL value. The following delimiters are required for separating successive units of time within literal INTERVAL values.
Delimiter Hyphen (- ) Blank space Colon (: ) Decimal point (. ) Position Within Numeric INTERVAL Value Between the year, month, and day portions of the value Between the day and hour portions Between the hour, minute, and second portions Between the second and fraction portions
INTERVAL
Time unit values in a numeric INTERVAL have a default precision of 2 digits, except for year (4 digits), and fraction (3). The qualier can override these defaults for the rst time unit, and for the scale of the fraction. For example, INTERVAL YEAR(3) TO MONTH values require one delimiter.
Year
102-08
Hyphen
Month
120815 12:42:06.01
Day Hour Minute Second Fraction INTERVAL literals can specify all the time units from the data type decla-
ration, or only the units that you need. For example, you can assign a value qualied as HOUR TO MINUTE to a variable declared as DAY TO SECOND if the entered value contains information for a contiguous sequence of time units. You cannot, however, assign only day and minute values; in this case, the INTERVAL literal must also include a value (and delimiters) for hour. The value for the rst time units in an INTERVAL literal can have up to nine digits of precision (except for FRACTION, which cannot include more than ve digits). If a rst unit value to be entered is greater than the default number of digits for that time unit, however, you must explicitly identify the number of signicant digits that you are entering. For example, an INTERVAL of DAY TO HOUR that spans 162.5 days can use the following format:
INTERVAL (162 12) DAY(3) TO HOUR
3-30
INTERVAL
An INTERVAL literal in a 4GL statement must include numeric values for both the rst and last time units from the qualier, and values for any intervening time units. You can optionally specify the precision of the rst time unit (and also a scale, if the last keyword of the INTERVAL qualier is FRACTION).
Similarly, values entered as character strings into INTERVAL columns of the database must include information for all time units that were declared for that column. For example, the following INSERT statement shows an INTERVAL value entered as a character string:
INSERT into manufact (manu_code, manu_name, lead_time) VALUES ("BRO", "Ball-Racquet Originals", "160")
Because the lead_time column is dened as INTERVAL DAY(3) TO DAY, this INTERVAL value requires only one value, indicating the number of days required. If the character string does not contain information for all the declared time units, the database server returns an error.
MONEY
Depending on the data type declaration of the eld, each of these units of time (except the rst) is restricted to values that combine traditional base-10, base-24, base-60, and lunar calendar values from clocks and calendars. The rst value can have up to nine digits, unless FRACTION is the rst unit of time. (If FRACTION is the rst time unit, the maximum scale is 5 digits.) Values that users enter in an INTERVAL eld of a 4GL form need not include all the declared time units, but users cannot enter data as INTERVAL literals, a format that is valid only within 4GL statements and in data type declarations of FORMONLY elds of data type INTERVAL in form specication les. By default, all values for time units in a numeric INTERVAL are two-digit numbers, except for the year and fraction values. The year value is stored as four digits. The fraction value requires n digits where 1 n 5, rounded up to an even whole number. You can use the following formula (rounded up to a whole number of bytes) to calculate the number of bytes required for an INTERVAL value:
( ( total_number_of_digits_for_all_time_units)/2) + 1
For example, a YEAR TO MONTH qualier requires a total of 6 digits (4 for year and 2 for month), or ((6/2) + 1) = 4 bytes of storage. For information on using INTERVAL data in arithmetic and relational operations, see Expressions of 4GL on page 3-49.
MONEY
The MONEY data type stores currency amounts. Like the DECIMAL data type, the MONEY data type stores xed-point numbers, up to a maximum of 32 signicant digits. As the syntax diagram in Simple Data Types on page 3-9 indicates, you can optionally include one or two whole numbers to specify the precision (the number of signicant digits) and the scale (the number of digits to the right of the decimal point). Unlike the DECIMAL data type (described in DECIMAL (p, s) on page 3-23), which stores oating-point numbers if its data type declaration species neither scale nor precision, MONEY values are always stored as xed-point decimal numbers. If you declare a MONEY data type with only one parameter, 4GL interprets that parameter as the precision. By default, the scale is 2, so the data type MONEY(p) is stored internally as DECIMAL(p,2), where p is the precision (1 p 32).
3-32 IBM Informix 4GL Reference Manual
NCHAR
If no parameters are specied, MONEY is interpreted as DECIMAL(16,2). This stores 16 signicant digits, 2 of which describe the fractional part of the currency value. The largest absolute value that you can store without error as a MONEY data type is 10p-s -10-s. Here p is the precision, and s is the scale. Values with an absolute value less than 0.5 x 10-s are stored as zero. You cannot specify the precision or the scale of a FORMONLY MONEY eld in a 4GL form; here the precision defaults to the smaller of 32 or (length - 2), where length is the eld length from the SCREEN section layout. On the screen, MONEY values are displayed with a currency symbol, by default, a dollar sign ( $ ), and a decimal point ( . ) symbol. You can change the display format for MONEY values in the DBMONEY or DBFORMAT environment variable. The settings of these variables take precedence over the default currency format of the locale. 4GL statements and keyboard input by users to elds of screen forms do not need to include currency symbols in literal MONEY values. The same formulae as for DECIMAL values apply to MONEY data types, with any fractional part of the result discarded: When scale is even: (precision + 3) /2 When scale is odd: (precision + 4) /2 For example, a MONEY(13,2) variable has a precision of 13 and a scale of 2. This requires ((13 + 3) /2) = 8 bytes of storage.
NCHAR
The NCHAR data type stores character data in a xed-length eld. This data can be a sequence of single-byte or multibyte letters, numbers, and symbols. However, the code set of your database locale must support the characters. NCHAR columns of the database can support localized collation, if the locale species a localized collating sequence, but 4GL treats NCHAR variables like CHAR variables.
NCHAR stores the number of bytes specied between parentheses in the size
parameter of the data type declaration. The size can range from 1 to 32,767 bytes.
SE
For INFORMIX-SE, the size can range from 1 to 32,511 bytes. If you do not specify size in a DEFINE declaration, the default is NCHAR(1).
Data Types and Expressions 3-33
NVARCHAR
When the database server retrieves or sends an NCHAR value, it transfers exactly size bytes of data. If the length of a character string is shorter than size, the database server extends the string with spaces to make up the size bytes. If the string is longer than size bytes, the database server truncates the string.
NVARCHAR
The NVARCHAR data type stores character data in a variable-length eld. This data can be a sequence of single-byte or multibyte letters, numbers, and symbols. However, the code set of your database locale must support the characters. NVARCHAR columns of the database can support localized collation, if the locale species a localized collating sequence, but 4GL treats NVARCHAR variables like VARCHAR variables. The database server does not strip an NVARCHAR object of any user-entered trailing white space, nor does it pad the NVARCHAR object to the full length of the column. However, if you specify a minimum reserved space (reserve) and some of the data values are shorter than that amount, some of the space that is reserved for rows goes unused.
NUMERIC
The NUMERIC keyword is a synonym for DECIMAL. (When the word numeric appears in lowercase letters in this manual, it is always the adjective formed from the noun number, rather than the name of a data type.) The NUMERIC keyword is a synonym for DECIMAL. (When the word numeric appears in lowercase letters in this manual, it is always the adjective formed from the noun number, rather than the name of a data type.)
REAL
The REAL keyword is a synonym for SMALLFLOAT. (When the phrase real number appears in lowercase letters in this manual, it denotes a number that is neither imaginary nor transnite, rather than the name of a data type.)
3-34
RECORD
RECORD
The RECORD data type is an ordered set of variables. Within each of these sets (called a program record), the component variables (called members) can be of any 4GL data type, or any combination of data types in a xed order. Valid data types for member variables of records include all the simple data types (listed in Simple Data Types on page 3-9), the large data types (BYTE, TEXT), and the structured data types (ARRAY, RECORD). The following is the data type declaration syntax for RECORD variables.
RECORD Data Type
,
RECORD member Simple Data Type p. 3-9 END RECORD
LIKE Table Qualier p. 3-89 LIKE Table Qualier p. 3-89 table. table.*
column
Description is the name of a column in the default (or specied) database. is a name that you declare for a member variable of the record. is the SQL identier of a database table, synonym, or view.
You can use the LIKE keyword to specify that a member variable has the same data type as a database column. If you do not specify member names, but use an asterisk ( * ) after a table name, you declare a record whose members have the same identiers as the columns in table; their data types correspond to the xed sequence of SQL data types in an entire row of the table. (Any SERIAL column in table corresponds to a record member of data type INTEGER.)
RECORD
This example uses the LIKE keyword to declare two program records, one of which contains a member variable called nested of the RECORD data type:
DEFINE p_customer RECORD LIKE informix.customer.*, p_orders RECORD order_num LIKE informix.orders.order_num, nested RECORD a LIKE informix.items.item_num, b LIKE informix.stock.unit_descr END RECORD END RECORD
If table is a view, the column cannot be based on an aggregate. You cannot specify table.* if table is a view that contains an aggregate column. In an ANSI-compliant database, you must qualify the table name with the owner prex, if the program will be run by users other than owner. If the table is an external or external, distributed table, its name must be qualied by the name of the remote database and by the name of its database server.
GLS
If the client locale and the database locale are not identical, do not use the
LIKE keyword to declare a member variable whose name is the same as a database column whose identier includes any non-ASCII character that is
The notation record.member refers to an individual member of a record, where member is the identier of the member. The notation record.rst THRU record.last refers to a consecutive subset of members, from record.rst through record.last. Here rst is an identier that was listed before last among the explicit or implicit member names in the RECORD declaration. You can also use the keyword THROUGH as a synonym for THRU. The notation record.* refers to the entire record.
3-36
SMALLFLOAT
You cannot use THRU or THROUGH to indicate a partial list of screen record members in 4GL statements for displaying or entering data in a screen form. You cannot use THRU, THROUGH, or .* to reference a program record that contains an ARRAY variable among its members. (But you can use these notations to specify all or part of a record that contains one or more other records as members.) You cannot use THRU, THROUGH, or .* notation in a SELECT or INSERT variable list in a quoted string in PREPARE statements. (You can, however, use the .* notation to specify a program record in the variable list of an INSERT or SELECT clause of a DECLARE statement.)
A program record whose members correspond in number, order, and data type compatibility to a database table or to a screen record can be useful for transferring data from the database to the screen, to reports, or to functions of the 4GL program. For more information, see Summary of Compatible 4GL Data Types on page 3-46 and Chapter 7, INFORMIX-4GL Reports.
SMALLFLOAT
The SMALLFLOAT data type stores single-precision oating-point binary numbers, with up to 8 signicant digits. The range of values is the same as for the oat data type of C. The storage requirement is usually 4 bytes. The SMALLFLOAT data type typically stores scientic or engineering data that can only be calculated approximately. Because oating-point numbers retain only their most signicant digits, a value entered into a SMALLFLOAT variable or column can differ slightly from the base-10 value that an 4GL form or 4GL report displays. This error arises from the internal storage format of binary oating-point numbers. For example, if you enter a value of 1.1 into a SMALLFLOAT eld, after processing the 4GL statement, the screen might display this value as 1.1000001. This occurs in the typical case where the exact oating-point binary representation of a base-10 value requires an innite number of digits in the mantissa. A computer stores only a nite number of digits, so it stores an approximate value, with the least-signicant digits treated as zeros.
SMALLINT
Statements of 4GL can specify SMALLFLOAT values as oating-point literals, using the following format.
Sign of the mantissa Mantissa Exponent Sign of the exponent
-1234.5e-3
You can use uppercase or lowercase E as the exponent symbol; omitted signs default to + (positive). If a literal value in another format (such as an integer or a xed-point decimal) is supplied from the keyboard into a SMALLFLOAT eld, or in a 4GL statement, 4GL attempts data type conversion. In reports and screen displays, the USING operator can format SMALLFLOAT values. The default scale in output, however, is two digits.
SMALLINT
The SMALLINT data type stores data as signed 2-byte binary integers. Values must be whole numbers within the range from -32,767 to +32,767. Any fractional part of the data value is discarded. If a value lies outside this range, you cannot store it in a SMALLINT variable or database column. (The negative value -32,768 is reserved; it cannot be assigned to a SMALLINT variable or database column, and it cannot be entered into a SMALLINT eld of a form.) You can use SMALLINT variables and FORMONLY elds of screen forms to store, manipulate, and display data that can be represented as whole numbers of an absolute value less than 2 15. This data type typically stores small whole numbers, Boolean values, ranks, or measurements that classify data into a small number of numerically-coded categories. Because the SMALLINT data type requires only 2 bytes of storage, arithmetic operations on SMALLINT operands can be done very efciently, provided that all of the data values lie within the somewhat limited SMALLINT range.
3-38
TEXT
TEXT
The TEXT data type stores character data in ASCII strings. TEXT resembles the BYTE data type, but 4GL supports features to display TEXT variables whose values are restricted to combinations of printable ASCII characters and the following white space characters:
s s s
If you attempt to include other non-printable characters in TEXT values, the features of 4GL for processing TEXT data might not work correctly.
GLS
In some locales, other white space characters are supported; more than one byte is required to store some East-Asian white space characters. Strings stored as TEXT variables have a theoretical limit of 231 bytes, and a practical limit determined by the available storage on your system.
SE
INFORMIX-SE database servers do not support TEXT columns, but regardless of the database server, you can declare 4GL variables of type TEXT.
You can use a TEXT variable to store, retrieve, or update the contents of a TEXT database column, or to reference a le that you wish to display to users of the 4GL program through a text editor. After you declare a TEXT data type, you must use the LOCATE statement to specify the storage location. When you retrieve a value from a TEXT column, you can assign all or part of it to a TEXT variable. Use brackets ( [ ] ) and comma-separated subscripts to reference only a specied part of a TEXT value, as in the following example:
SELECT cat_description [1,75] INTO cat_nap FROM catalog WHERE catalog_num = 10001
This reads the rst 75 bytes of the cat_description column of the row with the catalog number 10001, and stores these data in the cat_nap TEXT variable.
VARCHAR
VARCHAR
The VARCHAR data type stores character strings of varying lengths. You can optionally specify the maximum size of a data string, and the minimum storage reserved on disk.
SE
INFORMIX-SE database servers do not support this data type, but any 4GL application can declare VARCHAR variables.
The declared size of VARCHAR can range from 1 to 255 bytes. If you specify no size, the default is 1. The data type can store shorter character strings than this maximum size, but not longer strings. In a form specication le, you cannot specify any parameters for a FORMONLY VARCHAR eld; here the size defaults to the physical eld length in the screen layout. In data type declarations, the minimum reserved storage can range from 0 to 255 bytes, but this cannot be greater than the declared size. Just as 4GL accepts but ignores the precision specication in FLOAT or DOUBLE PRECISION data type declarations for compatibility with ANSI/ISO SQL syntax, 4GL accepts but ignores reserved in VARCHAR declarations. (But in SQL declarations like CREATE TABLE, the reserved value can affect the behavior of the database.)
3-40
VARCHAR
The ASCII 0 end-of-data character terminates every VARCHAR value; any subsequent characters in a data string generally cannot be retrieved from or entered into VARCHAR (nor CHAR) database columns. When you assign a value to a VARCHAR variable, only the data characters are stored, but neither 4GL nor the database server strips a VARCHAR value of user-entered trailing blanks. Unlike CHAR values, VARCHAR values are not padded with blank spaces to the declared maximum size, so the CLIPPED operator may not be needed in operations on VARCHAR values.
VARCHAR values are compared to CHAR values and to other VARCHAR values in 4GL Boolean expressions in the same way that CHAR values are
compared: the shorter value is padded on the right with spaces until both values have equal lengths and they are compared for the full length.
GLS
In most locales, VARCHAR values require one byte of storage per character, or size bytes for size characters. In some East Asian locales, however, more than one byte may be required to store an individual logical character, and some white space characters can occupy more than one byte of storage. If a collation order is dened by the COLLATION category in a locale le, the database server uses this order to sort values from NVARCHAR and NCHAR database columns in SQL statements, but uses code-set order to sort CHAR or VARCHAR values. If DBNLS is set to 1, 4GL uses COLLATION to sort CHAR or VARCHAR variables; otherwise, 4GL uses code-set order. If 4GL and the database have different locales, collation order for a sorting operation might depend on whether 4GL or the database server performs the sort. If the database has NVARCHAR or NCHAR columns, you must set the DBNLS environment variable to 1 if you want to store values from such columns in VARCHAR or CHAR variables of 4GL, or if you want to insert values of CHAR or VARCHAR variables into NCHAR or NVARCHAR database columns. For more information, see Appendix E, Developing Applications with Global Language Support.
objection when the process makes sense. If you assign a number expression to a CHAR variable, for example, 4GL converts the resulting number to a literal string. In an expression, 4GL attempts to convert the string representation of a number or time value to a number, time span, or point in time. An error is issued only if 4GL cannot perform the conversion. For example, 4GL converts the string "123.456" to the number 123.456 in an arithmetic expression, but adding the string "Juan" to a number produces an error. The global status variable is not reset when a conversion error occurs, unless you specify the ANY ERROR keywords (without CONTINUE) in a WHENEVER compiler directive, or include the - anyerr command-line argument.
3-42
the declared data types of the operands. (The exceptions are integers; see Arithmetic Operators on page 3-66.) The data type of the receiving variable determines the format of the stored or displayed result. The following rules apply to the precision and scale of the DECIMAL variable that results from an arithmetic operation on two numbers:
s
All operands, if not already DECIMAL, are converted to DECIMAL, and the result of the arithmetic operation is always a DECIMAL.
Source Operand FLOAT INTEGER MONEY (p) SMALLFLOAT SMALLINT Converted Operand DECIMAL (16) DECIMAL (10, 0) DECIMAL (p, 2) DECIMAL (8) DECIMAL (5, 0)
In addition and subtraction, 4GL adds trailing zeros to the operand with the smaller scale, until the scales are equal. If the data type of the result of an arithmetic operation requires the loss of signicant digits, 4GL reports an error. Leading or trailing zeros are not considered signicant digits, and do not contribute to the determination of precision and scale. If one operand has no scale (that is, a oating-point decimal), the result is also a oating-point decimal. The precision and scale of the result of an arithmetic operation depend on the precision and scale of the operands and on the arithmetic operator. The rules of 4GL are summarized in the following table for arithmetic operands that have a denite scale.
In this table, p1 and s1 represent the precision and scale of the rst operand, and p2 and s2 represent the precision and scale of the second operand.
Numeric Operation Addition ( + ) and Subtraction ( - ) Multiplication ( * ) Division ( / ) Precision and Scale of Returned Value Precision: MIN(32, MAX(p1 - s1, p2 - s2) + MAX(s1, s2) + 1) Scale: MIN( 30, MAX(s1, s2) ) Precision: MIN(32, p1+ p2) Scale: MIN(30, s1 + s2 ) Precision: 32 Scale: MAX(0, 32 - p1 + s1 - s2 )
These values are upper limits, because the actual precision and scale of DECIMAL(p,s) values are data-dependent. The USING operator can override the default scale when output is displayed.
If a DATE value is specied where a DATETIME YEAR TO DAY is expected, 4GL converts the DATE value to a DATETIME value. For example, 08/15/2001 becomes 2001-08-15. If a DATETIME YEAR TO DAY value is specied where a DATE is expected, 2001-08-15 becomes 08/15/2001. If a DATE value is specied where a DATETIME YEAR TO FRACTION (or TO SECOND, TO MINUTE, or TO HOUR) is expected, 4GL converts the DATE value to a DATETIME value, and lls any smaller time units from the DATETIME declaration with zeros. For example, the DATE value 08/15/2001 becomes 2001-08-15 00:00:00. If a DATETIME YEAR TO SECOND to DATE, value is specied where a DATE is expected, 4GL converts the DATETIME value to a DATE value, but drops any time units smaller than DAY. Thus, 2001-08-15 12:31:37 becomes 08/15/2001.
3-44
The EXTEND( ) operator can return a DATETIME value from a DATE operand.
When a character string is converted into a DATETIME or INTERVAL value, 4GL assumes that the character string includes information about all the declared time units. You cannot use character strings to enter DATETIME or INTERVAL values for a subset of time units, because this produces ambiguous values. If the character string does not contain information for all the declared time units, 4GL returns an error, as in some of these examples:
DEFINE tyme DATETIME YEAR TO DAY, mynt INTERVAL DAY TO SECOND LET tyme = DATETIME(5-12) MONTH TO DAY LET tyme = "5-12" --Valid --Error!
LET mynt = INTERVAL(11:15) HOUR TO MINUTE --Valid LET mynt = "11:15" --Error!
The previous DATETIME example (variable tyme) assigns a MONTH TO DAY value to a variable declared as YEAR TO DAY. Entering only these values is valid in the rst LET statement because the qualier of the DATETIME literal species no year, so 4GL automatically supplies the value of the current year. In the example of the character string, however, 4GL does not know whether the "5-12" refers to year and month, or month and day, so it returns an error.
The previous INTERVAL example (variable mynt) assigns an HOUR TO MINUTE value to a variable declared as DAY TO SECOND. The rst LET statement simply pads the value with zeros for day and second. The second LET statement produces a conversion error, however, because 4GL does not know whether "11:15" species HOUR TO MINUTE or MINUTE TO SECOND. Empty or blank strings are converted to null time (or number) values.
3-46
These relationships apply to values of simple data types, to simple members of RECORD data types, and to simple elements of ARRAY data types:
s
Unshaded cells show the types of values (listed in the top row) that 4GL can assign to each type of variable (listed on the left). Shaded cells indicate incompatible pairs of data types, for which 4GL does not support automatic data type conversion.
Data Type of Value to Be Passed SMALLFLOAT DATETIME SMALLINT INTERVAL VARCHAR DECIMAL
INTEGER
MONEY
FLOAT
CHAR
DATE
Symbols in the cells refer to notes in the next section. These apply when the data types of the passed value and of the receiving variable are not identical:
s
Light circles ( ) indicate the possibility of conversion failure, or discrepancies between the passed value and the receiving data type. Dark circles ( ) mark features that do not usually cause conversion errors, but that can produce unexpected data formats or values.
Data Types and Expressions 3-47
Numbers in dark circles ( ) indicate less critical conversion features. These can result in the assignment of unexpected values, or unexpected formats.
DBMONEY or DBFORMAT controls the format of the converted string. DBFORMAT, DBDATE, or GL_DATE controls the format of the result.
Rounding errors can produce an assigned value with a fractional part. An integer value corresponding to a count of days is assigned. An implicit EXTEND (value, YEAR TO DAY) is performed by 4GL. The DATE becomes a DATETIME YEAR TO DAY literal before assignment. If the passed value has less precision than the receiving variable, any missing time unit values are obtained from the system clock.
You may wish to avoid writing code that applies automatic conversion to
DATETIME variables declared with time units smaller than YEAR as the rst keyword of the qualier unless default values that feature ( ) assigns from
the system clock are useful in your application. For more information, see Chapter 2, The INFORMIX-4GL Language.
3-48 IBM Informix 4GL Reference Manual
Expressions of 4GL
Expressions of 4GL
A 4GL expression is a sequence of operands, operators, and parentheses that 4GL can evaluate as a single value.
4GL Expression
4GL Expression
)
Time Expressions:
INTERVAL Expression p. 3-74 DATETIME Expression p. 3-74 DATE Expression p. 3-74
Number Expressions:
Number Expression p. 3-66 Integer Expression p. 3-63 Boolean Expression p. 3-60
Usage
Statements, functions, form specications, operators, and expressions can have expressions as arguments, components, or operands. The context where an expression appears, as well as its syntax, determines the data type of its returned value. It is convenient to classify 4GL expressions into the following ve categories, based on the data type of the value that they return.
Expression Type Boolean Integer What the Expression Returns A value that is either TRUE or FALSE (or null in some contexts) A whole-number value of data type INT or SMALLINT (1 of 2)
Usage
What the Expression Returns A value of any of the number data types. For more information, see Number Data Types (page 3-10).
Character Time
A character string of data type CHAR or VARCHAR A value of data type DATE, DATETIME, or INTERVAL (2 of 2)
In this manual, if the term 4GL expression is not qualied as one of these ve data type categories, the expression can be any 4GL data type. As the diagram suggests, 4GL Boolean expressions are special cases of integer expressions, which in turn are a logical subset of number expressions. You can substitute a 4GL Boolean or integer expression where a number expression is valid (unless this results in an attempt to divide by zero).Topics that are discussed in this section include the following:
s s s s s s
Components of 4GL Expressions on page 3-52 Boolean Expressions on page 3-60 Integer Expressions on page 3-63 Number Expressions on page 3-66 Character Expressions on page 3-69 Time Expressions on page 3-72
3-50
The names of SPL variables The SQL keywords USER and ROWID Built-in or aggregate SQL functions that are not part of 4GL The BETWEEN and IN operators (except in form specications) The EXISTS, ALL, ANY, or SOME keywords of SQL expressions
Conversely, you cannot include the following 4GL operators in SQL or SPL expressions:
s s s s s
Arithmetic operators for exponentiation ( ** ) and modulus (MOD) String operators ASCII, COLUMN, SPACE, SPACES, and WORDWRAP Field operators FIELD_TOUCHED( ), GET_FLDBUF( ), and INFIELD( ) The report operators LINENO and PAGENO The time operators DATE( ) and TIME
These and other built-in functions and operators of 4GL are described in Chapter 5, Built-In Functions and Operators. See the Informix Guide to SQL: Syntax for the syntax of SQL expressions and SPL expressions.
Operators, as listed on the next page Parentheses, to override the default precedence of operators Operands, including the following:
Named values Function calls returning a single value Field names Literal values Other 4GL expressions
In the next example, however, y is assigned the value of 0 because the parentheses change the sequence of operations:
LET y = 15 MOD (3 + 2)
Chapter 4, INFORMIX-4GL Statements, describes the LET statement of 4GL, which can assign the value of an expression to a variable of a compatible data type.
3-52
Figure 3-2 Precedence ( P ) and Associativity ( A ) of 4GL Operators P 16 Operator . [] () UNITS + ** MOD * / + || LIKE MATCHES < <= = or == >= > != or <> IN( ) BETWEEN ... AND IS NULL NOT AND OR ASCII CLIPPED COLUMN ORD SPACES USING WORDWRAP Description Record membership Array index or substring Function call Single-qualier interval Unary plus Unary minus Exponentiation (by integer) Modulus (of integer) Multiplication Division Addition Subtraction Concatenation String comparison String comparison Test for: less than Less than or equal to Equal to Greater than or equal to Greater than Not equal to Test for: set membership Test for: range Test for: NULL Logical inverse Logical intersection Logical union Return ASCII character Delete trailing blanks Begin line-mode display Logical inverse of ASCII Insert blank spaces Format character string Multiple-line text display A Left Left None Left Right Right Left Left Left Left Left Left Left Right Right Left Left Left Left Left Left Right Left Left Left Left Left Right Right Right Right Right Right Right Example myrec.memb ar[i,6,k][2,(int-expr)] myfun(var1,expr) (int-expr) UNITS DAY + (number-expr) - numbarray_var3[i,j,k] (number-expr) ** (int-expr) (int-expr) MOD (int-expr) x * (number-expr) (number-expr) / arr[y] (number-expr) + (number-expr) (x - y) - (number-expr) "str" || "ing" (character-expr) LIKE "%z_%" (character-expr)MATCHES"*z?" (expr1) < (expr2) x <= yourfun(y,z) x = expr x >= FALSE var1 > expr myrec.memb<>LENGTH(var1) expr1 NOT IN (x,3,expr2) BETWEEN (integer-expr) AND 9 x IS NULL OR y IS NOT NULL NOT ((expr) IN (y,DATE)) expr1 AND fun(expr2,-y) LENGTH(expr1,j) OR expr2 LET x = ASCII (int-expr) DISPLAY poodle CLIPPED
PRINT COLUMN 58, "30" LET key = ORD(character-expr) DISPLAY (int-expr) SPACES TODAY USING "yy/mm/dd" PRINT odyssey WORDWRAP
15 14 13 12 11 10 9 8
7 6 5 4 3 2 1
Page 3-35 3-13 3-58 5-26 3-65 3-65 3-64 3-64 3-64 3-64 3-64 3-64 5-50 5-38 5-38 5-35 5-35 5-35 5-35 5-35 5-35 5-40 5-40 5-37 3-61 3-61 3-61 5-31 5-45 5-47 5-100 5-108 5-123 5-135
3-54
Figure 3-3 Data Types of Operands and of Returned Values P 16 Expression x . y w [x , y] ( y ) x UNITS + y
- y
Right (= y) Any INT or SMALLINT Any or Large Number or INTERVAL Number or INTERVAL INT or SMALLINT INT or SMALLINT Number Number Number or Time Number or Time Any Character Character Same as x Same as x Same as x Same as x Same as x Same as x Same as x Same as x Boolean Boolean Boolean INT or SMALLINT INT or SMALLINT Character Character
15 14
Returned Value Same as y Any or Character Any INTERVAL Same as y Same as y Number INT or SMALLINT Number or INTERVAL Number or INTERVAL Number or Time Number or Time Character Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Character Character Character INT or SMALLINT Character Character Character
Page 5-97 5-113 3-58 5-119 5-22 5-22 5-25 5-25 5-25 5-25 5-26 5-26 5-50 5-38 5-38 5-34 5-34 5-34 5-34 5-34 5-34 5-40 5-40 5-37 5-33 5-33 5-33 7-62 5-45 7-62 5-100 7-64 5-123 7-65
13 12
x * * y x MOD y x * y x / y
11 10 9 8
7 6 5 4 3 2 1
Number or Time Number or Time Any Character x MATCHES y Character x < y Any x <= y Any x = y or x == y Any x >= y Any x > y Any x != y or x <> y Any x IN (y) Any BETWEEN x AND y Any x IS NULL Any or Large NOT y x AND y Boolean x OR y Boolean ASCII y x CLIPPED Character COLUMN y ORD(y) x SPACES INT or SMALLINT x USING "y" Character,DATE,MONEY x WORDWRAP Character or TEXT x + y x - y x || y x LIKE y
Field operators FIELD_TOUCHED( ), GET_FLDBUF( ), and INFIELD( ) Report operators SPACE, LINENO, and PAGENO Time operators CURRENT, DATE( ), DAY( ), EXTEND( ), MDY( ), MONTH( ), TIME, TODAY, WEEKDAY( ), and YEAR( )
Where no data type is listed in the previous table, the operator has no left (or else no right) operand. If an operand is not of the data types listed here, 4GL attempts data type conversion, as described in Summary of Compatible 4GL Data Types on page 3-46. Most 4GL operators do not support RECORD nor ARRAY operands, but they can accept as an operand a variable (of a simple data type) that is an element of an array, or that is a member of a record.
Named values Function calls that return one value Literal values Other 4GL expressions
3-56
variable record
. ,
array
Element array
Description is the name of a structured variable of the ARRAY data type. The comma-separated expression list species the index of an element within the declared size of the array. is one of the built-in constants TRUE, FALSE, or NOTFOUND. is the name of a structured variable of the RECORD data type. is the name of a 4GL program variable of a simple data type.
Conditional COLOR attributes in form specication les can use a eld tag where a named value is valid in the syntax of a 4GL Boolean expression. The built-in FIELD_TOUCHED( ), GET_FLDBUF( ), and INFIELD( ) operators can take eld names (as described in Field Clause on page 3-86) as operands. See Chapter 5, Built-In Functions and Operators, for the syntax of these eld operators. The identier of a BYTE or TEXT variable can be the operand of the IS NULL and IS NOT NULL Boolean operators.
If the variable is a member of a record, qualify it with the record name prex, separated by a period ( . ) as the record membership operator. Variables of the BYTE or TEXT data types cannot appear in expressions, except as operands of the IS NULL or IS NOT NULL operators or (for TEXT variables only) the WORDWRAP operator. These operators are described in Chapter 5.
,
4GL Expression p. 3-49
Element function
Description is the name of a function. The parentheses are required, regardless of whether the function takes any arguments.
The function can be a programmer-dened or built-in function, provided that it returns a single value of a data type that is valid in the expression. (Function calls as arguments can return multiple values.)
3-58
For information about this statement, see FUNCTION on page 4-140, and see Chapter 5 for more information about declaring, dening, and invoking 4GL functions.
Expressions as Operands
Two expressions cannot appear consecutively without some separator, but you can nest expressions within expressions. In any context, however, the complexity of a 4GL expression is restricted. If an error message indicates that an expression is too complex, you should substitute two or more simpler expressions that 4GL can evaluate, and then combine these values. If an expression returns a different data type from what 4GL expects in the context, 4GL attempts data type conversion, as described in Summary of Compatible 4GL Data Types on page 3-46.
Boolean Expressions
Boolean Expressions
In 4GL, a Boolean expression is one that returns either TRUE (dened as 1) or FALSE (dened as 0) or (in some contexts) null. The syntax of Boolean expressions in 4GL statements is not identical to that of Boolean conditions in SQL statements. Boolean expressions of 4GL have the following syntax.
Boolean Expression
AND OR 4GL Expression p. 3-49 Boolean Comparison Function Call p. 3-58 TRUE
NOT
FALSE
3-60
Boolean Expressions
The logical operators AND, OR, and NOT combine one or more Boolean values into a single Boolean expression. Boolean comparisons can test operands and return Boolean values:
Relational comparisons test for equality or inequality. The IS NULL operator tests for null values. The MATCHES or LIKE operators compare character strings. The BETWEENAND operator compares a value to a range. The IN( ) operator tests a value for set membership.
Boolean Expressions
Character string representing a non-zero number Non-zero INTERVAL Any DATE or DATETIME value A TRUE value returned by a Boolean function like INFIELD( ) The built-in integer constant TRUE
If an expression that returns NULL is the operand of the IS NULL operator, the value of the Boolean expression is TRUE. If the value is NULL and the expression does not appear in any of the following contexts:
The NULL Test (page 5-37) Boolean Comparisons (page 5-34) Any conditional statement of 4GL (IF, CASE, WHILE)
Boolean expressions in CASE, IF, or WHILE statements return FALSE if any element of the comparison is NULL, except for operands of the IS NULL and the IS NOT NULL operator. See Boolean Operators on page 5-33 for more information about individual Boolean operators and Boolean expressions. If you include a Boolean expression in a context where 4GL expects a number, the expression is evaluated, and is then converted to an integer by the rules: TRUE = 1 and FALSE = 0.
3-62
Integer Expressions
Integer Expressions
An integer expression returns a whole number. It has the following syntax.
Integer Expression
+ -
Literal Integer p. 3-65 Function Call p. 3-58 Named Value p. 3-57 Boolean Expression p. 3-60
+ * /
MOD
**
Here any function call or named value must return an integer. Logical restrictions on using DATE values as integer expressions are discussed in Arithmetic Operations on Time Values on page 3-83. Integer expressions can be components of expressions of every other type. Like Boolean expressions, integer expressions are a logical subset of number expressions, but they are separately described here because some 4GL operators, statements, form specications, operators, and built-in functions are restricted to integer values, or to positive integers.
Integer Expressions
All arithmetic calculations are performed after converting both operands to DECIMAL values (but MOD operands are rst converted to INTEGER). If an expression has several operators of the same precedence, 4GL processes them from left to right. For the complete precedence scale for 4GL operators, see Figure 3-2 on page 3-54. If any operand of an arithmetic expression is a NULL value, the entire expression returns NULL. An integer expression specifying an array element or the right-hand MOD operand cannot include exponentiation (**) or modulus (MOD) operators, and cannot be zero. The right-hand integer expression operand of the exponentiation operator (**) cannot be negative. You cannot use mod as a 4GL identier. If both operands of the division operator ( / ) have INT or SMALLINT data types, 4GL discards any fractional portion of the quotient. An error occurs if the right-hand operand of the division operator evaluates to zero. With some restrictions, 4GL also supports these binary arithmetic operators in number expressions (as described in Number Expressions on page 3-66) and in some time expressions (as described in Time Expressions on page 3-72). Differences between two DATE values are integer expressions. To convert these to type INTERVAL, apply the UNITS DAY operator explicitly.
3-64
Integer Expressions
As noted earlier in this chapter, if you include a Boolean expression in a context where 4GL expects a number, the expression is evaluated, and is then converted to an integer by the rules: TRUE = 1 and FALSE = 0. An error results if you attempt to divide by zero.
Literal Integers
You must write literal integers in base-10 notation, without embedded blank spaces or commas, and without a decimal point.
Literal Integer
+
-
digit
Element digit
GLS
This release of 4GL does not support non-ASCII digits in number expressions, such as the Hindi numbers that some Middle-Eastern locales recognize.
Number Expressions
You can precede the integer with unary minus or plus signs:
15 -12 13938 +4
Number Expressions
A number expression is a specication that evaluates to a real number.
Number Expression Literal Number p. 3-67 Named Value p. 3-57 Function Call p. 3-58 Boolean Expression p. 3-60
+ -
+ * /
MOD Integer Expression p. 3-63
**
Here the function call or named value must return a real number of data type
DECIMAL, FLOAT, INTEGER, MONEY, SMALLFLOAT, or SMALLINT.
If any operand of an arithmetic operator in a number expression is a null value, 4GL evaluates the entire expression as a NULL value. The range of values in a number expression is that of the receiving data type.
Arithmetic Operators
The sections Binary Arithmetic Operators on page 3-64 and Unary Arithmetic Operators on page 3-65 apply to number expressions. 4GL converts any modulus (MOD) operand or right-hand operand of the exponentiation operator (**) to INTEGER before conversion to DECIMAL for evaluation; this feature has the effect of discarding any fractional part of the operands. If both operands are INTEGER, SMALLINT, or DATE data types, the result of any arithmetic operation (including division) is a whole number. If either operand is of data type DECIMAL, FLOAT, MONEY, or SMALLFLOAT, the returned value may include a fractional part, except in MOD operations.
3-66 IBM Informix 4GL Reference Manual
Number Expressions
Literal Numbers
A literal number is the base-10 representation of a real number, written as an integer, as a xed-point decimal number, or in exponential notation.
Literal Number + digit
. .
Element digit Description
e digit E
+
digit
This cannot include a comma ( , ) or blank space (ASCII 32). The unary plus or a minus sign can precede a literal number, mantissa, or exponent.
GLS
This release of 4GL does not support non-ASCII digits in literal numbers, such as the Hindi numbers that some Middle-Eastern locales recognize. There are three kinds of literal numbers:
s
Integer literals can exactly represent INTEGER and SMALLINT values. Literal integers have no decimal points, as in this example:
10 -27 25567
Fixed-point decimal literals can exactly represent DECIMAL(p,s) and MONEY values. These can include a decimal point:
123.456.00123456 -123456.0
Floating-point literals can exactly represent FLOAT, SMALLFLOAT, and DECIMAL(p) values that contain a decimal point or exponential notation, or both. These are examples of oating-point literals:
123.456e4 -1.23456e2 -123456.0e-3
When you use a literal number to represent a MONEY value, do not precede it with a currency symbol. Currency symbols are displayed by 4GL when MONEY values appear in a form or in a report, using whatever the DBMONEY or DBFORMAT environment variable species, or else the default symbol, which in the default (U.S. English locale) is the dollar sign ( $ ).
Data Types and Expressions 3-67
Number Expressions
GLS
In other locales, DBMONEY or DBFORMAT can specify number and currency display and data entry formats to conform with local cultural conventions.
4GL automatically attempts data type conversion when a literal number is in
a different format from the expected data type. If you include a character value in a context that requires a number expression, 4GL attempts to convert the string to a number. (For more information, see Summary of Compatible 4GL Data Types on page 3-46.) You may get unexpected results, however, if a literal number in a 4GL Boolean expression is not in a format that can exactly represent the data type of another value with which it is compared by a relational operator. Because of rounding errors, for example, relational operators generally cannot return TRUE if one operand returns a FLOAT value and the other an INTEGER. Similarly, you will get unpredictable (but probably useless) results if you use literal binary, hexadecimal, or other numbers that are not base-10 where 4GL expects a number expression. You must convert such numbers to a base-10 format before you can use them in a number expression.
3-68
Character Expressions
Character Expressions
A character expression is a specication that evaluates to a character string.
Character Expression character Function Call p. 3-58 Named Value p. 3-57
"
"
CLIPPED USING
] ,
Integer Expression p. 3-63
Element character
Description is one or more characters enclosed between two single ( ' ) or double ( " ) quotation marks. (This is sometimes called a character string, a quoted string, or a string literal.) is a formatting mask to specify how 4GL displays the returned character value. For details, see USING on page 5-123.
format string
Here the function call or named value returns a CHAR or VARCHAR value. No variable in a character expression can be of the TEXT data type, except in a NULL test (as described in The NULL Test on page 5-37), or as a WORDWRAP operand in a PRINT statement of a 4GL report. As in any 4GL statement or expression, you cannot reference a named value outside its scope of reference. (See Scope of Reference of 4GL Identiers on page 2-17.) If a character expression includes a 4GL variable or function whose value is neither a CHAR nor VARCHAR data type, 4GL attempts to convert the value to a character string. For example, the following program fragment stores the character string "FAX32" in the CHAR variable K:
VARIABLE I INTEGER, J, K CHAR(5) LET I = 4*8 LET J = "FAX" LET K = J CLIPPED,I
Character Expressions
The maximum length of a string value is the same as for the declared data type: up to 32,767 bytes for CHAR values, and up to 255 bytes for VARCHAR. If character expressions are operands of a relational operator, 4GL evaluates both character expressions, and then compares the returned values according to their position within the collating sequence of the locale. For more information, see Relational Operators on page 5-35.
String Operators
You can use the USING keyword, followed by a format string, to impose a specic format on the character string to which an expression evaluates, or upon any components of a concatenated character expression. (4GL forms and reports support additional features for formatting character values.) To discard trailing blanks from a character value, apply the CLIPPED operator to the expression, or to any components of a concatenated character expression. For more information about handling blank characters in character values, see the sections of Chapter 5 that describe the WORDWRAP eld attribute in forms and the WORDWRAP operator in 4GL reports, and see The WORDWRAP Operator on page 7-65. You can insert blanks in DISPLAY or PRINT statements by using the SPACE or COLUMN operators; these are described in Chapter 5. The keyword SPACES is a synonym for SPACE.
3-70 IBM Informix 4GL Reference Manual
Character Expressions
You can use the ASCII operator in DISPLAY or PRINT statements. This takes an integer expression as its operand, and returns a single-character string, corresponding to the specied ASCII character. See Chapter 5 for details.
Non-Printable Characters
In the default (U.S. English) locale, 4GL regards the following as the printable ASCII characters:
s s s s
TAB (= CONTROL-I) NEWLINE (= CONTROL-J) FORMFEED (= CONTROL-L) ASCII 32 (= blank) through ASCII 126 (= ~)
For information about the ASCII characters and their numeric codes, see Appendix G, Reserved Words. Any other characters are non-printable. Character strings that include one or more non-printable characters (for example, packed elds) can be operands or returned values of character expressions. They can be stored in 4GL variables or in database columns of the CHAR, VARCHAR, and TEXT data types. You should be aware, however, that many 4GL features for manipulating character strings were designed for printable characters only. If you create 4GL applications that use character expressions, character variables, or character columns to manipulate non-printable characters, you may encounter unexpected results. The following are examples of problems that you risk when CHAR, TEXT, and VARCHAR values include non-printable characters.
s
Behavior of I/O and formatting features like the WORDWRAP attribute or the DISPLAY or PRINT statements is designed and documented for printable characters only. It may be difficult to describe or to predict the effects of data with non-printable characters with these I/O features, but the users of your application are unlikely to enjoy the results. Strings with non-printable characters can have unpredictable results when output to I/O devices. For example, some sequences of nonprintable characters can cause terminals to position the cursor in the wrong place, clear the display, modify terminal attributes, or otherwise make the screen unreadable.
Data Types and Expressions 3-71
Time Expressions
For another example, CONTROL-D (= ASCII 4) and CONTROL-Z (= ASCII 26) in output from a report can be interpreted as logical endof-le, causing the report to stop printing prematurely. If you store a zero byte (ASCII 0) in a CHAR or VARCHAR variable or column, it might be treated as a string terminator by some operators, but as data by others, and this behavior might vary between the Rapid Development System and the C Compiler implementation of 4GL, or even between database servers. The workaround is to not use the ASCII 0 character within CHAR or VARCHAR data strings.
If you encounter these or related difficulties in processing non-printable characters, you might consider storing such values as BYTE data types.
GLS
character set that is different from that of the database communicate with the database. DBAPICODE species the character-mapping le between the character set of the peripheral device and the character set of the database. For more information about nondefault locales, see Appendix E.
Time Expressions
A time expression is a specication that 4GL can evaluate as a DATE, DATETIME, or INTERVAL value.
Time Expression INTERVAL Expression p. 3-74 DATETIME Expression p. 3-74 DATE Expression p. 3-74
3-72
Time Expressions
As the diagram suggests, the DATE data type is a logical subset of DATETIME. 4GL rules for arithmetic, however, are not identical for DATE and DATETIME operands, and the internal storage formats of DATE and DATETIME values are completely different. (For more information, see Arithmetic Operations on Time Values on page 3-83.) Formatting features, such as USING (described in Chapter 5) and the FORMAT and PICTURE attributes (described in Chapter 6, Screen Forms), also treat DATETIME and DATE values differently or support only DATE. These three data types are logically related, because they express values in units of time. But unlike the number and character data types that were described earlier in this chapter, for which 4GL supports automatic data type conversion (aside from restrictions based on truncation, overow, or underow), conversion among time data types is more limited. In contexts where a time expression is required, DATETIME or DATE values can sometimes be substituted for one another. INTERVAL values, however, which represent one-dimensional spans of time, cannot be converted to DATETIME or DATE values, which represent zero-dimensional points in time. In addition, if the declared precision of an INTERVAL value includes years or months, automatic conversion to an INTERVAL having smaller time units (like days, hours, minutes, or seconds) is not available. See also Summary of Compatible 4GL Data Types on page 3-46.
Time Expressions
Each of the three types of time expressions has its own syntax.
DATE Expression
"
Function Call p. 3-58
"
USING f Character Expression p. 3-69
TODAY
DATETIME Expression
"
"
DATETIME Literal p. 3-78
Function Call p. 3-58 Named Value p. 3-57 CURRENT EXTEND ( DATETIME Expression DATE Expression DATETIME Qualier p. 3-76
) ,
DATETIME Qualier p. 3-76
INTERVAL Expression
+ -
"
"
INTERVAL Literal p. 3-82 Named Value p. 3-57
UNITS keyword
3-74
Time Expressions
Here the keyword can be YEAR, MONTH, DAY, HOUR, MINUTE, SECOND, or FRACTION. The function call or named value must return a single value of the corresponding data type. Other operators besides those listed here can also appear in time expressions. Chapter 5 describes built-in operators like UNITS. Sections that follow show the syntax of component segments of DATE, DATETIME, and INTERVAL expressions.
Numeric Date
A numeric date represents a DATE value as a quoted string of digits and optional separator symbols. For the default locale, it has this format.
Numeric Date
"
mo
dd separator dd separator
yy yyyy
"
Description is the number of the day of the month, from 1 to 31. is a number from 1 to 12, representing the month. is any character that is not a digit. is an integer from 1 to 99, abbreviating the year. If only a single digit is supplied, 4GL automatically prexes it with a leading zero. is an integer from 1 to 9999, representing the year.
The digits must represent a valid calendar date. The default locale supports 6 digits (moddyy) or 8 digits (moddyyyy), with blank, slash ( / ), hyphen ( - ), no symbol, or any character that is not a digit as separator. Here mo, dd, and yyyy have the same meanings as in DATETIME Literal on page 3-78. The DBDATE environment variable can change the order of time units and can specify other separators. Like the USING operator or the FORMAT eld attribute, DBDATE can also specify how 4GL displays DATE values.
GLS
In some East-Asian locales, the GL_DATE environment variable can specify Japanese or Taiwanese eras for the entry and display of DATE values. (In any locale, GL_DATE can specify formats beyond what DBDATE can specify.)
Time Expressions
The DBCENTURY environment variable, or CENTURY attribute, determines how to expand abbreviated year values in DATE (or DATETIME) elds of 4GL forms. These features can also expand a two-digit year in a PROMPT statement. If you omit the quotation marks where a DATE value is expected, 4GL attempts to evaluate your specication as a literal integer or as an integer expression specifying a count of days since December 31, 1899. If slash ( / ) is the separator, the quotient of month and day is divided by the year value, producing a value that usually rounds to zero, or December 31, 1899. This result may not be useful, if the logical context requires a more recent date.
DATETIME Qualier
The DATETIME qualier species the precision and scale of a DATETIME value. It has the same syntax as the qualiers of DATETIME database columns.
DATETIME Qualier YEAR MONTH DAY HOUR MINUTE SECOND FRACTION TO YEAR TO MONTH TO DAY TO HOUR TO MINUTE TO SECOND TO FRACTION (3)
( scale )
Element scale Description is an integer (1 scale 5), enclosed between parentheses.
3-76
Time Expressions
Specify the largest time unit in the DATETIME value as the rst keyword. After the TO, specify the smallest time unit as the last keyword. These time units can be recorded in the numeric DATETIME value.
YEAR MONTH DAY HOUR MINUTE SECOND FRACTION
is a year; in numeric values, this can range from 1 to 9999. is a month, ranging from 1 to 12. is a day, ranging from 1 to 31, as appropriate to its month. is an hour, ranging from 0 (midnight) to 23. is a minute, ranging from 0 to 59. is a second, ranging from 0 to 59. is a fraction of a second, with up to 5 decimal places.
Unlike INTERVAL qualiers, DATETIME qualiers cannot specify nondefault precision (except for FRACTION when it is the smallest unit in the qualier). Here are some examples of DATETIME qualiers:
YEAR TO MINUTE DAY TO FRACTION(4) MONTH TO MONTH MONTH TO DAY
An error results if the rst keyword represents a smaller time unit than the last, or if you use the plural form of a keyword (such as MINUTES).
Time Expressions
DATETIME Literal
A DATETIME literal is the representation of a DATETIME value as the numeric date and time, or a portion thereof, followed by a DATETIME qualier.
DATETIME Literal DATETIME
mo
dd space hh
:
mi
:
ss
.
fffff
Description is the number of the day of the month, from 1 to 31. is the fraction of a second, up to 5 digits, as set by the precision specied for the FRACTION time units in the DATETIME qualier. is the hour (from a 24-hour clock), from 0 (midnight) to 23. is the minute of the hour, from 0 to 59. is a number from 1 to 12, representing the month. is a blank space (ASCII 32), entered by pressing SPACEBAR. is the second of the minute, from 0 to 59. is a number from 1 to 9999, representing the year. If it has fewer than 3 digits, 4GL expands the year value to 4 digits (according to the DBCENTURY setting, unless the CENTURY attribute is specied).
3-78
Time Expressions
An error results if you omit any required separator or include values for units outside the range specied by the qualier. Here are some examples:
DATETIME (99-3-6) YEAR TO DAY DATETIME (09:55:30.825) HOUR TO FRACTION DATETIME (01-5) YEAR TO MONTH
Here is an example of a DATETIME literal used in an arithmetic expression as an operand of the EXTEND operator:
EXTEND (DATETIME (2000-8-1) YEAR TO DAY, YEAR TO MINUTE) - INTERVAL (720) MINUTE (3) TO MINUTE
The DBCENTURY environment variable setting determines how single-digit and two-digit year specications in DATETIME elds of 4GL forms are expanded. For more information, see Appendix D, Environment Variables. The CENTURY attribute of 4GL forms can specify the same algorithms as DBCENTURY for expanding abbreviated year values. Unlike DBCENTURY , however, which species a single default algorithm for the entire application, CENTURY species the expansion rule for a single eld. If the two settings are different, the CENTURY setting takes precedence (within its eld) over the DBCENTURY setting. For more information, see DBCENTURY on page D-15 and CENTURY on page 6-35. The PROMPT statement also supports a CENTURY attribute for DATETIME (or DATE) values that the user enters with the year abbreviated.
GLS
The GL_DATETIME environment variable can specify display and data entry formats for DATETIME values to conform with local cultural conventions, such as Japanese or Taiwanese eras for year values in some East-Asian locales.
Time Expressions
INTERVAL Qualier
The INTERVAL qualier species the precision and scale of an INTERVAL value. It has the same syntax in 4GL as for INTERVAL database columns.
INTERVAL Qualier
DAY
TO DAY
HOUR
TO HOUR
MINUTE
TO MINUTE
SECOND
TO SECOND
FRACTION
TO FRACTION
(3) ( scale )
(4) (precision)
TO YEAR
MONTH
(2) (precision)
TO MONTH
Description is the number of decimal digits to record fractions of a second in a span of time. The default is 3 digits; the maximum is 5. is the number of digits in the largest time units that the interval can include. The maximum number of digits is 9; the default is 2 (except for the number of years, whose default precision is 4).
Any intermediate time units between the rst and last keywords that you specify in an INTERVAL qualier have the default precision of 2 digits.
3-80
Time Expressions
If the INTERVAL value can include more than one different time unit, specify the largest time unit in the INTERVAL as the rst keyword. After the TO, specify the smallest time unit as the last keyword. If the rst time unit keyword is YEAR or MONTH, the last cannot be smaller than MONTH. The following examples of an INTERVAL qualier are both YEAR TO MONTH. The rst example can record a span of up to 999 years, because 3 is the precision of the YEAR units. The second example uses the default precision for the YEAR units; it can record a span of up to 9999 years and 11 months.
YEAR (3) TO MONTH YEAR TO MONTH
When you intend for a value to contain only one kind of time unit, the rst and last keywords in the qualier are the same. For example, an interval of whole years that is qualied as YEAR TO YEAR can record a span of up to 9999 years, the default precision. Similarly, the qualier YEAR (4) TO YEAR can record a span of up to 9,999 years. The following examples show several forms of INTERVAL qualiers:
YEAR(5) TO MONTH DAY (5) TO FRACTION(2) DAY TO DAY FRACTION TO FRACTION (4)
The option to specify a nondefault precision or y-precision (as distinct from the scale) is a feature that INTERVAL variables do not share with DATETIME variables. An error results if you attempt to do this when you declare a DATETIME variable, specify DATETIME literal, or call the EXTEND operator. An error also results if the rst keyword represents a smaller time unit than the last, or if you use the plural form of a keyword (such as MONTHS).
Time Expressions
INTERVAL Literal
An INTERVAL literal represents a span of time as a numeric representation of its chronological units, followed by an INTERVAL qualier.
INTERVAL Literal INTERVAL
+ -
dd space hh
:
mi
:
ss
.
fffff
+ -
yyyy
mo
Description is the number of days. is the fraction of a second, up to 5 digits, depending on the precision of the fractional portion in the INTERVAL qualier. is the number of hours. is the number of minutes. is the number of months, in 2 digits. is a blank space (ASCII 32), entered by pressing SPACEBAR. is the number of seconds. is the number of years.
Time Expressions
For all time units except years and fractions of a second, the maximum number of digits allowed is two, unless this is the rst time unit, and the precision is specied differently by the INTERVAL qualier. (For years, the default maximum number of digits is four, unless some other precision is specied by the INTERVAL qualier. Neither the numeric values nor the qualier can combine units of time that are smaller than month with month or year time units. An error results if an INTERVAL literal omits any required eld separator, or includes values for units outside the range specied by the eld qualiers. Some examples of INTERVAL literal values follow:
INTERVAL (3-6) YEAR TO MONTH INTERVAL (09:55:30.825) HOUR TO FRACTION INTERVAL (40-5) DAY TO HOUR
+ +
All the other binary arithmetic operators (listed in Arithmetic Operators on page 3-66) also accept DATE operands, equivalent to the count of days since December 31, 1899, but the values returned (except from a DATE expression as the left-hand MOD operand) are meaningless in most applications.
DATE and DATETIME values have no true zero point; they lie on interval scales. Such scales can logically support addition and subtraction, as well as relational operators (as described in Relational Operators and Time Values on page 3-85), but multiplication, division, and exponentiation are undened. Data Types and Expressions 3-83
Time Expressions
The difference between two DATE values is an INTEGER value, representing the positive or negative number of days between the two calendar dates. You must explicitly apply the UNITS DAY operator to the difference between DATE values if you wish to store the result as an INTERVAL value. This is the syntax for arithmetic expressions that return a DATETIME value.
DATETIME Expression p. 3-74 DATE Expression p. 3-74 INTERVAL Expression p. 3-74
Do not write expressions that specify the sum ( + ) of two DATE or DATETIME values, or a difference ( - ) whose second operand is a DATE or DATETIME value, and whose rst operand is an INTERVAL value. This is the syntax for arithmetic expressions that return an INTERVAL value.
INTERVAL Expression p. 3-74
) + * / (
INTERVAL Expression p. 3-74 INTERVAL Expression p. 3-74 Number Expression p. 3-66 DATETIME Expression p. 3-74 DATE Expression p. 3-74
The difference between two DATETIME values (or a DATETIME and a DATE value, but not two DATE values) is an INTERVAL value.
3-84
Time Expressions
An expression cannot combine an INTERVAL value of precision in the range YEAR TO MONTH with another of precision in the DAY TO FRACTION range. Similarly, you cannot combine an INTERVAL value with a DATETIME or DATE value that has different qualiers. You must use EXTEND to change the DATE or DATETIME qualier to match that of the INTERVAL value. If the rst operand of an arithmetic expression includes the UNITS operator (page 5-119), you must enclose that operand in parentheses. If any component of a time expression is a NULL value, 4GL evaluates the entire expression as NULL.
DATETIME or INTERVAL operands in arithmetic cannot be quoted strings
representing numeric date and time (page 3-78) or numeric time interval (page 3-82) values. Use instead DATETIME or INTERVAL literals that also include appropriate DATETIME or INTERVAL qualiers. For example, the following LET statement that attempts to include an arithmetic expression
LET totalsec = "2002-01-01 00:00:00.000" - "1993-01-01 00:00:00.000"
in fact assigns a NULL value to the INTERVAL variable totalsec, rather than an interval of 9 years, because the two operands have no qualiers. Better is
LET totalsec = DATETIME (2002-01-01 00:00:00.000) YEAR TO FRACTION - DATETIME (1993-01-01 00:00:00.000) YEAR TO FRACTION
Arithmetic with the UNITS operator or INTERVAL operands can return invalid dates. For example, (5 UNITS MONTH) + DATETIME (1999-9 30) YEAR TO DAY produces an error (-1267: The result of a datetime computation is out of range,) because the returned value (2000-2 30) is not a valid calendar date.
Comparison x < y is TRUE when x is a briefer INTERVAL span than y, or when x is an earlier DATE or DATETIME value than y. Comparison x > y is TRUE when x is a longer INTERVAL span than y, or when x is a later DATE or DATETIME value than y. You cannot mix INTERVAL with DATE or DATETIME operands; but you can compare DATE and DATETIME values with each other.
Field Clause
Field Clause
The eld clause species one or more screen elds or screen records.
Field Clause
,
eld table screen record screen array
.
[ line ] [1]
FORMONLY
Description is a eld name, as declared in the ATTRIBUTES section of the form specication le. is an integer expression, enclosed within brackets, to specify a record within the screen array. Here 1 line size, where size is the array size that is declared in the INSTRUCTIONS section. If you omit the [line] specication, the default is the rst record. is the 4GL identier that you declared for a screen array in the INSTRUCTIONS section of the form specication le. is the 4GL identier that you declared for a screen record, or else a table reference (as the name of a default screen record). is the name, alias, or synonym of a database table or view.
Usage
A table reference cannot include table qualiers. You must declare an alias in the form specication le, as described in Table Aliases on page 6-24, for any table reference that requires a qualifying prex (such as database, server, or owner). Here the FORMONLY keyword acts like a table reference for elds that are not associated with a database column. For more information, see FORMONLY Fields on page 6-29.
3-86 IBM Informix 4GL Reference Manual
Usage
You can use an asterisk ( * ) to specify every eld in a screen record. Some contexts, such as the NEXT FIELD clause, support only a single-eld subset of this syntax. In these contexts, the THRU or THROUGH keyword, asterisk notation, and comma-separated list of eld names are not valid. You can specify one or more of the following in the eld clause:
s
A eld name without qualiers (eld) if this name is unique in the form A eld name, qualied by a table reference (FORMONLY.eld or table.eld) An individual member of a screen record (record.eld) An individual eld within a screen array (array [line].eld) A set of consecutive elds in a screen record (by the THRU notation) An entire screen record (record.*) The rst screen record in a screen array (array.* ) Any entire record within a screen array (array [line].*)
s s s s s s
Important: Some 4GL statements support only a subset of these features. For example, CONSTRUCT cannot specify a screen array line below the rst. Similarly, the FIELD_TOUCHED( ) operator in a CONSTRUCT or INPUT statement does not support the [line] notation to specify a screen record within a screen array. The eld list of a SCREEN RECORD specication in the INSTRUCTIONS section of a screen form can include the THRU or THROUGH keywords. (For details, see THRU or THROUGH Keywords and .* Notation on page 3-92.) Chapter 6 describes how to declare screen records and screen arrays. The following INPUT statement illustrates how to specify a eld name:
INPUT p_customer.fname, p_customer.lname FROM fname, lname
The following SCROLL statement moves the displayed values in all the elds of the s_orders screen array downwards by two lines. Any values are cleared from the rst two screen records; any values in the two screen records that are closest to the bottom of the 4GL screen or other 4GL windows are no longer visible:
SCROLL s_orders.* DOWN 2
References
The next SCROLL statement moves the displayed values in two of the elds of the s_orders screen array towards the top of the 4GL screen for every screen record. Any other elds of the s_orders array are not affected:
SCROLL s_orders.stock_num, s_orders.unit_descr UP 2
The following CLEAR statement clears one record of a screen array. In this example, the integer value of the idx variable determines which screen record is cleared:
CLEAR s_items[idx].*
References
CLEAR, CONSTRUCT, DISPLAY, INPUT, INPUT ARRAY, SCROLL, THRU
3-88
Table Qualiers
Table Qualiers
Statements that reference database tables, views, or synonyms (either alone or as qualiers of database column names) can include table qualiers.
Table Qualier
IDS database
owner.
: @server
"owner." 'owner.'
Description is the name of a database containing the table, view, or synonym. is the login name of the owner of the table, view, or synonym whose identier immediately follows the table qualier. is the name of the host system where database resides. Blank spaces are not valid after the @ symbol.
Usage
Table qualiers can appear in SQL and other 4GL statements and in table alias declarations in the TABLES section of form specications. You cannot, however, prex a table alias or a eld name with a table qualier. Except in table alias declarations within the TABLES section, you cannot include table qualiers anywhere in a form specication le.
Owner Naming
The qualier can specify the login name of the owner of the table. You must specify owner if table.column is not a unique identier within its database.
ANSI
In an ANSI-compliant database, you must qualify each table name with that of the owner of the table (owner.table). The only exception is that you can omit the owner prex for any tables that you own.
Table Qualiers
If the current database is ANSI-compliant, a runtime error results if you attempt to query a remote database that is not ANSI-compliant. For example, if Les owns table t1, you own table t2, and Sasha owns table t3, you could use the following statement to reference three columns in those tables:
VALIDATE var1, var2, var3 LIKE les.t1.c1, t2.c2, sasha.t3.c3
You can include the owner name in a database that is not ANSI-compliant. If owner is incorrect, however, 4GL generates an error. For more information, see the discussion of the Owner Name segment in the Informix Guide to SQL: Syntax.
Database References
The LIKE clause of 4GL statements like DEFINE, INITIALIZE, and VALIDATE can use this database: or database@server: notation in table qualiers to specify tables in a database other than the default database (as described in The Default Database at Compile Time on page 4-73). Without such qualiers, 4GL looks for the table in the default database. Even if the table qualier includes a database reference, however, the LIKE clause will fail unless you also include a DATABASE statement before the rst program block in the same module to specify a default database. The current database is the database specied by the most recently executed DATABASE statement in a MAIN or FUNCTION program block in the same module. 4GL programs can include SELECT statements that query a table in an Informix Dynamic Server database that is not the current database, but they cannot insert, update, or delete rows from any table that is not in the current database. If the current database is supported by Informix Dynamic Server, a table reference can also include @server to specify the name of another host system on which a table resides.
LOAD FROM "fyl" INSERT INTO dbas@hostile:woody.table42 SE
Only the databases stored in your current directory, or in a directory specied in your DBPATH environment variable, are recognized. Table qualiers cannot include references to an INFORMIX-SE database.
3-90
Table Qualiers
References
DATABASE, DEFINE, INITIALIZE, LOAD, VALIDATE, UNLOAD
. rst
last
. ,
array
Description is the name of an ARRAY variable or screen array, or the keyword FORMONLY. (But if array is not a variable, no loop is allowed.) is the name of some member variable or eld of record. is a variable or eld that was declared later than rst. is the name of a program record or screen record. is the name of the same record that qualied rst. is the name, alias, or synonym of a database table.
3-92
Usage
These notational devices in 4GL statements can simplify lists of structured sets of elds of a screen record or member variables of a program record, or can indicate all of the columns of a database table or view. The columns of a database table can be referenced by the asterisk notation, but you cannot use THRU or THROUGH to specify a partial list of columns. The notation record.member refers to an individual member variable of a 4GL program record, or a eld of a 4GL screen record. The record.* notation refers to the entire program record or screen record. Here record can be the name, alias, or synonym of a table or view, or the name of a program record or screen record, or the FORMONLY keyword. The THRU (or equivalently, THROUGH) notation can specify a partial list of the members of a program record or screen record. The notation record.rst THRU record.last refers to a consecutive subset of members of the record, from rst through last, where rst appears sooner than last in the data type declaration of a program record, or else in the ATTRIBUTES section of the form specication le (for screen records). These notations are a shorthand for writing out a full or partial list of set members with commas separating individual items in the list; this is the form to which 4GL expands these notations. Here are two examples:
INITIALIZE pr_rec.member4 THRU pr_rec.member8 TO NULL DISPLAY pr_rec.* TO sc_rec.*
This INITIALIZE statement sets to null the values of 4GL variables pr_rec.member4, pr_rec.member5, pr_rec.member6, pr_rec.member7, and pr_rec.member8. The DISPLAY statement lists the entire record pr_rec in the screen elds that make up the screen record sc_rec. The order of record members within the expanded list is the same order in which they were declared, from rst to last. For a screen record, this is the order of their eld descriptions in the ATTRIBUTES section. For example, suppose that the following lines appeared in the form specication le:
ATTRIBUTES ... f002=tab3.aa; f003=tab3.bb; f004=tab3.cc; f005=tab2.aa; f006=tab2.bb;
f007=tab1.aa; f008=tab1.bb; f009=tab1.cc; ... INSTRUCTIONS SCREEN RECORD sc_rec (tab3.cc THRU tab1.bb)
This implies the following order of eld names within screen record sc_rec:
tab3.cc tab2.aa tab2.bb tab1.aa tab1.bb
The order of elds in the screen record depends on the physical order of eld descriptions in the ATTRIBUTES section and on the SCREEN RECORD specication. The form compiler ignores the physical arrangement of elds in the screen layout, the order of table names in the TABLES section, the CONSTRAINED and UNCONSTRAINED keywords of the OPTIONS statement, and the lexicographic order of the table names or eld names when it processes the declaration of a screen record. For more information about default and nondefault screen records, see Screen Records on page 6-74. The THRU, THROUGH, or .* notation can appear in any list of columns, elds, or member variables, with the following exceptions:
s
You cannot use THRU or THROUGH to indicate a partial list of screen record members while the program displays or enters data in a form. You cannot use THRU, THROUGH, or .* in a quoted string to specify variables of a SELECT or INSERT clause in the PREPARE statement. You cannot use THRU, THROUGH, or the .* notation to reference a program record that contains an array member. (But these notations can specify all or part of a record that contains records as members, or a record that is an element of an array of records.) An exception to the general rule of .* expanding to a list of all column names occurs when .* appears in an UPDATE statement. Here any columns of the SERIAL data type are excluded from the expanded list. For example, the following UPDATE statement:
UPDATE table1 SET table1.* = program_rec.*
and so forth to the last column, but with any SERIAL column omitted.
3-94 IBM Informix 4GL Reference Manual
References
CLEAR, CONSTRUCT, DISPLAY, INPUT, INPUT ARRAY, REPORT, SCROLL
ATTRIBUTE Clause
ATTRIBUTE Clause
The ATTRIBUTE clause assigns visual attributes in some 4GL statements.
ATTRIBUTE Clause ATTRIBUTE ( BLACK BLUE CYAN GREEN MAGENTA RED WHITE YELLOW BOLD DIM INVISIBLE NORMAL
,
REVERSE BLINK UNDERLINE
Usage
Keywords listed at the left of this diagram specify color; those at the right specify intensity. The ATTRIBUTE clause can appear in the following 4GL statements:
CONSTRUCT DISPLAY ARRAY DISPLAY AT DISPLAY BY NAME
Besides these statements, both the OPEN WINDOW statement (OPEN WINDOW on page 4-280) and the OPTIONS statement (OPTIONS on page 4-291) can include ATTRIBUTE clauses that support additional keywords, as described in the sections about those statements in Chapter 4.
3-96
ATTRIBUTE Clause
The DISPLAY ARRAY, INPUT ARRAY, and PROMPT statements support additional attributes that are described in the next chapter. You must include at least one keyword in the ATTRIBUTE clause. An attribute clause in any statement except OPEN WINDOW or OPTIONS can specify zero or more of the BLINK, REVERSE, and UNDERLINE attributes, and zero or one of the other attributes. That is, all of the attributes except BLINK, REVERSE, and UNDERLINE are mutually exclusive.
If you specify the INVISIBLE attribute, 4GL does not display the data that the user enters in the eld. The data value, however, is stored in the input buffer, and is also available by using the get_dbuf( ) function.
ATTRIBUTE Clause
The following example demonstrates using the ATTRIBUTE clause in an ERROR statement. If the insert_items( ) function returns FALSE, 4GL rolls back the changes to the database and displays the error message:
IF NOT insert_items( ) THEN ROLLBACK WORK ERROR "Unable to insert items." ATTRIBUTE(RED, REVERSE, BLINK) RETURN END IF
If the terminal supports color, 4GL displays the error message in red, blinking, reverse video. If the terminal screen is monochrome, 4GL displays the error message in bold, blinking, reverse video. Within its scope (which may be while a eld, a form, or a 4GL window is displayed, or while a statement executes), a color attribute overrides any default colors specied for your terminal. (The next page describes the precedence of 4GL attributes.)
Precedence of Attributes
You can assign different attributes to the same eld. During execution of eld-related statements, however, 4GL uses these rules of precedence (descending) to resolve any conicts among attribute specications:
1. 2. 3.
The ATTRIBUTE clause of the current statement. The attributes from the eld descriptions in the ATTRIBUTES section of the current form le. (See Field Attribute Syntax on page 6-33.) The default attributes specied in the syscolatt table of any elds linked to database columns. To modify the syscolatt table, use the upscol utility. For information on using this utility, see Appendix B, INFORMIX-4GL Utility Programs. The ATTRIBUTE clause of the most recent OPTIONS statement. The ATTRIBUTE clause of the current form in the most recent DISPLAY FORM statement. The ATTRIBUTE clause of the current 4GL window in the most recent OPEN WINDOW statement. The default reserved line positions and the default foreground color on your terminal.
4. 5. 6. 7.
3-98
ATTRIBUTE Clause
You cannot override the attributes specied for the ERROR, MESSAGE, and PROMPT statements, so precedence rules do not affect these statements. Keywords of an ATTRIBUTES clause produce their documented effects only when the termcap or terminfo les and the physical terminals support the attribute. For more information on these les, see Appendix F, Modifying termcap and terminfo. On UNIX systems that use terminfo les rather than termcap, 4GL does not support attributes that specify colors, and the only valid keywords are REVERSE and UNDERLINE. Important: Some terminal entries in termcap or terminfo include the sg#1 or xmc#1 capabilities. If you are using one of these terminals and if the attributes specied for the INPUT ARRAY statement are different than the attributes of the current form or window, 4GL replaces the right and left square brackets that indicate the input elds with blank characters. 4GL uses the blank character as a transition character between the different attributes.
References
CONSTRUCT, DATABASE, DISPLAY, DISPLAY ARRAY, DISPLAY FORM, ERROR, INPUT, INPUT ARRAY, MESSAGE, OPEN WINDOW, OPTIONS, PROMPT
Chapter
INFORMIX-4GL Statements
4
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-9 4-9 4-9 4-13 4-15 4-16 4-17 4-19 4-20 4-21 4-22 4-23 4-24 4-25 4-28 4-28 4-29 4-29 4-29 4-30 4-31 4-32 4-34 4-37 4-41 4-43 4-44 4-52 4-53
In This Chapter .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
The 4GL Statement Set . . . . . Types of SQL Statements . . . Other Types of 4GL Statements .
Statement Descriptions . . . . . . . . . . . . . . . CALL . . . . . . . . . . . . . . . . . . . . Arguments . . . . . . . . . . . . . . . . . The RETURNING Clause . . . . . . . . . . . . Restrictions on Returned Character Strings . . . . . . Invoking a Function Without CALL . . . . . . . . CASE . . . . . . . . . . . . . . . . . . . . The WHEN Blocks . . . . . . . . . . . . . . The OTHERWISE Block . . . . . . . . . . . . The EXIT CASE Statement and the END CASE Keywords CLEAR . . . . . . . . . . . . . . . . . . . The CLEAR FORM Option . . . . . . . . . . . The CLEAR WINDOW Option . . . . . . . . . . The CLEAR WINDOW SCREEN Option. . . . . . . The CLEAR SCREEN Option. . . . . . . . . . . The CLEAR Field Option . . . . . . . . . . . . CLOSE FORM . . . . . . . . . . . . . . . . . CLOSE WINDOW. . . . . . . . . . . . . . . . CONSTRUCT . . . . . . . . . . . . . . . . . The CONSTRUCT Variable Clause. . . . . . . . . The ATTRIBUTE Clause . . . . . . . . . . . . The HELP Clause. . . . . . . . . . . . . . . The CONSTRUCT Input Control Blocks . . . . . . . The NEXT FIELD Clause . . . . . . . . . . . . The CONTINUE CONSTRUCT Statement . . . . . .
The EXIT CONSTRUCT Statement . . . . . . The END CONSTRUCT Keywords . . . . . . Using Built-In Functions and Operators . . . . Search Criteria for Query by Example . . . . . Positioning the Screen Cursor . . . . . . . Using WORDWRAP in CONSTRUCT. . . . . Editing During a CONSTRUCT Statement . . . Completing a Query . . . . . . . . . . . CONTINUE . . . . . . . . . . . . . . . CURRENT WINDOW . . . . . . . . . . . DATABASE . . . . . . . . . . . . . . . The Database Specication . . . . . . . . The Default Database at Compile Time . . . . The Current Database at Runtime . . . . . . The EXCLUSIVE Keyword . . . . . . . . Testing SQLCA.SQLAWARN . . . . . . . . Effects of the Default Database on Error Handling Additional Facts About Connections . . . . . DEFER . . . . . . . . . . . . . . . . . Interrupting Screen Interaction Statements . . . Interrupting SQL Statements . . . . . . . . DEFINE . . . . . . . . . . . . . . . . The Context of DEFINE Declarations . . . . . Indirect Typing . . . . . . . . . . . . Declaring the Names and Data Types of Variables Variables of Simple Data Types . . . . . . . Variables of Large Data Types . . . . . . . Variables of Structured Data Types . . . . . . DISPLAY . . . . . . . . . . . . . . . . Sending Output to the Line Mode Overlay . . . Sending Output to the Current 4GL Window . . Sending Output to a Screen Form . . . . . . The ATTRIBUTE Clause . . . . . . . . . Displaying Numeric and Monetary Values . . . Displaying Time Values. . . . . . . . . . DISPLAY ARRAY . . . . . . . . . . . . . The ATTRIBUTE Clause . . . . . . . . . The ON KEY Blocks . . . . . . . . . . . The EXIT DISPLAY Statement . . . . . . . The END DISPLAY Keywords . . . . . . . Using Built-In Functions and Operators . . . .
4-2 IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4-54 4-55 4-55 4-56 4-61 4-62 4-63 4-63 4-66 4-68 4-71 4-72 4-73 4-74 4-75 4-75 4-76 4-77 4-78 4-79 4-80 4-81 4-82 4-83 4-84 4-85 4-86 4-86 4-90 4-91 4-92 4-96 4-99 4-100 4-101 4-102 4-104 4-106 4-108 4-108 4-109
Scrolling During the DISPLAY ARRAY Statement Completing the DISPLAY ARRAY Statement . . DISPLAY FORM . . . . . . . . . . . . . Form Attributes . . . . . . . . . . . . Reserved Lines . . . . . . . . . . . . END . . . . . . . . . . . . . . . . . ERROR . . . . . . . . . . . . . . . . The Error Line . . . . . . . . . . . . The ATTRIBUTE Clause . . . . . . . . . System Error Messages . . . . . . . . . EXIT . . . . . . . . . . . . . . . . . Leaving a Control Structure . . . . . . . . Leaving a Function . . . . . . . . . . . Leaving a Report . . . . . . . . . . . Leaving the Program . . . . . . . . . . FINISH REPORT . . . . . . . . . . . . . FOR . . . . . . . . . . . . . . . . . The TO Clause . . . . . . . . . . . . The STEP Clause . . . . . . . . . . . The CONTINUE FOR Statement . . . . . . The EXIT FOR Statement . . . . . . . . . The END FOR Keywords . . . . . . . . Databases with Transactions . . . . . . . FOREACH . . . . . . . . . . . . . . . Cursor Names . . . . . . . . . . . . The USING Clause . . . . . . . . . . . The INTO Clause . . . . . . . . . . . The WITH REOPTIMIZATION Keywords. . . The FOREACH Statement Block . . . . . . The END FOREACH Keywords . . . . . . FUNCTION . . . . . . . . . . . . . . The Prototype of the Function . . . . . . . The FUNCTION Program Block . . . . . . Executable Statements. . . . . . . . . . Data Type Declarations . . . . . . . . . The Function as a Local Scope of Reference . . Returning Values to the Calling Routine . . . The END FUNCTION Keywords . . . . . . GLOBALS . . . . . . . . . . . . . . . Declaring and Exporting Global Variables . . . Importing Global Variables . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 4-111 . 4-111 . 4-113 . 4-113 . 4-114 . 4-116 . 4-118 . 4-118 . 4-119 . 4-120 . 4-121 . 4-121 . 4-122 . 4-122 . 4-123 . 4-125 . 4-128 . 4-128 . 4-129 . 4-129 . 4-130 . 4-130 . 4-130 . 4-131 . 4-133 . 4-134 . 4-134 . 4-135 . 4-136 . 4-138 . 4-140 . 4-141 . 4-142 . 4-142 . 4-143 . 4-143 . 4-144 . 4-144 . 4-145 . 4-146 . 4-147
GOTO . . . . . . . . . . . . . . IF. . . . . . . . . . . . . . . . INITIALIZE . . . . . . . . . . . . The LIKE Clause . . . . . . . . . INPUT . . . . . . . . . . . . . . The Binding Clause . . . . . . . . The ATTRIBUTE Clause . . . . . . The HELP Clause . . . . . . . . . The INPUT Control Block . . . . . . The CONTINUE INPUT Statement. . . The EXIT INPUT Statement . . . . . The END INPUT Keywords . . . . . Using Built-In Functions and Operators . Keyboard Interaction . . . . . . . Cursor Movement in Simple Fields. . . Multiple-Segment Fields . . . . . . Using Large Data Types . . . . . . Completing the INPUT Statement . . . INPUT ARRAY . . . . . . . . . . . The Binding Clause . . . . . . . . The ATTRIBUTE Clause . . . . . . The HELP Clause . . . . . . . . . The INPUT ARRAY Input Control Blocks The CONTINUE INPUT Statement. . . The EXIT INPUT Statement . . . . . The END INPUT Keywords . . . . . Using Built-In Functions and Operators . Using Large Data Types . . . . . . Keyboard Interaction . . . . . . . Completing the INPUT ARRAY Statement LABEL . . . . . . . . . . . . . . LET . . . . . . . . . . . . . . . LOAD . . . . . . . . . . . . . . The Input File . . . . . . . . . . The DELIMITER Clause . . . . . . The INSERT Clause . . . . . . . . Performance Issues with LOAD . . . . LOCATE . . . . . . . . . . . . . The List of Large Variables . . . . . The IN MEMORY Option . . . . . . The IN FILE Option . . . . . . . .
4-4 IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4-151 4-153 4-155 4-156 4-159 4-161 4-166 4-166 4-167 4-177 4-178 4-178 4-178 4-180 4-180 4-182 4-185 4-185 4-187 4-189 4-191 4-196 4-197 4-214 4-214 4-215 4-215 4-218 4-219 4-221 4-224 4-226 4-230 4-231 4-233 4-234 4-238 4-239 4-240 4-241 4-241
Passing Large Variables to Functions . . . . . Freeing the Storage Allocated to a Large Data Type MAIN . . . . . . . . . . . . . . . . . Variables Declared in the MAIN Statement . . . MENU . . . . . . . . . . . . . . . . . The MENU Control Blocks . . . . . . . . . Invisible Menu Options . . . . . . . . . . The CONTINUE MENU Statement . . . . . . The EXIT MENU Statement . . . . . . . . . The NEXT OPTION Clause . . . . . . . . . The HIDE OPTION and SHOW OPTION Keywords Nested MENU Statements . . . . . . . . . The END MENU Keywords. . . . . . . . . Identiers in the MENU Statement . . . . . . Choosing a Menu Option . . . . . . . . . Scrolling the Menu Options . . . . . . . . . Completing the MENU Statement . . . . . . COMMAND KEY Conicts . . . . . . . . . MESSAGE . . . . . . . . . . . . . . . . The Message Line . . . . . . . . . . . . The ATTRIBUTE Clause . . . . . . . . . . NEED. . . . . . . . . . . . . . . . . . OPEN FORM . . . . . . . . . . . . . . . Specifying a Filename . . . . . . . . . . . The Form Name . . . . . . . . . . . . . Displaying a Form in a 4GL Window . . . . . OPEN WINDOW. . . . . . . . . . . . . . The 4GL Window Stack . . . . . . . . . . The AT Clause . . . . . . . . . . . . . The WITH ROWS, COLUMNS Clause . . . . . The WITH FORM Clause. . . . . . . . . . The OPEN WINDOW ATTRIBUTE Clause . . . OPTIONS . . . . . . . . . . . . . . . . Features Controlled by OPTIONS Clauses . . . . Positioning Reserved Lines . . . . . . . . . Cursor Movement in Interactive Statements . . . The OPTIONS ATTRIBUTE Clause . . . . . . The HELP FILE Option . . . . . . . . . . Assigning Logical Keys . . . . . . . . . . Interrupting SQL Statements . . . . . . . . Setting Default Screen Modes . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 4-243 . 4-243 . 4-245 . 4-246 . 4-248 . 4-250 . 4-257 . 4-259 . 4-259 . 4-260 . 4-260 . 4-262 . 4-263 . 4-263 . 4-265 . 4-266 . 4-268 . 4-271 . 4-273 . 4-273 . 4-274 . 4-276 . 4-278 . 4-278 . 4-279 . 4-279 . 4-280 . 4-281 . 4-282 . 4-282 . 4-283 . 4-284 . 4-291 . 4-292 . 4-295 . 4-296 . 4-297 . 4-299 . 4-299 . 4-301 . 4-307
OUTPUT TO REPORT . . . . . . . . . . . PAUSE . . . . . . . . . . . . . . . . . PREPARE . . . . . . . . . . . . . . . . Statement Identier . . . . . . . . . . . Statement Text . . . . . . . . . . . . . Statements That Can or Must Be Prepared . . . Statements That Cannot Be Prepared . . . . . Using Parameters in Prepared Statements . . . Preparing Statements with SQL Identiers . . . Preparing Sequences of Multiple SQL Statements . Runtime Errors in Multistatement Texts . . . . Using Prepared Statements for Efciency . . . PRINT . . . . . . . . . . . . . . . . . PROMPT . . . . . . . . . . . . . . . . The PROMPT String . . . . . . . . . . . The Response Variable . . . . . . . . . . The FOR Clause . . . . . . . . . . . . The ATTRIBUTE Clauses . . . . . . . . . The HELP Clause . . . . . . . . . . . . The ON KEY Blocks . . . . . . . . . . . The END PROMPT Keywords . . . . . . . REPORT . . . . . . . . . . . . . . . . The Report Prototype . . . . . . . . . . The Report Program Block. . . . . . . . . Two-Pass Reports . . . . . . . . . . . . The Exit Report Statement . . . . . . . . . The END REPORT Keywords . . . . . . . RETURN . . . . . . . . . . . . . . . . The Data Types of Returned Values . . . . . RUN . . . . . . . . . . . . . . . . . Screen Display Modes . . . . . . . . . . The RETURNING Clause . . . . . . . . . The WITHOUT WAITING Clause . . . . . . SCROLL . . . . . . . . . . . . . . . . SKIP. . . . . . . . . . . . . . . . . . SLEEP . . . . . . . . . . . . . . . . . SQL . . . . . . . . . . . . . . . . . . START REPORT . . . . . . . . . . . . . The TO Clause . . . . . . . . . . . . . Dynamic Output Conguration . . . . . . .
4-6 IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
4-308 4-311 4-312 4-313 4-314 4-315 4-317 4-319 4-321 4-321 4-322 4-323 4-324 4-325 4-326 4-327 4-327 4-327 4-329 4-329 4-331 4-332 4-333 4-334 4-334 4-335 4-336 4-337 4-338 4-340 4-341 4-341 4-343 4-344 4-346 4-348 4-349 4-354 4-355 4-356
TERMINATE REPORT . . . . . . . . UNLOAD . . . . . . . . . . . . The Output File . . . . . . . . . The DELIMITER Clause . . . . . . Host Variables . . . . . . . . . The Backslash Escape Character . . . VALIDATE . . . . . . . . . . . . The LIKE Clause . . . . . . . . The syscolval Table . . . . . . . . WHENEVER . . . . . . . . . . . The Scope of the WHENEVER Statement The ERROR Condition . . . . . . The ANY ERROR Condition . . . . The NOT FOUND Condition . . . . The WARNING Condition . . . . . The GOTO Option . . . . . . . . The CALL Option . . . . . . . . The CONTINUE Option . . . . . . The STOP Option . . . . . . . . WHILE . . . . . . . . . . . . . The CONTINUE WHILE Statement . . The EXIT WHILE Statement . . . . The END WHILE Keywords . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . .
. 4-364 . 4-367 . 4-368 . 4-369 . 4-370 . 4-371 . 4-372 . 4-373 . 4-374 . 4-376 . 4-377 . 4-378 . 4-378 . 4-379 . 4-379 . 4-379 . 4-380 . 4-381 . 4-381 . 4-382 . 4-383 . 4-383 . 4-383
4-8
In This Chapter
This chapter describes the INFORMIX-4GL statements, classifying them by functional category and also providing alphabetized descriptions of the individual statements of 4GL that are not SQL statements.
SQL statements operate on tables and their columns in a database. 4GL statements operate on variables in memory.
Cursor manipulation statements Data denition statements Data manipulation statements Dynamic management statements Query optimization statements Data access statements Data integrity statements Stored procedure statements Client/server connection statements Optical statements
INFORMIX-4GL Statements 4-9
The SQL statements in each of these categories are listed in sections that follow. SQL statements that are not listed here are not available in 4GL. For syntax and usage information about SQL statements, see the Informix Guide to SQL: Syntax. To use the SQL statements identied by the SQL icon in a 4GL program, you must either put the statement in an SQL block, as described in SQL on page 4-349, or else prepare the statement, as described in PREPARE on page 4-312. You must also prepare (or delimit with SQLEND SQL) any other SQL statements that specify syntax that was not supported by Informix 4.1 database servers. SQL statements that include only Informix 4.1 syntax can be directly embedded or delimited with SQLEND SQL, but most SQL statements can also be prepared and can appear in SQL blocks.
4-10
ALTER FRAGMENT ALTER INDEX ALTER TABLE CLOSE DATABASE CREATE DATABASE
SQL
SQL SQL
SQL
SQL
SQL
CREATE TRIGGER
OUTPUT
SET RESIDENCY
SET SCHEDULE LEVEL UPDATE STATISTICS
SQL
SET PLOAD FILE SET TRANSACTION MODE START VIOLATIONS TABLE STOP VIOLATIONS TABLE WHENEVER
EXECUTE PROCEDURE
SQL
4-12
Optical statements are only valid on Informix database servers that support optical storage. No INFORMIX-SE database server, for example, supports these features.
Denition and declaration statements Storage manipulation statements Program ow control statements Compiler directives Screen interaction statements Report execution statements
4-14
Statement Descriptions
Most 4GL statements are not sensitive to whether INFORMIX-SE or Informix Dynamic Server supports the application. INFORMIX-SE cannot store values in BYTE, TEXT, or VARCHAR columns, but any 4GL program can declare variables of these data types.
Statement Descriptions
The following sections describe the 4GL statements that are not SQL statements, and certain SQL statements. Each description includes these elements:
s s s
The name and a terse summary of the effect of the 4GL statement A syntax diagram Notes on usage, typically arranged by syntax elements
If a description is longer than a few pages, a bulleted list identies the major topical headings and their page numbers. A list of related statements concludes most of these statement descriptions.
CALL
CALL
The CALL statement invokes a specied function.
CALL function
) , ,
RETURNING Receiving Variable p. 4-226
Element function
Usage
CALL can invoke the following types of functions from a 4GL application:
s s s
C language functions
It can also invoke ESQL/C functions. Programmer-dened 4GL functions are dened in FUNCTION statements. These functions can appear in the same source le as the MAIN statement, or they can be compiled in separate .4gl modules (individually, or with other function and report denitions) and linked later to the MAIN program block. When 4GL encounters a CALL statement at runtime, it locates the specied FUNCTION program block and executes its statements in sequence. If the function is not a built-in function, a link-time error occurs unless exactly one denition of that function exists in the modules that make up the program. The program block containing the CALL statement is called the calling routine. The RETURNING clause can specify the name of one or more variables that function returns to the calling routine. This variable (or list of variables) has the same syntax as a receiving variable in the LET statement.
4-16
)
4GL Expression p. 3-49
CALL
Tip: Unlike 4GL identiers, the names of C functions are case sensitive and must typically appear in lowercase letters within the function call. For more information, see Appendix C, Using C with INFORMIX-4GL. In this example, the CALL statement invokes the show_menu( ) function:
MAIN ... CALL show_menu() ... END MAIN FUNCTION show_menu() ... END FUNCTION
Chapter 5, Built-In Functions and Operators, provides more information about functions. The following sections describe these topics:
s s s s
Arguments on page 4-17 The RETURNING Clause on page 4-19 Restrictions on Returned Character Strings on page 4-20 Invoking a Function Without CALL on page 4-21
Arguments
The argument list after the function name species values for CALL to pass as actual arguments to the function. These actual arguments can be any 4GL expression (as described in Expressions of 4GL on page 3-49) if the returned data types are compatible with the corresponding formal arguments in the FUNCTION denition. Statements in the FUNCTION denition are executed with the values of actual arguments substituted for the corresponding formal arguments. (Parentheses are always required around the list of argument, even if the list is empty because the function accepts no arguments.)
CALL
For example, the following program fragment passes the current values of p_customer.fname and p_customer.lname to the print_name( ) function:
MAIN ... CALL print_name(p_customer.fname, p_customer.lname) ... END MAIN FUNCTION print_name(fname, lname) DEFINE fname, lname CHAR(15) ... END FUNCTION
Values in the argument list must correspond in number and position (within the list) to the formal arguments that were specied in the FUNCTION statement. Data types of values must be compatible, but need not be identical, to those of the formal arguments in the FUNCTION statement. An argument can be an expression that contains variables of simple data types, or simple members of records, or simple elements of arrays. An argument can also be a BYTE or TEXT variable. Results can be unpredictable if a variable that has not yet been assigned a value is used as an argument in a CALL statement.
4-18
CALL
This example shows how to pass a BYTE or TEXT argument to a 4GL function:
MAIN DEFINE resume TEXT ... LOCATE resume IN MEMORY CALL get_resume(resume) END MAIN FUNCTION get_resume(parm) DEFINE parm TEXT ... END FUNCTION
In this example, the LOCATE statement allocates memory for the TEXT variable, and places a pointer to this variable in resume. Any change to parm within the get_resume( ) function also changes the TEXT variable in MAIN.
Determine how many values function returns. In the CALL statement, specify that number of variables in the RETURNING clause. If you write the function denition, include expressions in a RETURN statement to specify values returned by the function. (For more information, see RETURN on page 4-337.)
When returning values to the CALL statement, keep the following considerations in mind:
s
The values in the RETURN statement of the FUNCTION denition must correspond in number and position to the variables specied in the RETURNING clause of the CALL statement. Data types of the RETURNING variables must be compatible with the RETURN values, but they need not be identical. (For more information, see Summary of Compatible 4GL Data Types on page 3-46.) It is an error to specify more variables in the RETURNING clause than the number of values in the RETURN statement of the FUNCTION denition. (If the RETURNING clause species fewer variables, any additional returned values are ignored by the calling routine.)
CALL
You can return simple or RECORD variables from a function. You cannot, however, return RECORD members of ARRAY, BYTE, and TEXT data types. The RETURNING clause passes information by value. Because variables of the BYTE and TEXT data types are passed by reference, they cannot be included in the RETURNING clause. (For more information, see Passing Arguments by Reference on page 4-18.)
Important: It is an error to specify a RETURNING clause in the CALL statement if the function does not return anything. It is not an error to omit the RETURNING clause when you invoke a function that returns values if no statement in the calling routine references the returned values. In the next example, the get_cust( ) function returns values of whole_price and ret_price to the CALL statement. 4GL then assigns the whole_price and ret_price variables to the wholesale and retail variables in the price record:
MAIN DEFINE price RECORD wholesale, retail MONEY END RECORD ... CALL get_cust() RETURNING price.* ... END MAIN FUNCTION get_cust() DEFINE whole_price, ret_price MONEY ... RETURN whole_price, ret_price END FUNCTION
4-20
CALL
This use of the concatenation operator is valid in calls to functions, regardless of whether the CALL statement or an expression invokes the function. Unlike in the LET statement, the comma and the concatenation operator are not interchangeable in the argument list of a function call. In this context, comma is the required separator and has no concatenation semantics.
References
DEFINE, FUNCTION, RETURN, WHENEVER
CASE
CASE
The CASE statement species statement blocks to be executed conditionally, depending on the value of an expression. Unlike IF statements, CASE does not restrict the logical ow of control to only two branches.
Case I: (single criterion)
CASE
WHEN
END CASE
WHEN
Element statement
Usage
The CASE statement is equivalent to a set of nested IF statements. You can specify two types of CASE statements:
s
If an expression follows the CASE keyword, you must specify INT, SMALLINT, DECIMAL, CHAR(1), or VARCHAR(1) expressions in the WHEN block. (The syntax diagram indicates a subset of general 4GL expressions because of these data type restrictions.) 4GL executes the statement block if both expressions return the same non-NULL value. If no expression follows the CASE keyword, the WHEN block must specify a Boolean expression; if this returns TRUE, the WHEN block is executed. (See Boolean Expressions on page 3-60.) This form of CASE typically executes more quickly than the other.
4-22
CASE
There is an implicit EXIT CASE statement at the end of each WHEN block of statements. An implicit or explicit EXIT CASE statement transfers program control to the statement that immediately follows the END CASE keywords.
Element statement
What data type can be returned by expression depends on what follows the
CASE keyword. If CASE (expression) precedes the rst WHEN block as a single criterion, an INTEGER, SMALLINT, DECIMAL, CHAR(1), or VARCHAR(1) expression must follow the WHEN keyword, returning a data type that is compatible with the (expression) term after CASE.
If a WHEN expression matches the value of CASE (expression), 4GL executes the statements in that WHEN block and exits from the CASE statement. In the following example, both customer_num and the WHEN expression values are of data type SMALLINT:
CASE (p_customer.customer_num) WHEN 101 ... WHEN 102 ... END CASE
CASE
If no (expression) term follows CASE, 4GL treats expression as a Boolean (returning TRUE or FALSE) in each of the WHEN blocks. If this Boolean expression returns TRUE (that is, neither zero nor NULL), 4GL executes the corresponding block of statements, as in the following CASE statement:
CASE WHEN total_price < 1000 ... WHEN total_price = 1000 ... WHEN total_price > 1000 ... END CASE
When more than one WHEN clause can satisfy your criteria, only the rst of these causes its statement block to be executed. In these cases, the lexical order of the WHEN clauses in effect prioritizes your logical criteria.
4GL does not execute the statement block if the expression in the WHEN block returns FALSE or NULL, or if CASE expression returns NULL. (The IF and WHILE statements and the WHERE clause of a COLOR attribute also treat any NULL value returned from a 4GL Boolean expression as FALSE.)
Element statement
4GL executes the OTHERWISE block only if it cannot execute any of the WHEN blocks. If you include the OTHERWISE block, it must follow the last WHEN
block.
4-24
CASE
In the next example, if neither 4GL Boolean expression in the WHEN blocks returns TRUE, 4GL invokes the retry( ) function:
WHILE question ... CASE WHEN answer MATCHES "[Yy]" CALL process() LET question = FALSE WHEN answer MATCHES "[Nn]" CALL abort() OTHERWISE CALL retry() END CASE END WHILE
An implied EXIT CASE statement follows the OTHERWISE block. Unless the OTHERWISE block contains a valid GOTO statement, program control passes to the statement that follows the END CASE statement. But the use of GOTO to leave a WHEN block, rather than an implicit or explicit EXIT CASE statement, can cause runtime error -4518, as described in the next section.
CASE
In the following example, print_option is a CHAR(1) variable that determines the destination of output from a REPORT program block:
CASE (print_option) WHEN "f" PROMPT " Enter file names for labels >" FOR file_name IF file_name IS NULL THEN LET file_name = "labels.out" END IF MESSAGE "Printing mailing labels to ", file_name CLIPPED," -- Please wait" START REPORT labels_report TO file_name WHEN "p" MESSAGE "Printing mailing labels -- Please wait" START REPORT labels_report TO PRINTER WHEN "s" START REPORT labels_report CLEAR SCREEN END CASE
Because WHEN blocks are logically disjunct, exactly one of the START REPORT statements is executed within the CASE statement in this example.
CASE
WHEN
END CASE
This is not valid because the expression that follows the WHEN keyword must return a value of data type INT, SMALLINT, DECIMAL, CHAR(1), or VARCHAR(1). Substituting a Boolean expression in this context tends to produce unexpected runtime results. Boolean expressions are valid only in Case II (multiple logical criteria).
4-26
CASE
For example, CASE statements with WHEN clauses of the following form produce a false result.
CASE Statement CASE variable WHEN A OR B CASE variable WHEN (variable = A OR variable = B) Translates to: if (variable == (A or B)) if (variable == (variable == A or variable == B))
To produce the intended result when the appropriate action depends on the value in the WHEN clause, omit the expression that immediately follows the CASE keyword. Use simplied logic, as in the following code, typically by associating each WHEN expression value with a function call:
CASE variable WHEN "A" ... WHEN "B" ...
References
FOR, IF, WHILE
CLEAR
CLEAR
The CLEAR statement can clear any of these portions of the screen display:
s s s s
The 4GL screen (excluding any open 4GL windows within it) Any specied 4GL window All of the elds in the current screen form A list of one or more specied elds in the current screen form
FORM WINDOW window SCREEN
CLEAR
,
Field Clause p. 3-86
Element window
Usage
The CLEAR statement clears the specied portion of the display. It does not change the value of any 4GL variable.
The CLEAR FORM option has no effect on other parts of the screen display.
4-28
CLEAR
If the window that you specify has a border, the CLEAR WINDOW statement does not erase the border. You can specify any 4GL window, including one that is not the current window, but the CLEAR WINDOW statement does not affect which 4GL window is the current 4GL window in the window stack.
Clears the 4GL screen, except for the area occupied by any open 4GL windows Leaves any information in the open 4GL windows untouched Does not change the current 4GL window setting
s s
As in several other 4GL statements, the keyword SCREEN here species the 4GL screen.
CLEAR
If you specify table.* (where table is a name or alias from the TABLE section of the form specication le), CLEAR clears all the elds associated with columns of that table. (See INSTRUCTIONS Section on page 6-74 for a description of screen records and screen arrays that the record.* notation can reference.) For example, the following program fragment clears the orders screen record and the rst four records of the s_items screen array:
FOREACH order_list INTO p_orders.* CLEAR s_orders FOR idx = 1 TO 4 CLEAR s_items[idx].* END FOR DISPLAY p_orders.* TO orders.* ... END FOREACH
If a screen form is in the current 4GL window, the following statement clears all the screen elds that are not associated with database columns:
CLEAR FORMONLY.*
Any elds that you associated with database columns in the ATTRIBUTES section of the form specication le are not affected by this statement.
References
CLOSE FORM, CLOSE WINDOW, CURRENT WINDOW, DISPLAY, DISPLAY ARRAY, INPUT, INPUT ARRAY, OPEN FORM, OPEN WINDOW, OPTIONS
4-30
CLOSE FORM
CLOSE FORM
The CLOSE FORM statement releases the memory required for a form.
CLOSE FORM form
Element form
Description is the name of the 4GL screen form to be cleared from memory.
Usage
When it executes the OPEN FORM statement, 4GL loads the compiled screen form into memory. The CLOSE FORM statement frees memory allocated to a form. For example, this program fragment opens and displays the o_cust form and then closes both the form and the 4GL window cust_w:
OPEN WINDOW cust_w AT 3,5 WITH 19 ROWS, 72 COLUMNS OPEN FORM o_cust FROM "custform" DISPLAY FORM o_cust ATTRIBUTE(MAGENTA) ... CLOSE FORM o_cust CLOSE WINDOW cust_w
If you open the form using the WITH FORM option of the OPEN WINDOW statement, you do not need to use CLOSE FORM before closing the 4GL window. In this case, CLOSE WINDOW closes both the form and the 4GL window, releasing the memory allocated to the form and to the 4GL window.
CLOSE FORM affects memory use only, not the logic of the 4GL program. After you use CLOSE FORM to release the memory allocated to a form, its name is
no longer associated with the form. If you subsequently try to redisplay the form, an error message results. If you execute a new OPEN FORM or OPEN WINDOW statement that species the same form name that an OPEN FORM or OPEN WINDOW statement referenced previously, 4GL automatically closes the previously opened form before opening the new form.
References
CLOSE WINDOW, DISPLAY FORM, OPEN FORM, OPEN WINDOW INFORMIX-4GL Statements 4-31
CLOSE WINDOW
CLOSE WINDOW
The CLOSE WINDOW statement closes a specied 4GL window.
CLOSE WINDOW window
Element window
Usage
The CLOSE WINDOW statement causes 4GL to take the following actions:
s
Clears the specied 4GL window from the 4GL screen and restores any underlying display Frees all resources used by the 4GL window and deletes it from the 4GL window stack If the OPEN WINDOW statement included the WITH FORM clause, closes both the form and the 4GL window
4GL maintains an ordered list of open 4GL windows, called the window stack. When you open a new 4GL window, it is added to the stack and becomes the
current window, occupying the top of the stack. Closing the current window makes the next 4GL window on the stack the new current window. If you close any other window, 4GL deletes it from the stack, leaving the current window unchanged. Closing a window has no effect on variables that were set while the window was open. The following program fragment opens and closes a 4GL window called stock_w:
OPEN WINDOW stock_w AT 7, 3 WITH 6 ROWS, 70 COLUMNS CLOSE WINDOW stock_w
You cannot specify CLOSE WINDOW SCREEN. If window is currently being used for input, CLOSE WINDOW generates a runtime error. For example, you cannot close the current 4GL window while a CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, or MENU statement is executing.
4-32
CLOSE WINDOW
References
CLEAR, CLOSE FORM, CURRENT WINDOW, OPEN WINDOW, OPTIONS
CONSTRUCT
CONSTRUCT
The CONSTRUCT statement stores in a character variable a 4GL Boolean expression that corresponds to query by example criteria that a user species. You can use this variable in the WHERE clause of a SELECT statement.
CONSTRUCT Variable Clause END CONSTRUCT
CONSTRUCT
HELP number CONSTRUCT Variable Clause BY NAME variable ON variable ON Column List p. 4-37
Description is a literal integer (as described in Literal Integers on page 3-65), specifying a help message number. is the identier of a CHAR or VARCHAR variable that stores a 4GL Boolean expression summarizing the user-entered search criteria.
Usage
The CONSTRUCT statement is designed to enable users to perform a query by example. Query by example enables a user to query a database by specifying values (or ranges of values) for screen elds that correspond to database columns. 4GL converts these values into a Boolean expression that species search criteria that can appear in the WHERE clause of a prepared SELECT statement.
4-34 IBM Informix 4GL Reference Manual
CONSTRUCT
The CONSTRUCT statement can also control the environment in which the user enters search criteria, and can restrict the values that the user enters. To use the CONSTRUCT statement, you must do the following:
s s s
Dene elds linked to database columns in a form specication le. Declare a character variable with the DEFINE statement. Open and display the screen form with either of the following:
OPEN FORM and DISPLAY FORM statements OPEN WINDOW statement with a WITH FORM clause
Use CONSTRUCT to store in the character variable a Boolean expression that is based on criteria that the user enters in the elds.
The CONSTRUCT statement activates the current form. This is the form most recently displayed or, if you are using more than one 4GL window, the form currently displayed in the current window. You can specify the current window by using the CURRENT WINDOW statement. When the CONSTRUCT statement completes execution, the form is deactivated. When it encounters the CONSTRUCT statement, 4GL takes the following actions at runtime:
1. 2. 3. 4.
Clears all the screen elds of the CONSTRUCT eld list Executes the statements in the BEFORE CONSTRUCT control block, if the CONSTRUCT statement includes that control block Moves the screen cursor to the rst screen eld in that list Waits for the user to enter some value as search criteria in the eld For elds where the user enters no value, any value in the corresponding database column satises the search criteria.
After the user presses the Accept key (typically ESCAPE), CONSTRUCT uses AND operators to combine eld values as search criteria in a Boolean expression, and stores this in the character variable. If no criteria were entered, the TRUE expression ' 1=1' is assigned to the character variable.
CONSTRUCT
By performing the following steps, you can use this variable in a WHERE clause to search the database for matching rows:
1.
Concatenate the variable that contains the Boolean expression with other strings to create a string representation of an SQL statement to be executed. The Boolean expression generated by the CONSTRUCT statement is typically used to create SELECT statements.
2. 3.
Use the PREPARE statement to create an executable SQL statement from the character string that was generated in the previous step. Execute the prepared statement in one of the following ways:
s
Use an SQL cursor with DECLARE and FOREACH statements (or else OPEN and FETCH statements) to execute a prepared SELECT statement that includes no INTO clause. Use the EXECUTE statement to execute an SQL statement other than SELECT, or to execute a SELECTINTO statement.
When the CONSTRUCT statement completes execution, the form is cleared. Environment variables that format data values, such as DBDATE, DBTIME, DBFORMAT, DBFLTMASK, and DBMONEY, have no effect on the contents of the Boolean expression. The following topics are described in this section:
s s s s s s s s s s s s
The CONSTRUCT Variable Clause on page 4-37 The ATTRIBUTE Clause on page 4-41 The HELP Clause on page 4-43 The CONSTRUCT Input Control Blocks on page 4-44 The NEXT FIELD Clause on page 4-52 The END CONSTRUCT Keywords on page 4-55 Using Built-In Functions and Operators on page 4-55 Search Criteria for Query by Example on page 4-56 Positioning the Screen Cursor on page 4-61 Using WORDWRAP in CONSTRUCT on page 4-62 Editing During a CONSTRUCT Statement on page 4-63 Completing a Query on page 4-63
4-36
CONSTRUCT
,
column
@ server
: :
owner .
table .
* *
,
eld table screen array screen record
. [1] [ line ] .
*
THRU Notation p. 3-92
Element column database eld line owner screen array screen record server table variable
Description is the unqualied identier of a database column in table. is the identier of the database in which the table resides. is the identier of a screen eld. is an integer expression, identifying a record in screen array. is the user name of the owner of the table containing the column. is the 4GL identier of a screen array in the current form. is the 4GL identier of a screen record or else a table reference (as the name of a default screen record). is the name of the host system where database resides. is the name, alias, or synonym of a database table or view. is the identier of a CHAR or VARCHAR variable.
CONSTRUCT
The CONSTRUCT variable clause temporarily binds the specied screen elds to database columns and species the database columns for which the user can enter search criteria. You can map the elds implicitly (with the BY NAME keywords) or explicitly (with the FROM keyword and eld list). With either method, each eld and corresponding column must be of the same or compatible data types. The order of elds in the FROM clause determines the default sequence in which the screen cursor moves from eld to eld in the form. Within a screen array, you can specify only one screen record. Here the eld list is a restricted subset of the eld clause that some 4GL screen interaction statements support (as described in Field Clause on page 3-86). In a eld list within the CONSTRUCT variable clause, a table reference cannot include table qualiers. You must declare an alias in the form specication le, as described in Table Aliases on page 6-24, for any table reference that requires a qualifying prex (such as database, server, or owner).
4GL constructs a character variable by associating each column name in the ON clause with search criteria that the user enters into the corresponding eld (as specied in the FROM clause, or implied by the BY NAME keywords). You can use the information stored in character variable in the WHERE clause of a prepared SELECT statement to retrieve rows from the database. To avoid
overow, declare the length of variable as several times the total length of all the elds, because the Boolean expression includes additional operators.
The user can enter search criteria in the elds named company, address1, address2, city, state, and zipcode. Because these elds have the same names as the columns specied after the ON keyword, the statement uses the BY NAME clause. If the eld names do not match the column names, you must use the FROM clause instead of the BY NAME clause.
4-38
CONSTRUCT
If the column names in a CONSTRUCT BY NAME statement are associated with eld names in a screen array, the construct takes place in the rst row of the screen array. If you want the CONSTRUCT to take place in a different row of the screen array, you must use the FROM clause, not the BY NAME clause. You cannot preface column names with a qualier that includes an owner name, a database server name, or a pathname when you use the BY NAME clause. Use the FROM clause to specify table aliases in the eld list when the qualier of any column name requires an owner name, a database server name, or a pathname.
CONSTRUCT
The following example uses the customer.* notation as a macro for listing all columns in the customer table and cust.* as a macro for all the elds in the customer screen record:
CONSTRUCT query_1 ON customer.* FROM cust.*
The names of elds on the screen form are different from the names of the corresponding database columns in the ON clause. You want to reference elds in a screen array beyond the rst record. You specify additional qualiers for table.column in the ON clause (for example, for external or non-unique table names, or to reference the owner of a table if the database is ANSI-compliant). You want to specify an order for the screen elds other than the default order. (The order of the elds in the screen record determines the default order of the screen elds.)
s s
The user can position the cursor only in elds specied in the FROM clause. The list of elds in the FROM clause must correspond in order and in number to the list of database columns in the ON clause, as in this example:
CONSTRUCT query_1 ON stock_num, manu_code, description FROM stock_no, m_code, descr
If you use the record.* notation in a eld list, be sure that the implied order of elds corresponds to the order of columns in the ON clause. (The order of elds in a screen record depends on its denition in the form specication.) In the following CONSTRUCT statement, the eld list includes the stock_num and manu_code elds, as well as the screen record s_stock.* that corresponds to the remaining columns in the stock table:
CONSTRUCT query_1 ON stock.* FROM stock_num, manu_code, s_stock.*
4-40
CONSTRUCT
The FROM clause is required when the eld list includes an alias representing a table, view, or synonym name that includes any qualier. For example, in the following CONSTRUCT statement, cust is a table alias declared in the form specication le for the actg.customer table, where actg is an owner prex. This table alias must be prexed to each eld name in the FROM clause, because the column qualiers in the ON clause include an owner name:
CONSTRUCT query_1 ON actg.customer.fname, actg.customer.lname, actg.customer.company FROM cust.fname, cust.lname, cust.company
To use screen-array eld names in the FROM clause, you must use the notation screen-record [line].eld-name to specify the row in which the construct takes place. Here line must be greater than zero, and the CONSTRUCT takes place on the lineth record of the screen array. For example, the following CONSTRUCT statement allows you to enter search criteria in the third line of the screen array s_items:
CONSTRUCT query_1 ON items.* FROM s_items[3].*
If you reference a screen array in the eld list with no [line] specication, the default is the rst screen record of the array.
Default attributes listed in syscolatt table (See the description of The upscol Utility on page B-5.) Default attributes in the form specication The NOENTRY and AUTONEXT attribute in the form specication
s s
CONSTRUCT
Whether or not the CONSTRUCT statement includes the ATTRIBUTE clause, when the user enters criteria into a eld that has the AUTONEXT attribute and keys past the eld delimiter, the cursor does not enter the next eld. The CONSTRUCT statement ignores the AUTONEXT attribute so that users can query for large ranges, alternatives, and so forth. The CONSTRUCT attributes temporarily override any display attributes set by the INPUT ATTRIBUTE clause of an OPTIONS or OPEN WINDOW statement. Attributes in the ATTRIBUTE clause of CONSTRUCT apply to all the elds in the eld list, but only during the current activation of the form. When the user deactivates the form, the form reverts to its previous attributes. The following CONSTRUCT statement includes an ATTRIBUTE clause that species CYAN and REVERSE for values entered in screen elds that have the same names as the columns in the customer table:
CONSTRUCT BY NAME query_1 ON customer.* ATTRIBUTE (CYAN, REVERSE)
These keywords can produce the effects indicated only when the termcap or terminfo les and the physical terminals support the specied attribute. For more information on using these les, see Appendix F, Modifying termcap and terminfo. On UNIX systems that use terminfo les rather than termcap, 4GL does not support attributes that specify colors, and the only valid keywords are REVERSE and UNDERLINE. Some terminal entries in termcap or terminfo can include sg#1 or xmc#1 capabilities. If you are using one of these terminals and if the attributes specied for the CONSTRUCT statement are different from the attributes of the current form or window, 4GL replaces the right and left ( [ ] ) brackets that indicate the input elds with blank characters. 4GL uses the blank character as a transition character between the different attributes.
4-42
CONSTRUCT
CONSTRUCT
,
eld
,
ON KEY ( key
Description is the name of a eld that was either explicitly or implicitly referenced in the CONSTRUCT variable clause (page 4-37). is a keyword listed in The ON KEY Blocks on page 4-47. is an SQL statement or other 4GL statement.
You can use CONSTRUCT input control blocks to specify the following:
s s s s s
Statements to execute before and after the query by example Statements to execute before and after a given eld Statements to execute if a user presses some key sequence The next eld to which to move the screen cursor When to exit from the CONSTRUCT statement
4-44
CONSTRUCT
4GL executes the statements in the block according to the following events:
s s
The elds into which and from which the user moves the cursor The keys that the user presses
Statements can include CONTINUE CONSTRUCT and EXIT CONSTRUCT, the NEXT FIELD clause, and most 4GL and SQL statements. See Nested and Recursive Statements on page 2-31 for details of including CONSTRUCT, PROMPT, INPUT, and INPUT ARRAY statements within an input control block.
4GL temporarily deactivates the form while executing statements in an input control block. After executing the statements, 4GL reactivates the form,
BEFORE FIELD (executed before the user enters values in a specied eld)
ON KEY (executed after the user presses a specied key) AFTER FIELD (executed after the user enters values in a specied
eld)
AFTER CONSTRUCT (executed after the user has nished data entry)
If you include no input control blocks, the program waits while the user enters values in the elds. When the user accepts the values in the form, the CONSTRUCT statement terminates, the form is cleared, and control passes to the next statement.
CONSTRUCT
The following CONSTRUCT statement displays the value HRO in the manu_code eld. If the user does not change the HRO value before pressing the Accept key, the query by example selects rows of the database that have the value HRO in the manu_code column:
CONSTRUCT query_1 ON stock.* FROM s_stock.* BEFORE CONSTRUCT LET p_stock.manu_code = "HRO" DISPLAY p_stock.manu_code TO stock.manu_code END CONSTRUCT
No more than one BEFORE CONSTRUCT block can appear in a CONSTRUCT statement. The FIELD_TOUCHED( ) operator is not valid in this control block.
4-46
CONSTRUCT
The following example uses the BEFORE FIELD clause to display a message when the cursor enters the state eld:
BEFORE FIELD state MESSAGE "Press F2 or CTRL-B to display a list of states"
The following program fragment denes two BEFORE FIELD blocks. The rst block uses the NEXT FIELD clause to limit access to the salary eld to certain users. The second block displays the current date in the q_date eld:
CONSTRUCT BY NAME query_1 ON employee.* BEFORE FIELD salary IF (username <> "manager") AND (username <> "admin") THEN NEXT FIELD NEXT END IF BEFORE FIELD q_date LET query_date = TODAY DISPLAY query_date TO q_date END CONSTRUCT
The following table lists the keywords that you can specify for key.
ACCEPT HELP DELETE INSERT DOWN INTERRUPT ESC or ESCAPE LEFT F1 through F64 RIGHT CONTROL-char (except A, D, H, I, J, K, L, M, R, or X) NEXT or NEXTPAGE PREVIOUS or PREVPAGE RETURN TAB UP
Like other keywords of 4GL, you can specify these in uppercase or lowercase letters.
CONSTRUCT
Some keys need special consideration if you assign them in an ON KEY block.
Key
ESC or ESCAPE
Special Considerations You must use the OPTIONS statement to specify another key as the Accept key, because ESCAPE is the default Accept key. You must use the OPTIONS statement to specify another key as the Next key, because F3 is the default Next key. You must use the OPTIONS statement to specify another key as the Previous key, because F4 is the default Previous key. You must execute a DEFER INTERRUPT statement. When the user presses the Interrupt key under these conditions, 4GL executes the ON KEY block and sets int_ag to non-zero but does not terminate the CONSTRUCT statement. Similarly, 4GL executes the statements in the ON KEY block and sets quit_ag to non-zero if the DEFER QUIT statement has been executed when the user presses the Quit key. 4GL reserves these control keys for eld editing; see Positioning the Screen Cursor on page 4-61. The standard meaning of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user. Instead, the key is trapped by 4GL and activates the commands in the ON KEY block. For example, if CONTROL-M appears in an ON KEY block, the user cannot press RETURN to advance the cursor to the next eld. If you specify one of these keys in an ON KEY block, be careful to restrict the scope of the statement.
F3
F4
Interrupt
Quit
CTRL-char A, D, H, L, R, X I, J, M
You might not be able to use other keys that have special meaning to your version of the operating system. For example, CONTROL-C, CONTROL-Q, and CONTROL-S respectively send the Interrupt, XON, and XOFF signals on many systems. If an ON KEY block is activated during data entry, 4GL takes these actions:
1. 2. 3.
Suspends the input of the current eld Preserves the input buffer that holds the characters the user typed Executes the statements in the corresponding ON KEY clause
4-48
CONSTRUCT
4. 5.
Restores the input buffer for the current screen eld Resumes input in the same eld, with the cursor at the end of the buffered list of characters
You can change this default behavior by including statements to perform the following tasks in the ON KEY block:
s s
Resume input in another eld by using the NEXT FIELD keywords Change the input buffer value for the current eld by assigning a new value to the corresponding variable and displaying the value
Version 4.12 of 4GL introduced a change in the output of CONSTRUCT statements interrupted by the user pressing the Interrupt key (usually CTRL-C or DEL) or the Quit key (usually CTRL-\). This applies only to programs that have executed DEFER INTERRUPT and DEFER QUIT; otherwise, an Interrupt or Quit signal terminates the 4GL application immediately. In 4.10 and earlier releases, an Interrupt or Quit keystroke in a CONSTRUCT statement produced an output query string that contained the contents of the eld buffer at the time the Interrupt keystroke was pressed. Therefore, if the program did not carefully check the value of int_ag before proceeding, it could miss the fact that the CONSTRUCT had been interrupted and proceed with a query that was based on defective search criteria. In Version 4.12 and later, a CONSTRUCT statement interrupted by an Interrupt or Quit keystroke produces a NULL query string. This reduces the risk of an Interrupt condition being undetected. The CONSTRUCT statement can only produce a NULL query string if it was interrupted; thus, you can detect an Interrupt or Quit without checking both int_ag and quit_ag. (A successful CONSTRUCT statement for which no criteria were entered before the Accept key was pressed produces the string ' 1=1' , not a NULL string.)
CONSTRUCT
cursor leaves the eld. The user can move the cursor from a eld by pressing any of the following keys:
s s s s
key
Accept key
TAB
key
When the NEXT FIELD keywords appear in an AFTER FIELD block, 4GL places the cursor in the specied eld and ignores the Accept keystroke. If an AFTER FIELD block exists for each eld, and if a NEXT FIELD clause appears in every AFTER FIELD block, the user is unable to leave the form. The following program fragment checks for the Accept key and terminates execution of CONSTRUCT if the Accept key was pressed:
AFTER FIELD status IF NOT GET_LASTKEY( ) = ACCEPT_KEY THEN LET p_stat = GET_FLDBUF(status) IF p_stat MATCHES "married" THEN NEXT FIELD spouse_name END IF END IF END CONSTRUCT
The following AFTER FIELD control block displays a message after the cursor leaves the state eld, prompting the user to enter search criteria:
AFTER FIELD state MESSAGE "Press ESC to begin search"
As noted in Completing a Query on page 4-63, the user can terminate the CONSTRUCT statement by using Accept, Interrupt, or Quit, or by pressing the TAB or RETURN key after the last form eld. You can use the AFTER FIELD clause with the NEXT FIELD keywords on the last eld to override this default termination. (Alternatively, you can specify INPUT WRAP in an OPTIONS statement to achieve the same effect.) A eld can have no more than one AFTER FIELD control block.
4-50
CONSTRUCT
For more information, see Searching for All Rows on page 4-60.
4GL executes the statements in the AFTER CONSTRUCT block when the user
The Accept key The Interrupt key (if DEFER INTERRUPT has executed) The Quit key (if the DEFER QUIT statement has executed)
The user presses the Interrupt or Quit key and the DEFER INTERRUPT or DEFER QUIT statement, respectively, has not been executed. In either case, the program terminates immediately, and no query is performed. The EXIT CONSTRUCT statement terminates the CONSTRUCT statement.
CONSTRUCT
The CONSTRUCT statement can include only one AFTER CONSTRUCT block.
The next eld, as dened by the explicit (FROM clause) or implicit (BY NAME) order of elds in the eld list of the CONSTRUCT variable clause. In this case, specify the NEXT keyword. The previous eld, as dened by the same order of elds. In this case, specify the PREVIOUS keyword. Any other eld in the current form. In this case, specify the name of the eld (from the ATTRIBUTES section of the form specication le).
The NEXT FIELD keywords can appear in a BEFORE CONSTRUCT block (for example, to position the cursor at a different starting eld) and in a BEFORE FIELD block (for example, to restrict access to a eld), but they are more commonly used in AFTER FIELD, ON KEY, or AFTER CONSTRUCT blocks. Use NEXT FIELD only if you want the cursor to deviate from the default eld order. 4GL immediately positions the cursor in the form when it encounters the NEXT FIELD clause, without executing any statements that immediately follow the NEXT FIELD clause in the same statement block. In the following program fragment, function qty_help( ) cannot be invoked because its CALL statement is positioned after the NEXT FIELD clause:
ON KEY (CONTROL_B, F4) IF INFIELD(stock_num) OR INFIELD(manufact) THEN CALL stock_help( ) NEXT FIELD quantity CALL qty_help( ) -- function is never called END IF
4-52
CONSTRUCT
The following program fragment includes NEXT FIELD clauses in ON KEY and AFTER FIELD blocks. The user triggers the ON KEY block by pressing CONTROL-B or F4. If the cursor is in the stock_num eld or manufact eld, 4GL calls the stock_help( ) function. When 4GL returns from the stock_help( ) function, the NEXT FIELD clause moves the cursor to the quantity eld. The user executes the AFTER FIELD block by moving the cursor out of the zipcode eld. The FIELD_TOUCHED( ) operator checks whether the user entered a value into the eld. If this returns TRUE, GET_FLDBUF( ) retrieves the value entered into the eld during a query, and assigns it to the p_zipcode variable. If the rst character in the p_zipcode variable is not a 5, 4GL displays an error, clears the eld, and returns the cursor to the eld.
ON KEY (CONTROL_B, F4) IF INFIELD stock_num) OR INFIELD(manufact) THEN CALL stock_help( ) NEXT FIELD quantity END IF AFTER FIELD zipcode IF FIELD_TOUCHED(zipcode) THEN LET p_zipcode = GET_FLDBUF(zipcode) IF p_zipcode[1,1] <> "5" THEN ERROR "You can only search area 5." CLEAR zipcode NEXT FIELD zipcode END IF END IF
Do not use NEXT FIELD clauses to move the cursor across every eld in a form. If you want the cursor to move in a specic order, list the elds in the CONSTRUCT statement in the desired order. In most situations, NEXT FIELD appears in a conditional statement. The NEXT FIELD clause must appear in a conditional statement when it appears in an AFTER CONSTRUCT block; otherwise, the user cannot exit from the query.
CONSTRUCT
This statement is useful where program control is nested within multiple conditional statements and you want to return control to the user. It is also useful in an AFTER CONSTRUCT block, where you can examine eld buffers and, depending on their contents, return the cursor to the form. In this example, CONTINUE CONSTRUCT appears in an AFTER CONSTRUCT clause. If the user enters N or n at the prompt, the cursor returns to the form:
CONSTRUCT BY NAME query1 ON customer.* ... AFTER CONSTRUCT IF NOT FIELD_TOUCHED(customer.*) THEN PROMPT "Do you really want to see ", "all customer rows? (y/n)" FOR CHAR answer IF answer MATCHES "[Nn]" THEN MESSAGE "Enter search criteria; ", "press ESC to begin search." CONTINUE CONSTRUCT END IF END IF END CONSTRUCT
If no criteria are entered, the user is prompted to conrm that all customer records are requested. If the user types N or n, CONTINUE CONSTRUCT positions the cursor in the form, giving the user another chance to enter selection criteria in the last eld occupied. If the user types any other key, the IF statement terminates, and control passes to the END CONSTRUCT statement. Compare this method of detecting and handling the absence of search criteria to the examples in The AFTER CONSTRUCT Block on page 4-51 and Searching for All Rows on page 4-60. When a test in an AFTER CONSTRUCT clause identies a eld that requires action by the user, specify NEXT FIELD, rather than CONTINUE CONSTRUCT, to position the cursor in the eld.
Skip all statements between EXIT CONSTRUCT and END CONSTRUCT. Terminate the process of constructing the query by example.
4-54
CONSTRUCT
s s
Create the Boolean expression and store it in the character variable. Resume execution at the statement following the END CONSTRUCT keywords.
If it encounters the EXIT CONSTRUCT statement, 4GL does not execute the statements in the AFTER CONSTRUCT control block, if that block is present.
FIELD_TOUCHED( ) Returns TRUE when the user has touched (made a change to) a screen eld whose name is passed as an operand. Moving the screen cursor through a eld (with the RETURN, TAB, or arrow keys) does not mark a eld as touched. This feature also ignores the effect of statements that appear in the BEFORE INPUT control block. For example, you can assign values to elds in the BEFORE INPUT control block without having the elds marked as touched. GET_FLDBUF( ) Returns the character values of the contents of one or more elds in the currently active form. (1 of 2)
CONSTRUCT
Feature FGL_GETKEY( )
Description Waits for a key to be pressed, and then returns an INTEGER value corresponding to the raw value of the key that was pressed. Returns an INTEGER value corresponding to the most recent keystroke executed by the user in the screen form. Returns TRUE if the name of the eld that is specied as its operand is the name of the current eld. (2 of 2)
FGL_LASTKEY( ) INFIELD( )
Each eld in a form has only one eld buffer, and a buffer cannot be used by two statements simultaneously. If a CONSTRUCT statement calls a function that includes an INPUT, INPUT ARRAY, or CONSTRUCT statement, and both statements use the same form, they might overwrite one or more of the eld buffers, unless you rst close the form or window. (See, however, Nested and Recursive Statements on page 2-31.) If you plan to display the same form more than one time and will access the form elds, open a new window and open and display a second copy of the form. 4GL allocates a separate set of buffers to each form, and you can then be certain that your program is processing the correct eld values.
CONSTRUCT
Meaning Not less than Not greater than Not equal to Range Wildcard for any string Single-character wildcard Logical OR
Data Type Domain All simple SQL types All simple SQL types All simple SQL types All simple SQL types CHAR, VARCHAR CHAR, VARCHAR All simple SQL types
Pattern >=x <=x !=x, <>x x:y, x..y, *x, x*, *x* ?x, x?, ?x?, x?? a|b... [xy]*, [xy]? (2 of 2)
The . . form of the range operator is required for ranges of DATETIME or INTERVAL literal values that include : symbols as time-unit separators. Users cannot perform a query by example on BYTE, TEXT, or FORMONLY elds. If the search criteria exceed the length of a eld, 4GL opens a work space on the Comment line. This action erases any comments present. The following list explains the symbols in the preceding table: x The x means any value appropriate to the data type of the eld. The value must immediately follow any of the rst six symbols in the preceding table. Do not leave a space between a symbol and a value. The equal sign ( = ) is the default symbol for non-character elds, and for character elds in which the search value contains no wildcards. If the user enters a character value that does not contain a wildcard character, CONSTRUCT produces the following Boolean expression:
char-column = "value"
=x
The equal sign ( = ) with no value searches for a NULL value. The user must explicitly enter the equal sign to nd any character value that is also used as a search criteria symbol.
CONSTRUCT
These symbols imply an ordering of the data. For character elds, greater than means later in the ASCII sequence (where a > A > 1), as listed in Appendix G, Reserved Words. For DATE or DATETIME data, greater than means after. For INTERVAL data, it means a longer span of time.
A query by example cannot combine these relational operators with the range, wildcard, or logical operators that are described later. Any characters that follow a relational operator are interpreted as literals. In Version 4.11 and earlier releases, 4GL would put double quotation marks(") characters around the eld values entered during the CONSTRUCT statement regardless of the data types. The resulting WHERE clause for the SQL statement might not be compatible with non-Informix database servers because of the double quotation marks. In Version 4.12 and later releases, the CONSTRUCT statement puts single quotation marks ( ' ) around values of the character and time data types: CHAR, DATE, DATETIME, INTERVAL, and VARCHAR. Values of the number data types are not enclosed in quotation marks: FLOAT, SMALLFLOAT, DECIMAL, MONEY, INTEGER, SMALLINT, and SERIAL. Double quotation marks are not used as delimiters in the constructed variable to avoid incompatibility with non-Informix databases. These changes allow 4GL programs to work with Informix Enterprise Gateway for interoperability with DB2/400, DB2/MVS (also called, simply, DB2) and DB2/VM (also called SQL/DS). These changes are known colloquially as the DRDA changes. The latest versions of the Informix Enterprise Gateway product automatically convert the keyword MATCHES to LIKE and generate an error if the MATCHES string contains a character range enclosed in square brackets (for example, [a-z]).
4-58
CONSTRUCT
Besides the relational operators, the user can specify a range, or use syntax like that of the MATCHES operator to search for patterns in character values:
s
Colon. The colon in x: y searches for all values between the x and y value, inclusive. The y value must be larger than the x value. The search criterion 1: 10 would nd all rows with a value in that column from 1 through 10. For character data, the range species values in the ASCII collating sequence between x and y. (For DATETIME and INTERVAL elds, use instead the .. symbol to specify ranges.) Two periods. Sometimes you must substitute two periods ( .. ) as a synonym for the colon ( : ) in DATETIME and INTERVAL ranges to avoid ambiguity with time-unit separators in hh:mm:ss values. Asterisk. The asterisk ( * ) is a character string wildcard, representing zero or more characters. Use the asterisk character as follows:
The search value *ts* in a eld species all strings containing the letters ts, such as the strings "Watson" and "Albertson". The search value S* species all strings beginning with the letter s, including the strings "S", "Sadler", and "Sipes". The search value *er species all strings that end in the letters er, such as the strings "Sadler" and "Miller".
Question mark. The question mark ( ? ) is the single-character wildcard. The user can use the question mark to nd values matching a pattern in which the number of characters is xed, as in the following examples:
Enter Eriks?n to nd names like "Erikson" and "Eriksen". Enter New??n to nd names like "Newton", "Newman", and "Newson", but not "Newilsson".
Pipe. The pipe symbol between values a and b represents the logical OR operator. The following entry species any of three numbers:
102|105|118
Brackets. The brackets ( [ ] ) delimit a set of values. When used in conjunction with the * and ? wildcard characters, the brackets enclose a list of characters, including ranges, to be matched.
CONSTRUCT
Caret. A caret ( ^ ) as the rst character within the brackets species the logical complement of the set, and matches any character that is not listed. For example, the search value [^AB]* species all strings beginning with characters other than A or B. Hyphen. A hyphen between characters within brackets species a range. The search value [^d-f*] species all strings beginning with characters other than lowercase d, e, or f. If you omit the * or ? wildcard, 4GL treats the brackets as literal characters, not as logical operators.
4-60
CONSTRUCT
erase the contents of the eld. If this is the end of the eld, 4GL creates a workspace at the bottom of the screen and places the cursor there, so the user can continue entering values.
These arrow keys all operate non-destructively. That is, they move the screen cursor without erasing any underlying character. When the cursor moves to a new eld, the CONSTRUCT statement clears the Comment line and the Error line. The Comment line displays the text dened with the COMMENTS attribute in the form specication le. The Error line displays system error messages, output from the built-in ERR_PRINT( ) and ERR_QUIT( ) functions, and ERROR statement messages.
CONSTRUCT
If the user enters search criteria that exceed the length of the screen eld, 4GL automatically moves the cursor down to the Comment line and allows the user to continue entry. When the user presses RETURN or TAB, 4GL clears the Comment line. The eld buffer contains all the criteria that the user entered, even though only a portion is visible in the screen display.
In a multiple-segment eld (that is, one with the WORDWRAP attribute), 4GL ignores any values that the user enters in any segment beyond the rst segment of the eld. Similarly, in a screen array, the user can enter criteria only in the rst screen record of the array during a CONSTRUCT statement.
4-62
CONSTRUCT
Effect Toggles between insert and type-over mode Deletes characters from the cursor position to the end of the eld Moves the cursor non-destructively one space to the left within a eld (This is equivalent to pressing left arrow.) Moves the cursor non-destructively one space to the right within a eld (This is equivalent to pressing right arrow.) Redisplays the screen Deletes the character beneath the cursor
CONTROL-L
CONTROL-R CONTROL-X
Completing a Query
The following actions terminate the CONSTRUCT statement:
s
The Accept key The RETURN or TAB key from the last eld (when INPUT WRAP is not set in the OPTIONS statement) The Interrupt or Quit key
The user must press the Accept key to complete the query under these conditions:
s s
An AFTER FIELD block for the last eld includes a NEXT FIELD clause.
By default, the Accept, Cancel, Interrupt, and Quit keys terminate both the query and the CONSTRUCT statement. (But pressing the Interrupt or Quit key can also immediately terminate the program, unless the program has also executed the DEFER INTERRUPT and DEFER QUIT statements.)
INFORMIX-4GL Statements 4-63
CONSTRUCT
If 4GL previously executed a DEFER INTERRUPT statement in the program, pressing the Interrupt key while CONSTRUCT is awaiting input causes 4GL to take the following actions:
s s
Set the global variable int_ag to TRUE. Terminate the CONSTRUCT statement (except the AFTER CONSTRUCT block, if any) but not the 4GL program.
If 4GL previously executed a DEFER QUIT statement in the program, pressing the Quit key while CONSTRUCT is awaiting input causes 4GL to take the following actions:
s s
Set the global variable quit_ag to TRUE. Terminate the CONSTRUCT statement (except the AFTER CONSTRUCT block, if any) but not the 4GL program.
In both cases, the variable that stores the query criteria is set to NULL, a value that causes an SQL error if you attempt to use it as the WHERE clause. To avoid this problem, set any non-zero value of int_ag or quit_ag to zero (FALSE) before the CONSTRUCT statement begins execution. When the user terminates a CONSTRUCT statement, 4GL executes the statements in the AFTER CONSTRUCT clause, unless the CONSTRUCT statement is terminated by an EXIT CONSTRUCT statement. In this case, the statements in the AFTER CONSTRUCT clause and in the AFTER FIELD clause of the current eld are not executed. When NEXT FIELD appears in either of these clauses, 4GL ignores the Accept keystroke, and focus moves to the specied eld. The following program segment uses a simple CONSTRUCT statement to specify the search condition of a WHERE clause. The variable query_1 is declared as CHAR(250), and the cursor_1 cursor executes the query.
CONSTRUCT BY NAME query_1 ON order_num, customer_num, order_date, ship_date ATTRIBUTE(BOLD) LET s1 = "SELECT * FROM orders WHERE ", query_1 CLIPPED, " ORDER BY order_date, order_num" PREPARE s_1 FROM s1 DECLARE cursor_1 CURSOR FOR s_1 FOREACH cursor_1 INTO order_rec.* ... END FOREACH
4-64
CONSTRUCT
The following program fragment demonstrates six CONSTRUCT input control blocks:
CONSTRUCT BY NAME query_1 ON customer.* BEFORE CONSTRUCT MESSAGE "Enter search criteria; ", "press ESC to begin search." DISPLAY "Press F1 or CTRL-W for field help." AT 2,1 ON KEY (F1, CONTROL-W) CALL customer_help() -- display field level help BEFORE FIELD state MESSAGE "Press F2 or CTRL-B ", "to display a list of states." ON KEY (F2, CONTROL-B) IF INFIELD(state) THEN CALL statehelp() -- display list of states END IF AFTER FIELD state MESSAGE "Enter search criteria; ", "press ESC to begin search." AFTER CONSTRUCT -- check for blank search criteria IF NOT FIELD_TOUCHED(customer.*) THEN PROMPT "Do you really want to see ", "all customer rows? (y/n) " FOR CHAR answer IF answer MATCHES "[Nn]" THEN MESSAGE "Enter search criteria; ", "press ESC to begin search." CONTINUE CONSTRUCT -- reenter query by example END IF END IF END CONSTRUCT LET s1 = "SELECT * FROM customer WHERE ", query_1 CLIPPED PREPARE s_1 FROM s1 DECLARE q_curs CURSOR FOR s_1 DISPLAY "" AT 2,1 -- clear line 2 of text LET exist = 0
References
DECLARE, DEFER, DISPLAY FORM, EXECUTE, LET, OPEN FORM, OPEN WINDOW, OPTIONS, SELECT, PREPARE
CONTINUE
CONTINUE
The CONTINUE statement transfers control of execution from a statement block to another location in the currently executing compound statement.
CONTINUE keyword
Element keyword
Description species the current 4GL statement. You can choose from the keywords CONSTRUCT, FOR, FOREACH, INPUT, MENU, and WHILE.
Usage
You can use CONTINUE within a statement block of the currently executing compound statement that keyword species. This is a runtime instruction to transfer control within the current statement. (Use the EXIT keyword, rather than CONTINUE, to terminate the compound statement unconditionally.) The use of CONTINUE in WHENEVER statements is described in The CONTINUE Option on page 4-381.
4-66
CONTINUE
References
CONSTRUCT, FOR, FOREACH, GOTO, INPUT, INPUT ARRAY, MENU, WHILE, WHENEVER
CURRENT WINDOW
CURRENT WINDOW
The CURRENT WINDOW statement makes a specied 4GL window the current window (that is, the top-most 4GL window in the window stack).
CURRENT WINDOW IS window SCREEN
Element window
Usage
4GL maintains a list or stack of all open 4GL windows in the 4GL screen. The OPEN WINDOW statement creates a new 4GL window that is added to the top of this window stack, becoming the current window. When you close a 4GL window, that 4GL window is removed from the stack. The top-most 4GL
window among those that remain open becomes the new current window. Its values take effect for the positions of reserved lines like Prompt, Message, Form, and Comment lines. The current 4GL window is always completely visible and can obscure all or part of any inactive 4GL windows. When you specify a new current window, 4GL adjusts the window stack by moving the new current 4GL window to the top and closing the gap in the stack left by this 4GL window. Programs with multiple 4GL windows might need to switch to a different open window so that input and output occur in the appropriate 4GL window. To make a 4GL window the current window, use the CURRENT WINDOW statement. For example, this statement makes win1 the current 4GL window:
CURRENT WINDOW IS win1
When a program starts, the 4GL screen is the current 4GL window. Its name is SCREEN. To make this the current 4GL window, specify the keyword SCREEN instead of a window identier:
CURRENT WINDOW IS SCREEN
4-68
CURRENT WINDOW
If a 4GL window contains a form, that form becomes the current form when a CURRENT WINDOW statement species the name of that 4GL window. The CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, and MENU statements use only the current 4GL window for input and output. If the user displays another form (for example, through an ON KEY clause) in one of these statements, the 4GL window containing the new form becomes the current window. When the CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, or MENU statement resumes, its original 4GL window becomes the current window. The next program fragment opens multiple 4GL windows, including one called w2. Interactive statements that use the 4GL window w2 can follow the CURRENT WINDOW statement within the do2( ) function. If the function do2( ) terminates after assigning the modular variable next_win any value but 2, the CALL statement in the WHILE loop invokes a different function. The w2 4GL window remains current until another CURRENT WINDOW statement species some other 4GL window, or until CLOSE WINDOW w2 is executed.
DEFINE next_win INTEGER MAIN OPEN WINDOW w1 AT 3,3 WITH FORM "cust1" OPEN WINDOW w2 AT 9,15 WITH FORM "cust2" OPEN WINDOW w3 AT 15,27 WITH FORM "cust3" . . . LET next_win = 1 WHILE next_win IS NOT NULL CASE (next_win) WHEN 1 CALL do1() WHEN 2 CALL do2() WHEN 3 CALL do3() . . . END CASE END WHILE CLOSE WINDOW w1 CLOSE WINDOW w2 CLOSE WINDOW w3 . . . END MAIN FUNCTION do2() LET next_win = NULL CURRENT WINDOW IS w2 . . . END FUNCTION
CURRENT WINDOW
References
CLEAR, CLOSE WINDOW, DISPLAY ARRAY, INPUT, INPUT ARRAY, MENU, OPEN WINDOW, OPTIONS
4-70
DATABASE
DATABASE
The DATABASE statement opens a default database at compile time, or a current database at runtime. (See also the description of the DATABASE statement in the Informix Guide to SQL: Syntax.)
DATABASE Database Specication EXCLUSIVE Database Specication variable database IDS SE database @server
"/ / server / database" "/ pathname / database @ server " "/ / server / pathname / database "
Description is the name of a database. Blank spaces are not valid between quotation marks or after the @ symbol. is the path to the parent directory of the .dbs directory. is the name of the host system where database resides. is a variable that contains the database specication (as described in The Database Specication on page 4-72). You can specify variable only in a MAIN or FUNCTION block.
DATABASE
Usage
This statement is not required if your 4GL program does not reference entities in a database. You can use the DATABASE statement in two distinct ways, depending on the context of the statement within its source code module:
s
You can specify the default database (as described in The Default Database at Compile Time on page 4-73) for the compiler to use in declaring data types indirectly in DEFINE statements, or for INITIALIZE or VALIDATE to access syscolatt or syscolval. (The default database is opened automatically at runtime.) You can specify the current database (as described in The Current Database at Runtime on page 4-74), so that SQL statements can access data and other entities in that database at runtime.
Only the databases stored in your current directory, or in a directory specied in your DBPATH environment variable, are recognized. To specify a database that does not reside in your current directory or in a DBPATH directory, you must follow the DATABASE keyword with a complete pathname, or with a program variable that evaluates to the full pathname of the database (excluding the .dbs extension).
4-72
DATABASE
GLS
When the DATABASE statement establishes the database connection between 4GL and the database server, the locale categories for COLLATION and CTYPE on the client system are transmitted with the request for database service. The database server uses these settings to compare the user locale and the database locale. If the user locale and database locale do not match, the request for database service is rejected. This process is referred to as locale consistency checking. The CTYPE and COLLATION categories at the time of database creation are stored with the database in a system table. These values are kept unchanged throughout the life of the database to ensure the consistent use of collating sequences, code sets, and formatting rules. You cannot change the character set and collation settings for a database; you must unload and reload all the data into a different database to change locales. For more information on nondefault locales and locale-dened collation, see Appendix E, Developing Applications with Global Language Support.
DATABASE
If you want different program blocks to use the same database, you can repeat the same DATABASE statement in each program block in which entities in the database are referenced or created. Alternatively, you can create a le that includes only the DATABASE and the GLOBALSEND GLOBALS statements, and then include GLOBALS "lename" statements at the beginning of each module that requires the DATABASE statement. The next example shows the contents of a le in which no global variables are declared, but the zeitung database can be accessed by statements in any other source modules that include the GLOBALS "lename" statement:
DATABASE zeitung GLOBALS END GLOBALS
DATABASE
You cannot include the DATABASE statement in a multiple-statement PREPARE operation. (See also the descriptions of the PREPARE statement and the CLOSE DATABASE statement in the Informix Guide to SQL: Syntax.)
If another user already has the specied database open, exclusive access is denied, an error is returned, and no database is opened.
Testing SQLCA.SQLAWARN
You can determine the type of database that the DATABASE statement opens by examining the built-in SQLCA.SQLAWARN variable (as described in Error Handling with SQLCA on page 2-45) after the DATABASE statement has executed successfully:
s
If the specied database uses transactions, SQLCA.SQLAWARN[2], the second element of the SQLCA.SQLAWARN global record, contains a W. If the database is ANSI-compliant, SQLCA.SQLAWARN[3], the third element of the SQLCA.SQLAWARN global record, contains a W. If Informix Dynamic Server is the database server, SQLCA.SQLAWARN[4], the fourth element of the SQLCA.SQLAWARN global record, contains a W.
DATABASE
If ANSI compliance is requested and no WHENEVER ERROR statement is in effect, the default action after an error is CONTINUE.
ANSI compliance is in effect if one of the following conditions exists:
s s s
There is a stated default database and it is ANSI-compliant. The -ansi compilation ag is specied. The DBANSIWARN environment variable is set.
In releases of RDS before 7.2, for the last two of these conditions, the default error action was (improperly) STOP instead of CONTINUE.
2.
If the -anyerr ag is used, the default action is STOP. If, instead, the -anyerr ag is not used, the default action after expression or data type conversion errors is CONTINUE; after other categories of errors, it is STOP.
If you compile part of the application against an ANSI-compliant database and part of it against a non-ANSI-compliant database, the parts of the application compiled against the ANSI-compliant database have the default error action of CONTINUE, and the parts compiled against the non-ANSI-compliant database have the default error action of STOP.
4-76
DATABASE
You must use a network connection, rather than a shared-memory connection, to connect a 32-bit 4GL client to a 64-bit database server.
4GL supports the stream-pipe interprocess connection mechanism to local
hosts. You can use this mechanism to do distributed communication, if both systems are on the same computer. Unlike shared-memory connections, stream pipes do not pose the risk of being overwritten or being read by other programs that explicitly access the same part of shared memory. Stream-pipe connections, however, are slower than shared-memory connections and are not available on some computers. A stream-pipe connection requires onipcstr as the entry in the nettype eld of the sqlhosts le.
Server alpha nettype onipcstr hostname idcsun33 Service service1
References
DEFINE, FUNCTION, GLOBALS, INITIALIZE, MAIN, REPORT, VALIDATE
DEFER
DEFER
The DEFER statement prevents 4GL from terminating program execution when the user presses the Interrupt key or the Quit key.
DEFER INTERRUPT QUIT
Usage
DEFER is a method of intercepting asynchronous signals from outside the program. Unless it includes the DEFER statement, the 4GL application termi-
nates whenever the user presses the Interrupt or Quit key. The Interrupt key is CONTROL-C, and the Quit key is CONTROL-\. The DEFER statement tells 4GL to set a built-in global variable to a non-zero value, rather than terminate, when the user presses one of these keys:
s
If the user presses the Interrupt key when DEFER INTERRUPT has been specied, 4GL sets the built-in global variable int_ag to TRUE. If the user presses the Quit key when DEFER QUIT has been specied, 4GL sets the built-in global variable quit_ag to TRUE.
The DEFER INTERRUPT and DEFER QUIT statements can appear only in the MAIN program block, and only once in any program. Once executed, the DEFER statement remains in effect for the duration of the program; you cannot restore the original function of the Interrupt key or the Quit key.
4GL programs can include code to check whether int_ag or quit_ag is TRUE, and if so, to take appropriate action. Be sure also to reset int_ag or quit_ag to FALSE (that is, to zero) so that subsequent tests are valid.
4-78
DEFER
DEFER
CONSTRUCT BY NAME where_clause ON stock.* FROM s_stock.* IF int_flag THEN ERROR "Query cancelled." RETURN END IF . . . END FUNCTION
If the user decides not to enter any selection criteria, pressing the Interrupt key terminates the CONSTRUCT statement without executing the query. If int_ag ag is set to a non-zero value (TRUE), the program terminates the function by executing a RETURN statement. Notice that the function resets the value of int_ag to FALSE (zero) before beginning the CONSTRUCT statement. Here if int_ag is set to a non-zero value (evaluates to TRUE), a RETURN statement terminates the function. Notice that in this example, the nd_stock( ) function explicitly resets the value of int_ag to FALSE (zero) before beginning the CONSTRUCT statement.
the DEFER INTERRUPT statement. the OPTIONS statement with the SQL INTERRUPT ON option.
The keywords SQL INTERRUPT OFF restore the default of uninterruptable SQL statements. Interrupting SQL Statements on page 4-301 describes this feature in detail and its effect on the current database transaction.
References
CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, MAIN, MENU, OPTIONS, PROMPT, WHENEVER
4-80
DEFINE
DEFINE
The DEFINE statement declares the names and data types of 4GL variables. ,
DEFINE variable Data Type p. 4-84
Element variable
Usage
A variable is a named location in memory that can store a single value, or an ordered set of values. Except for predened global variables like status, int_ag, quit_ag, or the SQLCA record, you cannot reference any program variable before it has been declared by the DEFINE statement. Releases of 4GL prior to 7.3 supported a total of no more than 64,535 bytes in all the names of variables in a single 4GL program, including record members and redened variables. In this release, however, the upper limit on global string space (which includes variables, regardless of their scope, and certain other named 4GL program entities) is now 2 gigabytes (= 2,048 megabytes). Your available system resources might impose a lower limit. In programs that are compiled to p-code, however, a single 4GL function or report can have a total of no more than 32,767 bytes in the names of all its variables. The GLOBALS "lename" statement can extend the visibility of module-scope variables that you declare in lename to additional source code modules. The following sections describe these topics:
s s s s s s
The Context of DEFINE Declarations on page 4-82 Indirect Typing on page 4-83 Declaring the Names and Data Types of Variables on page 4-84 Variables of Simple Data Types on page 4-85 Variables of Large Data Types on page 4-86 Variables of Structured Data Types on page 4-86
INFORMIX-4GL Statements 4-81
DEFINE
Where in the program can they be used? The answer denes the scope of reference of the variable. A point in the program where an identier can be used is said to be in the scope of the identier. A point where the identier is not known is outside the scope of the identier. When is storage for the variable allocated? Storage can be allocated either statically, when the program is loaded to run (at load time), or dynamically, while the program is executing (at runtime).
The context of its declaration in the source module determines where a variable can be referenced by other 4GL statements, and when storage is allocated for the variable in memory. The DEFINE statement can appear in only two contexts:
1.
Within a FUNCTION, MAIN, or REPORT program block, DEFINE declares local variables, and causes memory to be allocated for them. These DEFINE declarations of local variables must precede any executable statements within the same program block.
s
The scope of reference of a local variable is restricted to the same program block. Elsewhere, the variable is not visible. Storage for local variables is allocated when its FUNCTION, REPORT, or MAIN block is entered during execution. Functions can be called recursively, and each recursive entry creates its own set of local variables. The variable is unique to that invocation of its program block. Each time the block is entered, a new copy of the variable is created.
2.
Outside any FUNCTION, REPORT, or MAIN program block, the DEFINE statement declares names and data types of module variables, and causes storage to be allocated for them. These declarations must appear before any program blocks.
s
Scope of reference is from the DEFINE statement to the end of the same module (but the variable is not visible within this scope in program blocks where a local variable has the same identier). Memory storage for variables of module scope is allocated statically, in the executable image of the program.
4-82
DEFINE
Indirect Typing
You can use the LIKE keyword to declare a variable that has the same simple, BYTE, or TEXT data type as a specied column in a database table. ,
DEFINE variable LIKE Table Qualier p. 3-89 table . column
Description is the identier of some column in table, as it appears in the syscolumns table of the system catalog. is the identier or synonym of a table or view in the default database that was specied in the DATABASE statement. is the 4GL identier of a variable that you declare here.
If table is a view, then column cannot be based on an aggregate. If LIKE references a SERIAL column, the new variable is of the INTEGER data type. The DATABASE statement must specify a default database before the rst program block (or before the rst DEFINE statement that uses LIKE to dene module-scope or global variables) in the current module. (For more information, see The Default Database at Compile Time on page 4-73.) At compile time, 4GL substitutes a data type for the LIKE declaration, based on the schema of table. (If that schema is subsequently modied, recompile the module to restore the correspondence between variables and columns.) Any column in the LIKE declaration has either a simple or a large data type. (These data types are described in sections that follow.) The table qualier must specify owner if table.column is not a unique column identier within its database, or if the database is ANSI-compliant and any user of your 4GL application is not the owner of table. In the demonstration database, the manufact table has three columns:
s s s
manu_code of data type CHAR(3) manu_name of data type CHAR(15) lead_time of data type INTERVAL DAY(3) TO DAY
DEFINE
The LIKE keyword cannot reference column names that violate the naming rules for 4GL identiers, such as restrictions on the character set or length.
,
variable Data Type
Data Type LIKE Table Qualier p. 3-89 RECORD Data Type p. 4-88 Large Data Type p. 4-86 ARRAY Data Type p. 4-87 table . column Simple Data Type p. 4-85
Description is the name of a database column. is the name or synonym of a database table or view. is the name of the variable. This name must be unique among variables within the same scope of reference.
See Data Types of 4GL on page 3-6 for details of the various data types that you can specify when you declare 4GL variables.
4-84 IBM Informix 4GL Reference Manual
DEFINE
SMALLINT
Number DECIMAL DEC NUMERIC MONEY FLOAT DOUBLE PRECISION
(16) ( precision
, scale )
(16, 2) ( precision ,
REAL
,2 )
scale
( precision )
SMALLFLOAT DATE Time DATETIME INTERVAL CHARACTER Character CHAR NCHAR VARCHAR NVARCHAR DATETIME Qualier p. 3-76 INTERVAL Qualier p. 3-80
DEFINE
TEXT, for character strings BYTE, for any data that can be stored on your system
Unlike BYTE and TEXT declarations in SQL, DEFINE has no IN clause; in 4GL the LOCATE statement supports the functionality of the IN clause. The CALL and RUN statements cannot include the BYTE or TEXT keyword in their RETURNING clauses. For more information, see BYTE on page 3-14 and TEXT on page 3-39.
ARRAY, for arrays of values of any single data type except ARRAY RECORD, for sets of values of any combination of data types
Structured Data Type RECORD Data Type p. 4-88 ARRAY Data Type p. 4-87
A database table cannot include a column of the ARRAY or RECORD data types because these 4GL data types are not part of the SQL language. For information on RECORD and ARRAY data types, see ARRAY on page 3-13 and RECORD on page 3-35. For information on using program arrays of records in interactive statements, see INPUT ARRAY on page 4-187 and DISPLAY ARRAY on page 4-102.
4-86 IBM Informix 4GL Reference Manual
DEFINE
ARRAY Variables
The ARRAY keyword declares a structured variable that can store a 1-, 2-, or 3-dimensional array of values, all of the same data type.
ARRAY Data Type ARRAY
, [
3 size
OF
4GL Simple Data Type p. 4-87 RECORD Data Type p. 4-88 BYTE TEXT
Element size
Description is the number (up to 32,767) of elements in a dimension. Dimensions can be different sizes, up to the limit of your C compiler.
The elements of an ARRAY variable can be of any data type except ARRAY, but an element can be a record that contains an array member. You cannot specify an ARRAY data type as an argument or as a returned value of a 4GL function. The CALL and RUN statements cannot include the ARRAY keyword in their RETURNING clauses. In the DEFINE section of a REPORT statement, formal arguments cannot be declared as ARRAY data types, nor as RECORD variables that contain ARRAY members. (Data types of local variables that are not formal arguments are unrestricted.)
DEFINE
RECORD Variables
A 4GL program record is a collection of members, each of which is a variable. The member variables of a record can be of any 4GL data type, including the simple data types (described in Declaring the Names and Data Types of Variables on page 4-84), the structured (ARRAY and RECORD) data types, and the large (BYTE and TEXT) data types.
RECORD Data Type
,
member Data Type p. 4-84 END RECORD
RECORD
LIKE Table Qualier p. 3-89 LIKE Table Qualier p. 3-89 table. table.*
column
Description is a name of a column whose data type is the same as member. is a name that you declare here for a member variable of the new record; this identier must be unique within the record. is the identier or synonym of a table or view in the default database that was specied in the DATABASE statement.
The DATABASE statement must specify a default database before the rst program block (or before the rst DEFINE statement that uses LIKE to dene module-scope or global variables) in the current module. (For more information, see The Default Database at Compile Time on page 4-73.) Specify LIKE table.* to declare the record members implicitly, with identiers and data types that correspond to all the non-SERIAL columns of table. You do not need the END RECORD keywords to declare a single record whose members correspond to all the non-SERIAL columns of table:
recordname RECORD LIKE table.*
4-88
DEFINE
In this context, table.* cannot be a view containing an aggregate column. You can use multiple LIKE clauses in the same RECORD declaration, provided that the LIKE keyword does not immediately follow the keyword RECORD:
DEFINE cust_ord_item RECORD cust_no LIKE customer.customer_num, ord RECORD LIKE orders.*,-- row from "orders" table it1 RECORD a1 LIKE items.item_num, -- subset of row b1 LIKE items.order_num -- in "items" END RECORD item_quantity LIKE items.quantity, --an "items" column it2 RECORD a2 LIKE items.total_price -- columns from b2 LIKE stock.unit, -- various tables c2 LIKE manufact.manu_name END RECORD END RECORD
A compilation error occurs, however, if a LIKE clause begins the declaration of a record that is terminated by the END RECORD keywords. To declare a record with members that mirror the data types of a database table, but that also contains other members, declare one or more of the other members rst. Then you can mix LIKE clauses and explicit variable declarations to the end of the record, as in the previous example. Join columns often have the same name, but you must avoid the repetition of column names when using two or more LIKE clauses in the same scope of reference, so that both variables do not have the same name. In the demonstration database, both the orders and items tables include a column order_num that can join them. In the previous example, the record members declared LIKE the columns of items appear in the same order as in the table, but the record member that is declared like the second order_num column is called item_order_num. Important: A scroll cursor cannot be used with a record that includes a member that is declared LIKE a BYTE or TEXT column.
References
DATABASE, FUNCTION, GLOBALS, MAIN, REPORT
DISPLAY
DISPLAY
The DISPLAY statement displays data values on the screen in line mode overlay, in a specied line of the current 4GL window, or in a form.
Case I: (output in the line mode overlay)
DISPLAY
,
DISPLAY value Value COLUMN left-offset
,
DISPLAY DISPLAY Value AT line , left offset ATTRIBUTE Clause p. 3-96
,
TO
,
Field Clause p. 3-86 ATTRIBUTE Clause p. 3-96
,
variable
Description is an integer variable or a literal integer, specifying the horizontal coordinate of the rst character of the next item of output. is an integer variable or a literal integer, specifying the vertical coordinate of a line of the screen or of the current window. is the name of a variable of the TEXT data type. is a quoted string, a simple variable, a literal value, or a character string returned by a CLIPPED or USING expression. is the name of a variable that is also the name of a eld.
DISPLAY
Usage
DISPLAY sends output directly to the screen, or to elds of a screen form. DISPLAY cannot reference ARRAY or BYTE data types. After DISPLAY is
executed, changing the value of a displayed variable has no effect on the current display until you execute the DISPLAY statement again. (To produce output within a REPORT, you must use PRINT rather than DISPLAY.) The following topics are described in this section:
s s s s s
Sending Output to the Line Mode Overlay on page 4-91 Sending Output to the Current 4GL Window on page 4-92 Sending Output to a Screen Form on page 4-96 The ATTRIBUTE Clause on page 4-99 Displaying Numeric and Monetary Values on page 4-100
,
DISPLAY Value value p. 4-90 COLUMN left offset
Description species the position of the rst character of the next item of output within the line mode overlay.
Formatted mode statements: INPUT, INPUT ARRAY, CONSTRUCT, ERROR, MESSAGE, DISPLAY ARRAY, and DISPLAY (with any clause) Line mode statements: DISPLAY (without any clause)
DISPLAY
The PROMPT statement produces output in whichever mode is current. When 4GL executes a DISPLAY statement that has no qualifying clause, a new 4GL window opens, called the line mode overlay, that covers the entire 4GL screen until another interactive statement produces formatted mode output. If the next interactive statement is neither a line mode DISPLAY nor a PROMPT statement, the line mode overlay disappears, revealing the 4GL screen. Otherwise, any line mode DISPLAY statement continues the display in the next line of the line mode overlay.
,
DISPLAY DISPLAY value Value p. 4-90 AT line, left offset ATTRIBUTE Clause p. 3-96
Description is a literal integer that species the position of the rst character of the next item of output within the specied line. is an integer expression that returns a line number of the current 4GL window (or the 4GL screen itself, if no other 4GL window is current).
4-92
DISPLAY
You can refer to substrings of CHAR, VARCHAR, and TEXT variables by following the identier with the starting and ending positions of the substring, separated by a comma and enclosed in brackets. For example, this statement displays characters 8 through 20 of the full_name variable:
DISPLAY "name", full_name[8,20],"added to database" AT 9, 2
You can use the following keywords to format the screen output:
s s s s
ASCII number (to display any ASCII character) CLIPPED (to truncate trailing blanks) COLUMN number (to begin output at a specied character position) USING "string" (to format values of number or DATE data types)
Important: You cannot use the AT, ATTRIBUTE, BY NAME, or TO clause with the COLUMN operator. These operators are described in Chapter 5. No others are supported. If you want to display the current time, for example, you must assign the value of CURRENT to a program variable and then display that variable, rather than include the CURRENT operator among the list of DISPLAY values. The following statement displays the values of two character variables in the format lname, fname on the next line, using the CLIPPED operator:
DISPLAY p_customer.lname CLIPPED, ", ", p_customer.fname
Unless you use the CLIPPED or USING operator, the DISPLAY statement formats character representations of the values of program variables and constants with display widths (including any sign) that depend on their declared data types, as the following table indicates.
Data Type CHAR DATE DATETIME DECIMAL FLOAT INTEGER INTERVAL Default Display Width (in Characters) The length from the data type declaration 10 From 2 to 25, as implied in the data type declaration (2 + m), where m is the precision from the data type declaration 14 11 From 3 to 25, as implied in the data type declaration (1 of 2) INFORMIX-4GL Statements 4-93
DISPLAY
Default Display Width (in Characters) (3 + m), where m is the precision from the data-type declaration The length from the data type declaration The maximum length from the data type declaration 6 The maximum length from the data type declaration (2 of 2)
SMALLFLOAT 14
When no eld is referenced by the TO or BY NAME keywords, output begins on the screen where the AT line, left-offset coordinates position it, or (if the AT clause is omitted) it defaults to the line below the current cursor position. Unless the COLUMN operator species a nondefault character position, the output begins in the rst character position, and successive output items within the same DISPLAY statement are not separated by blank spaces. For example, suppose the following program fragment runs on May 5, 1999:
DEFINE col INTEGER, cow DATE LET col = 2 LET cow = CURRENT DISPLAY COLUMN 3, "col", col, COLUMN 23, cow, cow SLEEP 5
This DISPLAY statement would produce one line of output on May 5, 1999.
col 2 left-offset = 3
s s s
05/05/199905/05/1999 left-offset = 23
Two blank spaces (the COLUMN 3 specication) The string col (the "col" string specication) Ten blank spaces, followed by the character 2 (the col INTEGER variable) Seven blank spaces (the COLUMN 23 specication) The string 05/05/199905/05/1999 (the cow, cow DATE variables)
s s
4-94
DISPLAY
Each DISPLAY statement begins its output on a new line. You can also use the AT clause to position output when no screen elds are specied by the TO or BY NAME clause. If no elds are specied, you cannot include an ATTRIBUTES clause in the DISPLAY statement, unless you also include the AT clause.
The AT Clause
You can use the AT clause to display text at a specied location in the current 4GL window, which can be the 4GL screen. The CLIPPED or USING operator can format the displayed values. You cannot, however, include the COLUMN operator in a DISPLAY statement that includes the AT clause. The coordinates start with line 1 and character position 1 in the upper-left corner of the 4GL screen or the current 4GL window. The line values increase as you go down, and the character position values increase as you move from left to right. An error occurs if either coordinate value exceeds the dimensions of the 4GL screen or the current 4GL window. For example, the following DISPLAY statement displays the value of record member total_price, starting in line 22, at character position 5:
DISPLAY "TOTAL: ", p_items.total_price AT 22, 5
Text that you display remains on the screen until you overwrite it. If you use the AT clause when the last variable is a NULL value of the CHAR data type, 4GL clears to the end of the line. If you execute a formatted-mode statement when line mode output from a DISPLAY statement with no clause is visible, 4GL clears the screen or the current 4GL window before producing formattedmode display. (Formatted mode statements include ERROR, MESSAGE, PROMPT, and DISPLAY with any AT, BY NAME, or TO clause.) Do not use DISPLAY AT to display text where it could overwrite useful data. Because INPUT clears the Comment line and the Error line when the cursor moves between elds, it is often a good idea not to display text in the following positions of the current 4GL window or the 4GL screen:
s s
The last line of the current 4GL window (the default Comment line) The last line of the 4GL screen (the default Error line)
To use these lines for text display, you must reposition the Comment and Error lines. The OPEN WINDOW and OPTIONS statements can position the Comment line, and OPEN WINDOWCOMMENT LINE OFF can hide the Comment line. The OPTIONS statement can position the Error line.
INFORMIX-4GL Statements 4-95
DISPLAY
If the displayed text exceeds the size of the current 4GL window, 4GL truncates the text to t the available space.
,
DISPLAY DISPLAY value Value p. 4-90 text BY NAME TO
,
Field Clause p. 3-86 ATTRIBUTE Clause p. 3-96
,
variable
Description is the name of a variable of the TEXT data type. is the name of a variable that is also the name of a eld.
Here you cannot use the COLUMN operator or the AT keyword to position output because the locations of elds within the form are xed. If 4GL was in line mode, this form of the DISPLAY statement rst clears the screen before sending output to the elds of the form. Character representations of values are displayed according to data type.
Type of Value Number Literal string, TEXT BYTE Display Right-justied. If the number does not t in the eld, 4GL lls the eld with asterisks ( * ) to indicate an overow. Left-justied. If a character string does not t in the eld, 4GL truncates the display of the value. The eld displays the message <byte value>, but actual BYTE values do not appear in the eld. (The PROGRAM attribute, as described in Chapter 6, can display BYTE and TEXT values.)
4-96
DISPLAY
Field attributes can change some of these default formats. For example, the LEFT attribute (described in Chapter 6) left-justies numbers, and the FORMAT attribute can format DATE, DECIMAL, FLOAT, and SMALLFLOAT values. See also the PICTURE attribute (in Chapter 6) and the USING operator (in Chapter 5).
You can produce the same result by using the THRU or THROUGH notation when listing the elds of the screen record:
DISPLAY BY NAME p_customer.company THRU p_customer.zipcode
This BY NAME clause displays data to the screen elds of the default screen records. The default screen records are those having the names of the tables dened in the TABLES section of the form specication le. To use a screen array, you dene a screen array in addition to the default screen record. This default screen record holds only the rst line of the screen array. For example, the following DISPLAY statement displays the ordno variable only in the rst line of the screen array (the default screen record):
DISPLAY BY NAME p_stock[1].ordno
To display ordno in all elements of the array, you can use the DISPLAY ARRAY statement, or DISPLAY and the TO clause, as in the next example:
FOR i = 1 TO 10 DISPLAY p_stock[i].ordno TO sc.stock[i].ordno ... END FOR
DISPLAY
The TO Clause
If the variables do not have the same names as the screen elds, the BY NAME clause is not valid. Instead, you must use the TO clause to map variables to elds explicitly. You can list the elds individually, or you can use the screen record.* or screen record[n].* notation, where screen record[n].* species all the elds in line n of a screen array. In a DISPLAY TO statement, any screen attributes specied in the ATTRIBUTE clause apply to all the elds that you specify after the TO keyword. You can use the SCROLL statement to move such values up or down, but the DISPLAY ARRAY statement is generally more convenient to use with screen arrays. In the following example, the values in the p_items program record are displayed in the rst row of the s_items screen array:
DISPLAY p_items.* TO s_items[1].*
The expanded list of screen elds must correspond in order and in number to the expanded list of identiers after the DISPLAY keyword. Identiers and their corresponding elds must have the same or compatible data types. For example, the next DISPLAY statement displays the values in the p_customer program record in elds of the s_customer screen record:
DISPLAY p_customer.* TO s_customer.*
For this example, the p_customer program record and the s_customer screen record require compatible declarations. The following DEFINE statement declares the p_customer program record:
DEFINE p_customer RECORD customer_num LIKE fname LIKE lname LIKE phone LIKE END RECORD customer.customer_num, customer.fname, customer.lname, customer.phone
4-98
DISPLAY
The ATTRIBUTE clause temporarily overrides any default display attributes or any attributes specied in the OPTIONS or OPEN WINDOW statements for the elds. When the DISPLAY statement completes execution, the default display attributes are restored. The column labeled Interpretation indicates how an attribute appears on a color terminal (for the rst four keywords) or on a monochrome terminal (for the subsequent keywords). For example, on color terminals, NORMAL is interpreted as WHITE, and BOLD is interpreted as RED. The REVERSE, BLINK, INVISIBLE, and UNDERLINE attributes are not sensitive to the color or monochrome status of the terminal, if the terminal is capable of displaying these intensity modes. The ATTRIBUTE clause can include zero or more of the BLINK, REVERSE, and UNDERLINE attributes, and zero or one of the other attributes.
INFORMIX-4GL Statements 4-99
DISPLAY
That is, all of the attributes except BLINK, REVERSE, and UNDERLINE are mutually exclusive. For information about additional eld attributes and other form specications, see Chapter 6. These interpretations also apply to the ATTRIBUTE clause of the CONSTRUCT, DISPLAY ARRAY, DISPLAY FORM, INPUT, and INPUT ARRAY statements. The following DISPLAY statement species the attributes REVERSE and BLUE for the message that will be displayed on line 12, starting in the rst column:
DISPLAY " There are ", num USING "#####", " items in the list" AT 12,1 ATTRIBUTE(REVERSE, BLUE)
While the DISPLAY statement is executing, 4GL ignores the INVISIBLE attribute, regardless of whether you specify it in the ATTRIBUTE clause.
A leading currency symbol (as set by DBFORMAT or DBMONEY) can precede MONEY values. If the FORMAT attribute species a leading currency symbol for other data types, 4GL displays that symbol.
4GL omits the thousands separators in DISPLAY statements, unless they are specied by a FORMAT attribute or by the USING operator. 4GL displays the decimal separator, except for INT or SMALLINT
values.
s
4GL displays the trailing currency symbol (as set by DBFORMAT or DBMONEY) for MONEY values, unless you specify a FORMAT attribute or the USING operator. In this case, 4GL ignores the trailing
currency symbol; the user cannot enter a trailing currency symbol, and 4GL does not display it.
4-100
DISPLAY
GLS
The MONETARY and NUMERIC categories of the locale les can specify default display formats that are distinct for currency and number values. In some locales, such as those that support the Italian or Portuguese languages, it is conventional for currency values to be displayed in a different format from other numeric values.
For more information on DBFORMAT and DBMONEY, refer to Appendix D, Environment Variables.
References
INPUT, DISPLAY ARRAY, DISPLAY FORM, OPEN WINDOW, OPTIONS, PRINT
DISPLAY ARRAY
DISPLAY ARRAY
The DISPLAY ARRAY statement displays program array values in a screen array, so that the user can scroll through the screen array.
DISPLAY ARRAY record array ON KEY Block p. 4-106 TO screen array END DISPLAY
. *
ATTRIBUTE Clause p. 3-96
Description is the identier of a program array of RECORD variables. is the identier of a screen array. (For more information, see Screen Arrays on page 6-77.)
Usage
The following steps describe how to use the DISPLAY ARRAY statement:
1. 2. 3.
Dene a screen array in the form specication le. Use DEFINE to declare an array of program records whose members correspond in name, data type, and order to the screen array elds. Open and display the screen form with either of the following statements:
s s
The OPEN FORM and DISPLAY FORM statements The OPEN WINDOW statement with the WITH FORM clause
4.
Fill the program array with data to be displayed, counting the number of program records being lled with retrieved data.
4-102
DISPLAY ARRAY
5. 6.
Call the SET_COUNT(x) function, where x is the number of lled records. Use the DISPLAY ARRAY statement to display the program array values in the screen array elds.
The SET_COUNT( ) function sets the initial value of the ARR_COUNT( ) function. If you do not call SET_COUNT( ), 4GL cannot determine how much data to display, and so the screen array remains empty. For a description of the syntax of the built-in SET_COUNT( ) function, see Chapter 5. The DISPLAY ARRAY statement binds the screen array elds to the member records of the program array. The number of variables in each record of the program array must be the same as the number of elds in each screen record (that is, in a single row of the screen array). Each mapped variable must have the same data type or a compatible data type as the corresponding eld. The size of the screen array (from the form specication le) determines the number of program records that 4GL displays at one time on the screen. The size of the program array determines how many retrieved rows of data the program can store. The size of the program array can exceed the size of the screen array. In this case, the user can scroll through the rows on the form. When 4GL encounters a DISPLAY ARRAY statement, it takes the following actions:
1. 2. 3.
Displays the program array values in the screen array elds Moves the cursor to the rst eld in the rst screen record Waits for the user to press a scroll key (by default, F3 or PAGE DOWN to scroll forward, or F4 or PAGE UP to scroll backwards) or the Accept key (ESCAPE by default)
Because the DISPLAY ARRAY statement does not terminate until the user presses the Accept or Interrupt key, you might want to display a message informing the user. By default, 4GL displays variables and constants as follows:
s s s
Right-justies number values in a screen eld Left-justies character values in a screen eld Truncates the displayed value, if a character value is longer than the eld
DISPLAY ARRAY
Fills the eld with asterisks ( * ) to indicate an overow, if a number value is larger than the eld can display If the eld contains a BYTE value, displays <byte value> in the eld
The ATTRIBUTE Clause on page 4-104 The ON KEY Blocks on page 4-106 The EXIT DISPLAY Statement on page 4-108 The END DISPLAY Keywords on page 4-108 Using Built-In Functions and Operators on page 4-109 Scrolling During the DISPLAY ARRAY Statement on page 4-111 Completing the DISPLAY ARRAY Statement on page 4-111
The ATTRIBUTE clause specications override all default attributes and temporarily override any display attributes that the OPTIONS or the OPEN WINDOW statement specied for these elds. While the DISPLAY ARRAY statement is executing, 4GL ignores the INVISIBLE attribute.
4-104
DISPLAY ARRAY
"
keyword
"
Element keyword
Description is zero or one of the color attribute keywords, and zero or more of the intensity attribute keywords (except DIM, INVISIBLE, and NORMAL) from the syntax diagram of The ATTRIBUTE Clause on page 4-41.
The comma-separated list of attributes within the quoted string is applied to the current row of screen array. For example, the following specication displays screen array as in the previous example, but with the current row (the row that contains the screen cursor) in reverse video and green:
DISPLAY ARRAY p_items TO s_items.* ATTRIBUTE (RED, CURRENT ROW DISPLAY = "GREEN, REVERSE")
If the quoted string includes no keyword, an error is issued. If screen array has only one row, the CURRENT ROW DISPLAY attributes are applied to that row.
DISPLAY ARRAY
, (
key name ) statement EXIT DISPLAY
Description is one or more of these keywords, in uppercase or lowercase letters, separated by commas, to specify a key: ACCEPT DELETE DOWN ESC or ESCAPE F1 through F64 HELP INSERT INTERRUPT LEFT RIGHT NEXT or NEXTPAGE PREVIOUS or PREVPAGE RETURN TAB UP
For key name, you can substitute the NEXTPAGE keyword as a synonym for NEXT, and PREVPAGE as a synonym for PREVIOUS.
4GL executes the statements specied in the ON KEY block when the user presses one of the keys that you specify. 4GL deactivates the form while executing statements in an ON KEY block. After executing the statements, 4GL
re-activates the form, allowing the user to continue viewing the elds.
4-106
DISPLAY ARRAY
You can enter uppercase or lowercase key specications. The keys in the following table require special consideration before you reference them in an ON KEY clause.
Key
ESC or ESCAPE
Special Considerations Specify another key as the Accept key in the OPTIONS statement, because ESC is the default Accept key. You must execute a DEFER INTERRUPT statement, so that when the user presses the Interrupt key, 4GL executes the statements in the ON KEY clause and sets int_ag to nonzero for the current task, but does not terminate the DISPLAY ARRAY statement. 4GL also executes the statements in this ON KEY clause if the DEFER QUIT statement has executed and the user presses the Quit key. In this case, 4GL sets quit_ag to non-zero for the current task.
Interrupt
Quit
4GL reserves these keys for eld editing. If you specify these keys in the ON KEY clause, the key is trapped by 4GL to activate the ON KEY clause. The standard effect of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user. For example, if CONTROL-M appears in an ON KEY clause, the user cannot press RETURN to advance the cursor to the next eld.
You might not be able to use other keys that have special meaning to your version of the operating system. For example, CONTROL-C, CONTROL-Q, and CONTROL-S specify the Interrupt, XON, and XOFF signals on many systems. After executing the statements in the ON KEY block, 4GL resumes the display with the cursor in the same location as before the ON KEY block, unless it encounters EXIT DISPLAY within the block. (In this case, program execution resumes at the statement following the DISPLAY ARRAY statement.) The following ON KEY clause species two keys to display a help message:
ON KEY (f1, control-w) CALL customer_help()
DISPLAY ARRAY
Skips all subsequent statements between the EXIT DISPLAY keywords and the END DISPLAY keywords Resumes execution at the statement after the END DISPLAY keywords
For example, the EXIT DISPLAY statement terminates the following DISPLAY ARRAY statement if the user presses F5 and the value of amt_received in the current program array record is greater than 1000:
DISPLAY ARRAY p_receipts TO s_receipts.* ON KEY (F5) LET x = arr_curr() IF p_receipts[x].amt_received > 1000 THEN CALL get_allocation(p_receipts[x].receipt_num) EXIT DISPLAY END IF END DISPLAY
The DISPLAY ARRAY statement includes one or more ON KEY blocks. The DISPLAY ARRAY statement is specied in a form management block of a CONSTRUCT, INPUT, or INPUT ARRAY statement, and an ON KEY block of the enclosing statement follows the DISPLAY ARRAY statement. The DISPLAY ARRAY statement is specied within an ON KEY block in a PROMPT statement or in another DISPLAY ARRAY statement.
4-108
DISPLAY ARRAY
The following DISPLAY ARRAY statement must include the END DISPLAY keywords because it immediately precedes an ON KEY block that belongs to an INPUT statement:
INPUT BY NAME p_customer.* AFTER FIELD company ... DISPLAY ARRAY pa_array TO sc_array.* END DISPLAY ON KEY (CONTROL_B) ... END INPUT
Otherwise, it would be ambiguous whether the ON KEY block were part of the INPUT statement or part of the DISPLAY ARRAY statement. Here the END DISPLAY keywords are required because of the ON KEY clause:
DISPLAY ARRAY p_items TO s_items.*ON KEY (CONTROL_W) CALL get_help() END DISPLAY
These functions are described in Chapter 5 and are summarized here. You can use the following built-in functions to keep track of the relative states of the screen cursor, the program array, and the screen array.
Function ARR_CURR( ) Description Returns the number of the current record of the program array. This corresponds to the position of the screen cursor at the beginning of the ON KEY control block, not the line to which the screen cursor moves after execution of the block Returns the current number of records in the program array. Returns the number of the current line within the screen array. This number can be different from the value returned by ARR_CURR( ) if the program array is larger than the screen array. Takes the number of rows currently in the program array as an argument, and sets the initial value of ARR_COUNT( ).
ARR_COUNT( ) SCR_LINE( )
SET_COUNT( )
DISPLAY ARRAY
DISPLAY ARRAY also supports the following built-in functions and operators
FIELD_TOUCHED( ) Returns TRUE when the user has touched (made a change to) a screen eld whose name is passed as an operand. Moving the screen cursor through a eld (with the RETURN, TAB, or arrow keys) does not mark a eld as touched. GET_FLDBUF( ) FGL_GETKEY( ) FGL_LASTKEY( ) Returns the character values of the contents of one or more elds in the currently active form. Waits for a key to be pressed, and then returns an INTEGER corresponding to the raw value of the key that was pressed. Returns an INTEGER value corresponding to the most recent keystroke executed by the user while in the screen form. Returns TRUE if the name of the eld that is passed as its operand is the name of the current eld.
INFIELD( )
For more about these built-in 4GL functions and operators, see Chapter 5. Each eld in a form has only one eld buffer, and a buffer cannot be used by two different statements simultaneously. If you plan to display the same form with data entry elds more than once, you can open a new 4GL window, and then open and display in it a second copy of the form. 4GL allocates a separate set of buffers to each form, and you can be certain that your program is retrieving the correct eld values.
4-110
DISPLAY ARRAY
F3
F4
By default, the Accept, Interrupt, and Quit keys terminate the DISPLAY ARRAY statement. Each of these actions also deactivates the form. (But pressing the Interrupt or Quit key can immediately terminate the program, unless the program also includes the DEFER INTERRUPT and DEFER QUIT statements.)
INFORMIX-4GL Statements 4-111
DISPLAY ARRAY
If 4GL previously executed a DEFER INTERRUPT statement in the program, pressing the Interrupt key causes 4GL to take the following actions:
1. 2.
Set the global variable int_ag to a nonzero value. Terminate the DISPLAY ARRAY statement but not the 4GL program.
If 4GL previously executed a DEFER QUIT statement in the program, pressing the Quit key causes 4GL to take the following actions:
1. 2.
Set the global variable quit_ag to a nonzero value. Terminate the DISPLAY ARRAY statement but not the 4GL program.
The following program fragment displays a program array p_customer in the elds of a screen array called s_customer:
OPEN FORM f_customer FROM "f_customer" DISPLAY FORM f_customer ... DECLARE c_custs CURSOR FOR SELECT customer_num, company FROM customer WHERE state = "CA" LET counter = 1 FOREACH c_custs INTO p_customers[counter].* LET counter = counter + 1 END FOREACH ... CALL SET_COUNT(counter - 1) DISPLAY ARRAY p_customers TO s_customers.*
References
ATTRIBUTE, DISPLAY, INPUT ARRAY, OPEN WINDOW, OPTIONS, SCROLL
4-112
DISPLAY FORM
DISPLAY FORM
The DISPLAY FORM statement displays a compiled 4GL screen form.
DISPLAY FORM form ATTRIBUTE Clause p. 3-96
Element form
Usage
Before you can use a compiled form, you must take these steps:
1. 2.
Use OPEN FORM to declare the name of the form. Use DISPLAY FORM to display the form on the screen.
The form name species which screen form to display. DISPLAY FORM is not required if you display a form by using the WITH FORM option of the OPEN WINDOW statement (see The WITH FORM Clause on page 4-283). An error occurs if the current 4GL window is too small to display the form.
Form Attributes
The DISPLAY FORM statement ignores the INVISIBLE attribute. 4GL applies any other display attributes that you specify in the ATTRIBUTE clause to any elds that have not been assigned attributes by the ATTRIBUTES section of the form specication le, or by the syscolatt table, or by the OPTIONS statement. If the form is displayed in a 4GL window, color attributes from the DISPLAY FORM statement supersede any from the OPEN WINDOW statement. If subsequent CONSTRUCT, DISPLAY, or DISPLAY ARRAY statements that include an ATTRIBUTE clause reference the form, however, their attributes take precedence over those specied in the DISPLAY FORM statement.
DISPLAY FORM
Reserved Lines
DISPLAY FORM displays the specied form in the current 4GL window, or in the 4GL screen itself, if no other 4GL window is open.
The form begins in the line that was indicated by the FORM LINE specication of the OPEN WINDOW or OPTIONS statement. This specication positions the rst line of the form relative to the top of the current 4GL window. If you provided no FORM LINE specication, the default Form line is 3. On a default screen display, the reserved lines are positioned as follows.
Default Location First line Second line Third line Second-to-last line Last line Reserved for Prompt line (output from PROMPT statement); also Menu line (command value from MENU statement) Message line (output from MESSAGE statement; also the description value output from MENU statement) Form line (output from DISPLAY FORM statement) Comment line (output from COMMENT attribute) when SCREEN is the current 4GL window Error line (output from ERROR statement); also Comment line in any 4GL window except SCREEN
For example, the following statements display the cust_form form in the 4GL screen (or in the current 4GL window):
OPEN FORM cust_form FROM "customer" DISPLAY FORM cust_form
The OPTIONS statement can change the default position of all the reserved lines, including that of the Form line, for all 4GL windows, including the entire 4GL screen (specied as SCREEN). You can also reposition the Form line for a specic 4GL window only, by using an ATTRIBUTE clause in the OPEN WINDOW statement. The following statements make line 6 the Form line for all 4GL windows, and then displays cust_form:
OPTIONS FORM LINE 6 OPEN FORM cust_for FROM "customer" DISPLAY FORM cust_form
4-114
DISPLAY FORM
References
CLEAR, CLOSE FORM, OPEN FORM, OPEN WINDOW, OPTIONS
END
END
The END keyword marks the end of a compound 4GL statement.
END keyword
Element keyword
Description is a keyword that species the name of the 4GL statement to be delimited, from among the keywords listed in this section.
Usage
The END keyword marks the last line of a compound 4GL statement. This is a compile-time indicator of the end of the statement construct. (Use the EXIT keyword, rather than END, to terminate execution of a compound statement.) The following compound statements of 4GL support END keywords to mark the end of the statement construct within the source module.
CASE CONSTRUCT DISPLAY ARRAY FOR FOREACH FUNCTION GLOBALS IF INPUT INPUT ARRAY MAIN MENU PROMPT REPORT SQL WHILE
The END DISPLAY keywords delimit the DISPLAY ARRAY statement, and END INPUT delimits both INPUT and INPUT ARRAY. Unlike EXIT statement clauses, no more than one END statement clause can appear within the specied statement, but most compound statements of 4GL can be nested. This statement fragment uses END MENU to delimit a MENU statement:
MENU "MAIN" ... END MENU
The END keyword can also delimit RECORD declarations (as described in RECORD Variables on page 4-88).
4-116
END
References
CASE, DISPLAY ARRAY, FOR, FOREACH, FUNCTION, GLOBALS, IF, INPUT, INPUT ARRAY, MAIN, MENU, PROMPT, REPORT, SQL, WHILE
ERROR
ERROR
The ERROR statement displays an error message on the Error line and rings the terminal bell. ,
ERROR
"string"
variable Character Expression p. 3-69 ATTRIBUTE Clause p. 3-96
Description is a quoted string no longer than the number of characters that the Error line of the current 4GL window can display. is the name of a CHAR or VARCHAR variable whose contents are to be displayed on the Error line of the 4GL screen.
Usage
The string or variable value species all or part of the text of a screen message to be displayed on the Error line. You can specify any combination of character variables and literal character strings for the message. 4GL generates the message to display by replacing any variables with their values, and concatenating the returned strings. The total length of this message must not be greater than the number of characters that the Error line can display in a single line of the 4GL screen. The message text remains on the screen until the user presses the next key.
ERROR
The position of the Error line is determined by the most recently executed ERROR LINE specication in the OPTIONS statement. Otherwise, the default Error line position is the last line of the screen. Because the Error line is positioned relative to the screen, rather than to the current window, you cannot use the OPEN WINDOW statement to reposition the Error line. See Reserved Lines on page 4-114 for more information about the Error line and its relationship to the other reserved lines of 4GL. You can use the CLIPPED and USING operators in the ERROR statement, as illustrated in the following examples:
ERROR p_orders.order_num USING "#####", " is not valid." ERROR pattern CLIPPED, " has no match."
You can also use the ASCII and COLUMN operators, and other features of 4GL character expressions. (For more information on the built-in functions and operators of 4GL, see Chapter 5.)
If the terminal supports color, then 4GL displays this error message in red, blinking, reverse video. If the terminal screen is monochrome, then 4GL displays the error message in bold, blinking, reverse video. The next example species BLUE and BLINK attributes for the ERROR text:
ERROR "Unable to insert items" ATTRIBUTE(BLUE, BLINK)
ERROR
References
DISPLAY, MESSAGE, OPTIONS, PROMPT, WHENEVER
4-120
EXIT
EXIT
The EXIT statement transfers control out of a control structure (a block, a loop, a CASE statement, an interface statement) or out of the program itself.
Case I: (terminating a program)
EXIT PROGRAM
(
Case II: (terminating a statement)
keyword
Description is an integer expression. For a description of this term, see The Exit Code Value on page 4-123. is a keyword that species the current statement from which control of execution is to be transferred, from among those in the list that appears later in this section.
Usage
The EXIT PROGRAM statement terminates the program that is currently executing. Other forms of EXIT transfer control from the current control structure to whatever statement follows the corresponding END keyword keywords.
EXIT
Here EXIT DISPLAY exits from DISPLAY ARRAY (but not DISPLAY) statements, and EXIT INPUT can exit from both INPUT ARRAY and INPUT statements. Unlike EXIT PROGRAM, these other EXIT statements can only appear within the specied statement. For example, EXIT FOR can occur only in a FOR loop; if it is executed, it transfers control to the statement following the END FOR keywords that mark the end of that FOR statement. Similarly, EXIT MENU can appear only within a control block of a MENU statement, where it transfers control to the rst statement that follows the END MENU keywords of the same MENU statement.
Leaving a Function
The RETURN statement exits from a FUNCTION denition. There is no EXIT PROGRAM statement, because RETURN supports this functionality (and can also pass zero or more values from the FUNCTION program block to the calling statement). You cannot use the GO TO or WHENEVER GO TO statements to transfer control of execution from the currently executing function. (These statements can only transfer control within the same program block.)
Leaving a Report
The EXIT REPORT statement exits from a REPORT denition. An error is issued if RETURN is encountered within a REPORT denition. Unlike a function, a report does not return anything to the calling routine, but a report normally sends formatted output to some specied destination. Within the report driver, you can terminate processing of a report by executing the FINISH REPORT or TERMINATE REPORT statements. You cannot use the GO TO or WHENEVER GO TO statements to transfer control of execution from the currently executing report. (These statements can only transfer control within the same program block.)
4-122
EXIT
If 4GL encounters the END MAIN keywords in the MAIN block, END MAIN terminates the program, as if you had specied EXIT PROGRAM (0). If you are using the INFORMIX-4GL Interactive Debugger, a program that EXIT PROGRAM terminates can be examined subsequently by the WHERE or STACK commands of the Debugger, as if an abnormal termination had occurred.
The low byte contains the termination status of whatever RUN executes. You can recover this by calculating the value of (integer value modulo 256). The high byte contains the low byte from the EXIT PROGRAM statement of the 4GL program that RUN executes. You can recover this returned code by dividing integer value by 256.
See The RETURNING Clause on page 4-341 for an example of using RUN and EXIT PROGRAM to examine termination status and exit codes from 4GL programs that RUN invoked and EXIT PROGRAM terminated.
INFORMIX-4GL Statements 4-123
EXIT
References
CONTINUE, END, GOTO, LABEL, MAIN, RETURN, RUN
4-124
FINISH REPORT
FINISH REPORT
The FINISH REPORT statement completes processing of a 4GL report.
FINISH REPORT report
Element report
Usage
This statement indicates the end of a report driver and complete processing of the report. (For more information, see The Report Driver on page 7-5.) FINISH REPORT must follow a START REPORT statement and at least one OUTPUT TO REPORT statement that reference the same report. If the REPORT denition includes an ORDER BY section with no EXTERNAL keyword, or species aggregates based on all the input records, 4GL makes two passes through the input records. During the rst pass, it uses the database server to sort the data, and then stores the sorted values in a temporary le. During the second pass, it calculates any aggregate values, and produces output from data in the temporary les. For more information, see The EXTERNAL Keyword on page 7-27 and Aggregate Report Functions on page 7-60. The FINISH REPORT statement performs the following actions:
s
Completes the second pass, if report is a two-pass report. These second pass activities handle the calculation and output of any aggregate values that are based on all the input records in the report, such as COUNT(*) or PERCENT(*) with no GROUP qualier. Executes any AFTER GROUP OF control blocks (described in Chapter 7, INFORMIX-4GL Reports). Executes any PAGE HEADER, ON LAST ROW, and PAGE TRAILER control blocks to complete the report, as described in Chapter 7.
FINISH REPORT
Copies data from the output buffers of the report to the destination in START REPORT or in the OUTPUT section of the report denition. If no destination is specied, output goes to the Report window (as described in Sending Report Output to the Screen on page 7-19). Closes the Select cursor on any temporary table that was created to order the input records or to perform aggregate calculations. Deallocates memory for local BYTE or TEXT variables of the report. Terminates processing of the 4GL report, and deletes from the database any les that held temporary tables for a two-pass report.
s s
The following program creates a report based on data in the orders table:
DATABASE stores7 MAIN DEFINE p_orders RECORD LIKE orders.* DECLARE q_ordcurs CURSOR FOR SELECT * FROM orders START REPORT ord_list TO "ord_listing" FOREACH q_ordcurs INTO p_orders OUTPUT TO REPORT ord_list(p_orders) END FOREACH FINISH REPORT ord_list END MAIN REPORT ord_list(r_orders) DEFINE r_orders RECORD LIKE orders.* FORMAT EVERY ROW END REPORT
The temporary tables that 4GL reports use for sorting input records or for calculating aggregates in two-pass reports are stored in the current database. If you do not open any database, or if the CLOSE DATABASE statement closes the current database, then a runtime error occurs when 4GL cannot create or access the temporary tables that are required for a two-pass report. Similarly, the FINISH REPORT statement cannot access temporary tables in more than one database. An error can occur if the DATABASE statement opens a different database while a two-pass 4GL report is being processed. The following program fragment, for example, produces a runtime error if the produce report requires two passes:
DATABASE apples . . . START REPORT produce --database is apples . . . OUTPUT TO REPORT produce(input_rex) . . . DATABASE oranges --new database is oranges FINISH REPORT produce --cannot access files in apples database
4-126
FINISH REPORT
References
OUTPUT TO REPORT, REPORT, START REPORT, TERMINATE REPORT
FOR
FOR
The FOR statement executes a statement block a specied number of times.
FOR
counter
start TO nish
END FOR
STEP increment
EXIT FOR
Description is a variable of type INTEGER or SMALLINT that serves as an index for the statement block. is an integer expression to specify an upper limit for counter. is an integer expression whose value is added to counter after each iteration of the statement block. is an integer expression to set an initial counter value. is an SQL statement or other 4GL statement. (This statement block is sometimes called the FOR loop.)
Usage
The FOR statement executes the statements up to the END FOR statement a specied number of times, or until EXIT FOR terminates the FOR statement. (Use the WHILE statement, rather than FOR, if you cannot specify an upper limit on how many times the program needs to repeat a statement block, but you can specify a Boolean condition for leaving the block.)
The TO Clause
4GL maintains an internal counter, whose value changes on each pass through
the statement block. On the rst iteration through the loop, this counter is set to the initial expression at the left of the TO keyword. Thereafter, the value of the increment expression in the STEP clause specication (or by default, 1) is added to counter in each pass through the block of statements.
4-128
FOR
When the sign of the difference between the values of counter and the nish expression at the right of the TO keyword changes, 4GL exits from the FOR loop. Execution resumes at the statement following the END FOR keywords. For example, this statement clears four records of the s_items screen array:
FOR counter = 1 TO 4 CLEAR s_items[counter].* END FOR
The FOR loop terminates after the iteration for which the left- and right-hand expressions are equal. If either returns NULL, the loop cannot terminate, because here the Boolean expression "left = right" cannot become TRUE.
If you use a negative STEP value, specify the second expression in the TO clause as smaller than the rst value in the range. Before processing the block of statements, 4GL rst tests the counter value against the terminating value. For example, if the STEP value is positive and the counter value is greater than the last value in the range, 4GL skips over the statements in the loop without executing them.
Skips the remaining statements between the CONTINUE FOR and END FOR keywords Increments the counter variable and tests it If the counter does not exceed the nal value, goes back to the beginning of the loop and performs another iteration; otherwise, continues execution after the END FOR keywords
INFORMIX-4GL Statements 4-129
s s
FOR
It might be difcult to determine the extent to which the integrity of the database has been compromised. If the database has been corrupted, it might be difcult to restore it to its condition prior to the execution of the FOR loop.
The same data integrity considerations also apply to FOREACH and WHILE loops that include SQL statements in 4GL programs. (See the Informix Guide to SQL: Tutorial for more information about the SQL concepts and statements that support data integrity through transactions.)
References
CONTINUE, FOREACH, WHILE
4-130
FOREACH
FOREACH
The FOREACH statement applies a series of actions to each row of data that is returned from a query by a cursor.
FOREACH
cursor
statement
END FOREACH
USING
Variable List
INTO
Variable List
WITH REOPTIMIZATION
Variable List
,
Variable p. 3-57
.
record
.* . rst
THROUGH THRU record . last
Description is the name of a previously declared SQL cursor. is the name of a member variable in which to store a value. is a member of record that was declared later than rst. is the name of a variable of the RECORD data type. is an SQL statement or other 4GL statement.
FOREACH
Usage
Use the FOREACH statement to retrieve and process database rows that were selected by a query. The FOREACH statement is equivalent to using the OPEN, FETCH, and CLOSE statements. The FOREACH statement has these effects:
1. 2. 3.
Opens the specied cursor Fetches the rows selected Closes the cursor (after the last row has been fetched)
You must declare the cursor (by using the DECLARE statement) before the FOREACH statement can retrieve the rows. A compile-time error occurs unless the cursor was declared prior to this point in the source module. You can reference a sequential cursor, a scroll cursor, a hold cursor, or an update cursor, but FOREACH only processes rows in sequential order. The FOREACH statement performs successive fetches until all rows specied by the SELECT statement are retrieved. Then the cursor is automatically closed. It is also closed if a WHENEVER NOT FOUND statement within the FOREACH loop detects a NOTFOUND condition (that is, status = 100). Implicit FETCH statements that FOREACH executes with a FOR UPDATE cursor can support promotable locks. (See the Informix Guide to SQL: Syntax.) The following topics are described in this section:
s s s s s s
Cursor Names on page 133 The USING Clause on page 4-134 The INTO Clause on page 4-134 The WITH REOPTIMIZATION Keywords on page 4-135 The FOREACH Statement Block on page 4-136 The END FOREACH Keywords on page 4-138
4-132
FOREACH
Cursor Names
You must follow the FOREACH keyword with a cursor name that a DECLARE statement declared earlier in the same module. A runtime error can occur if the FOREACH statement does not specify a previously declared cursor. The next example fetches values retrieved by the c_orders cursor. For each retrieved row, 4GL increments the counter variable by 1, invokes a function called scan( ), and passes the values of ord_num, cust_num, and comp. If the query does not return any rows, 4GL ignores the FOREACH loop and resumes processing with the statement that immediately follows the END FOREACH keywords. This IF statement examines the counter variable, and displays a message on the Error line if the query returns no rows.
PROMPT "Enter cut-off date for orders: " FOR o_date DECLARE c_orders CURSOR FOR SELECT order_num, orders.customer.num, company INTO ord_num, cust_num, comp FROM orders o, customer c WHERE o.customer_num = c.customer_num AND order_date < o_date LET counter = 1 FOREACH c_orders LET counter = counter + 1 CALL scan(ord_num, cust_num, comp) END FOREACH IF counter = 0 THEN ERROR "No orders before ", o_date END IF
FOREACH internally generates an OPEN statement, a FETCH loop (which normally exits when NOTFOUND is returned), and a CLOSE statement. If a FETCH returns an error other than NOTFOUND (error 100, the normal end-ofdata indication) and WHENEVER ERROR GOTO is in effect, the implicit CLOSE statement is not executed. (Also, if you use WHENEVER ERROR CALL and the
called function terminates the program, the cursor is not closed before entering the called function.) If you use WHENEVER ERROR GOTO to resume execution elsewhere in the program, the cursor might remain open and would need to be explicitly closed. Because the internally generated CLOSE statement can change the values in the SQLCA structure, the value of SQLCA.SQLERRD[3] after the END FOREACH keywords are encountered does not represent the number of rows fetched by the FOREACH. If you need to know the number of rows fetched, you must maintain your own row counter.
FOREACH
The USING clause is required only if the cursor expects user-supplied values to replace question (?) mark placeholders. Just as with the OPEN statement of SQL, the number and data types of placeholders in the prepared SELECT statement must correspond exactly to the number and data types of the variables in the USING clause. If both the USING and INTO clauses are used, the USING clause must precede the INTO clause. (In embedded EXECUTE statements of SQL, however, 4GL supports both the EXECUTEINTOUSING and EXECUTEUSINGINTO sequences of clauses, as a convenience to the programmer.)
The number and order of variables in the INTO clause must match the number and order of the columns in the active set of rows that are retrieved by the cursor, and must be of compatible data types.
4-134
FOREACH
For example, the following FOREACH statement stores the retrieved rows in the p_items program array:
LET counter = 1 FOREACH my_curs INTO p_items[counter].* LET counter = counter + 1 IF counter > 10 THEN CALL mess ("Ten or more items.") EXIT FOREACH END IF END FOREACH
You can include the INTO clause in the SELECT statement associated with the cursor, or in the FOREACH statement, but not in both. To retrieve rows into a program array, however, you must place the INTO clause in the FOREACH statement, rather than in the SELECT-statement of a DECLARE statement.
FOREACH
Element statement
This block is sometimes called the FOREACH loop. If the cursor returns no rows, then no statements in this loop are executed, and program control passes to the rst statement that follows the END FOREACH keywords. If the specied cursor is FOR UPDATE, the statement block can include statements to modify retrieved rows. See the Informix Guide to SQL: Syntax.
It might be difcult to determine the extent to which the integrity of the database has been compromised. If the database has been corrupted, it might be difcult to restore it to its condition prior to the execution of the FOREACH loop.
These considerations apply to FOR and WHILE loops that can change the database. (See Informix Guide to SQL: Tutorial for information about the SQL concepts and statements that support data integrity through transactions.)
4-136
FOREACH
If your database has transactions and the cursor was declared by DECLARE FOR UPDATE but not DECLARE WITH HOLD, the FOREACH statement must be executed within a transaction. (You can open an update cursor that was declared with a DECLARE WITH HOLD via a FOREACH statement outside a transaction, but you cannot roll back any changes that the cursor performs outside the transaction. In this situation, each UPDATE WHERE CURRENT OF is automatically committed as a singleton transaction.)
FOREACH
The next example creates a cursor c_query, based on search criteria entered by the user. For each row retrieved by the SELECT statement of the cursor, this example displays the row on the screen and waits for the user to request the next row. If no rows are selected, then 4GL displays a message.
DEFINE stmt1, query1 CHAR(300), p_customer RECORD LIKE customer.* CONSTRUCT BY NAME query1 ON customer.* LET stmt1 = "SELECT * FROM customer ", "WHERE ", query1 CLIPPED PREPARE stmt_1 FROM stmt1 DECLARE c_query CURSOR FOR stmt_1 LET exist = 0 FOREACH c_query INTO p_customer.* LET exist = 1 DISPLAY BY NAME p_customer.* PROMPT "Do you want to see the next customer (y/n): " FOR answer IF answer MATCHES "[Nn]" THEN
4-138
FOREACH
EXIT FOREACH END IF END FOREACH IF exist = 0 THEN MESSAGE "No rows found." END IF
If a query returns no rows, then none of the statements in the FOREACH block is executed, and program control passes immediately to the rst statement following END FOREACH. If you need to know whether any rows were returned, you can set up a ag or a counter as in the example that follows:
PROMPT "Enter cut-off date for query: "FOR o_date DECLARE q_curs CURSOR FOR SELECT order_num, o.customer_num, company FROM orders o, customer c WHERE o.customer_num = c.customer_num AND order_date < o_date LET counter = 0 FOREACH q_curs INTO ord_num, cust_num, comp LET counter = counter + 1 CALL scan (ord_num, cust_num, comp) END FOREACH IF counter = 0 THEN ERROR "No orders before ", o_date END IF
References
CONTINUE, FETCH, FOR, OPEN, WHILE, WHENEVER
FUNCTION
FUNCTION
The FUNCTION statement denes a FUNCTION program block.
FUNCTION Prototype p. 4-141 FUNCTION Program Block p. 4-142
FUNCTION
END FUNCTION
Usage
As Chapter 5 explains, a 4GL function is a named block of statements. The FUNCTION statement denes a 4GL function that can be invoked from any module of your program. The FUNCTION statement has two effects:
s
It declares the name of a function and any formal arguments. 4GL imposes no limit on the number or size of formal arguments. It denes the corresponding FUNCTION program block.
The FUNCTION statement cannot appear within the MAIN statement, in a REPORT statement, nor within another FUNCTION statement. If the function returns a single value, it can be invoked as an operand within a 4GL expression (as described in Function Calls as Operands on page 3-58). Otherwise, you must invoke it with the CALL statement. An error results if the list of returned values in the RETURN statement conicts in number or in data type with the RETURNING clause of the CALL statement that invokes the function (as described in The RETURNING Clause on page 4-19). The following topics are described in this section:
s s s s s s s
The Prototype of the Function on page 4-141 The FUNCTION Program Block on page 4-142 Executable Statements on page 4-142 Data Type Declarations on page 4-143 The Function as a Local Scope of Reference on page 4-143 Returning Values to the Calling Routine on page 4-144 The END FUNCTION Keywords on page 4-144
4-140
FUNCTION
, (
argument )
Element argument
Description is the name of a formal argument to this function. This can be of any data type except ARRAY. (See Declaring the Names and Data Types of Variables on page 4-84 and ARRAY Variables on page 4-87.) is the identier that you declare for this 4GL function.
function
FUNCTION
Element statement
Description is any SQL statement or other 4GL statement (but not GLOBALS, DEFINE, DEFER, MAIN, FUNCTION, REPORT, EXIT REPORT, NEED, PAUSE, PRINT, nor SKIP).
You can dene a function whose statement block is empty. This enables you to test other parts of a program before a function denition is written.
Executable Statements
Any executable statements in the statement block are executed when the function is called. Here is a simple example of a function denition:
FUNCTION state_abbrev(state) DEFINE st LIKE state.code, state LIKE state.sname SELECT state.code INTO st FROM state WHERE state.sname MATCHES state RETURN st END FUNCTION
SELECT is an executable SQL statement. RETURN returns control (and the value of st) to the calling routine. END FUNCTION marks the end of the program block.
4-142
FUNCTION
Here DEFINE and END FUNCTION are not executable statements, but they are needed to declare the formal argument and another local variable, and to delimit the function denition.
FUNCTION
Any global or module variable that has the same identier as a local variable, however, is not visible within the scope of the local variable. For information about using the LIKE keyword during compilation to declare the data types of local variables indirectly, see the description of the DATABASE statement (in The Default Database at Compile Time on page 4-73) . You can also use DATABASE within a FUNCTION denition to specify a new current database at runtime (as described in The Current Database at Runtime on page 4-74). Any GOTO or WHENEVERGOTO statement in a function must reference a statement label (described in LABEL on page 4-224) within the same FUNCTION program block.
References
CALL, DEFINE, RETURN, WHENEVER 4-144 IBM Informix 4GL Reference Manual
GLOBALS
GLOBALS
The GLOBALS statement declares modular variables that can be exported to other program modules. It can also import variables from other modules.
Case I: (declaring and exporting variables)
,
GLOBALS DEFINE Statement p. 4-81 END GLOBALS
"lename.4gl"
Element lename Description is a quoted string that species the name of a le that contains the GLOBALSEND GLOBALS statement (and optionally the DATABASE statement) but no executable statements. The lename can include a pathname. The .4gl le extension is required.
Usage
In general, a program variable is in scope only in the same FUNCTION, MAIN, or REPORT program block in which it was declared. To make its scope of reference the entire source module, you must specify a modular declaration, by locating the DEFINE statement outside of any program block. To extend the visibility of one or more module variables beyond the source module in which they are declared, you must take the following steps:
s
Declare variables in GLOBALSEND GLOBALS declarations (in les containing only GLOBALS, DEFINE, and DATABASE statements). Specify the les in GLOBALS lename statements in each additional source module that includes statements referencing the variables.
GLOBALS
These les must also be compiled and linked with the 4GL application. (Earlier 4GL releases permitted no more than one GLOBALSEND GLOBALS statement, but the number of globals les is now unrestricted.)
4-146
GLOBALS
LET idx = ARR_CURR() CLOSE WINDOW w_state LET p_customer.state = p_state[idx].code DISPLAY BY NAME p_customer.state RETURN END FUNCTION
GLOBALS lename statements cannot reference this le because it includes executable statements (besides GLOBALS, DEFINE, and DATABASE).
A compile-time error would occur if you declared a 4GL variable of modular scope called fty, p_customer, p_state, or state_cnt in the same module as this GLOBALS statement. If you want, however, you can declare local variables whose names match those of variables from GLOBALS declarations. Although you can include multiple GLOBALS ... END GLOBALS statements in the same 4GL application, do not declare the same identier as the name of a variable within the DEFINE statements of more than one GLOBALS declaration. Even if several declarations of a global variable dened in multiple places are identical, declaring any global variable more than once can result in compilation errors, or in unpredictable runtime behavior. The GLOBALS lename statement must occur earlier in every le than any function that makes reference to a global variable. Within its source code le, the GLOBALS statement must be outside the MAIN program block (and also outside any FUNCTION or REPORT denition).
GLOBALS
If necessary, a DATABASE statement This is required only if you use the LIKE keyword in the DEFINE declaration. If present, the DATABASE statement must precede the GLOBALS statement. For the syntax of LIKE in declarations of variables, see Indirect Typing on page 4-83.
The GLOBALS keyword, followed by as many DEFINE statements as necessary to declare your global variables You cannot include any DEFINE statements if the GLOBALS lename statement is used only to apply a DATABASE statement to several modules.
2.
In any other module of the program that includes statements referencing the global variables, include a GLOBALS lename statement before the rst MAIN, FUNCTION, or REPORT program block. To import global variables, you specify the lename of the globals le, but do not include the END GLOBALS keywords.
These two steps correspond, respectively, to Case I and Case II in the syntax diagram at the beginning of this section. For example, the globals le d4_glob.4gl in the stores7 demonstration application includes the following DATABASE and GLOBALS statements:
DATABASE stores7 GLOBALS DEFINE p_customer RECORD LIKE customer.*, p_orders RECORD order_num LIKE orders.order_num, order_date LIKE orders.order_date, po_num LIKE orders.po_num, ship_instruct LIKE orders.ship_instruct END RECORD, p_items ARRAY[10] OF RECORD item_num LIKE items.item_num, stock_num LIKE items.stock_num, manu_code LIKE items.manu_code, description LIKE stock.description, quantity LIKE items.quantity, unit_price LIKE stock.unit_price, total_price LIKE items.total_price
4-148
GLOBALS
END RECORD, p_stock ARRAY[30] OF RECORD stock_num LIKE stock.stock_num, manu_code LIKE manufact.manu_code, manu_name LIKE manufact.manu_name, description LIKE stock.description, unit_price LIKE stock.unit_price, unit_descr LIKE stock.unit_descr END RECORD, p_state ARRAY[fifty] OF RECORD LIKE state.*, fifty, state_cnt, stock_cnt INTEGER, print_option CHAR(1) END GLOBALS
The next program fragment include a GLOBALS statement that species d4_glob.4gl as the globals le that declares global variables:
GLOBALS "d4_glob.4gl" MAIN DEFER INTERRUPT ... CALL get_states() CALL get_stocks() ... END MAIN
Here the database specied by the DATABASE statement in the globals le is both the default database at compile time and the current database at runtime, because the GLOBALS "d4_glob.4gl" statement includes the DATABASE statement before the MAIN program block. (For more information, see The Default Database at Compile Time on page 4-73 and The Current Database at Runtime on page 4-74.) If a local variable has the same name as another variable that you declare in the GLOBALS statement, only the local variable is visible within its scope of reference. Similarly, a modular variable takes precedence in the module where it is declared over any variable of the same name whose declaration is in the lename referenced by a GLOBALS statement. (A compile-time error occurs if you declare another module variable with the same identier as another variable that the GLOBALSEND GLOBALS statement declares in the same module.) For more information about the scope and visibility of 4GL identiers, see 4GL Identiers on page 2-14.
4GL does not check for the name conicts between global variables and
system function calls. To avoid errors at runtime, do not use system function names such as read( ), open( ), or stat( ), as identiers of global variables.
GLOBALS
References
DATABASE, DEFINE, FUNCTION, INCLUDE, MAIN, REPORT
4-150
GOTO
GOTO
The GOTO statement transfers program control to a labeled line within the same program block.
GOTO label
:
Element label Description is a statement label that you declare in a LABEL statement.
Usage
The GOTO statement transfers control of execution within a program block. Upon encountering this statement, 4GL jumps to the statement immediately following the specied LABEL statement, and resumes execution there, skipping any intervening statements that lexically follow the GOTO statement. These rules apply to the use of the GOTO and LABEL statements:
s
To transfer control to a labeled line, the GOTO statement must use the same label name as the LABEL statement above the desired line. Both statements must be in the same MAIN, FUNCTION, or REPORT block. GOTO cannot transfer control into or out of a program block.
Excessive use of GOTO statements in 4GL (or any programming language) can make your code difcult to read or to maintain, or can result in a loop that has no termination. Many situations in which you need to transfer control of program execution can be solved by using one of the following alternatives to the GOTO statement:
s s s
Boolean expressions and the CASE, FOR, IF, and WHILE statements The CALL, OUTPUT TO REPORT, or WHENEVER statement The EXIT keyword in blocks within the following statements:
CASE CONSTRUCT DISPLAY ARRAY
GOTO
MENU WHILE
It is convenient to use the GOTO and LABEL statements in some situations; for example, to exit from deeply nested code:
FOR i = 1 TO 10 FOR j = 1 TO 20 FOR k = 1 To 30 ... IF pa_array3d[i,j,k] IS NULL THEN GOTO :done ELSE ... END IF ... END FOR END FOR END FOR LABEL done: ERROR "Cannot complete processing." ROLLBACK WORK
More important than avoiding the GOTO statement, however, is to adhere to the design principle that any block of statements (such as a function or a loop) have only one entry point and one exit point, as in this program fragment:
CALL do_things(value) --invokes a FUNCTION block ... FUNCTION do_things(arglist)--unique entry point ... IF (exit_condition) THEN GOTO :outofhere --jump within same program block END IF ... LABEL outofhere: CALL clean_up() RETURN ret_code --unique exit point END FUNCTION --marks end of FUNCTION construct
You can optionally place a colon before label name in the GOTO statement. This conforms to the ANSI/ISO standard for embedded SQL syntax.
References
CASE, FOR, IF, FOR, FUNCTION, LABEL, MAIN, REPORT, WHENEVER, WHILE 4-152 IBM Informix 4GL Reference Manual
IF
IF
The IF statement executes a group of statements conditionally. It can switch program control conditionally between two blocks of statements.
Boolean Boolean Expression expression p. 3-60
IF
THEN
statement
Element statement
Usage
If the Boolean expression is TRUE, then 4GL executes the block of statements following the THEN keyword, until it reaches either the ELSE keyword or the END IF keywords. 4GL then resumes execution after the END IF keywords. If the Boolean expression is FALSE, 4GL executes the block of statements between the ELSE keyword and the END IF statement. If ELSE is absent, execution after the END IF keywords. The Boolean expression returns FALSE if it contains a NULL value (except as the operand of the IS NULL operator). You can nest IF statements up to a limit (around 20) that also depends on the number of FOR and WHILE loops. If nested IF statements all test the same value, consider using the CASE statement. In the next example, if the value of direction matches the string "BACK", 4GL decrements p_index by one. If direction matches the string "FORWARD", 4GL increments p_index by one.
direction = "BACK" THEN LET p_index = p_index - 1 DISPLAY dp_stock[p_index].* TO s_stock.* ELSE IF direction = "FORWARD" THEN LET p_index = p_index + 1 DISPLAY dp_stock[p_index].* TO s_stock.* END IF END IF IF
IF
References
CASE, FOR, WHENEVER, WHILE
4-154
INITIALIZE
INITIALIZE
The INITIALIZE statement assigns initial NULL or default values to variables. ,
INITIALIZE Variable List LIKE Table Qualier p. 3-89 TO NULL Variable List variable . record table
.column .*
.* . rst ,
Integer Expression p. 3-63 THROUGH THRU record . last
array
Description is the name of a variable of the ARRAY data type. is the name of a column of table for which a DEFAULT value exists. is the name of a member variable to be initialized. is another member of record that was declared later than rst. is the name of a variable of the RECORD data type. is the name or synonym of the table or view that contains column. is the name of a variable of a simple data type.
INITIALIZE
Usage
After you declare a variable with a DEFINE statement, the compiler allocates memory to that variable. The contents of the variable, however, is whatever occupies that memory location.
INITIALIZE can specify initial values for 4GL variables in either of two ways:
s
The LIKE keyword assigns the default values of a specied database column, using default values from the syscolval table. You can use the TO NULL keywords to assign NULL values, using the representation of NULL for the declared data type of each variable.
The table.* notation species every column in the specied table. If tab1 has only the three columns (col1, col2, and col3), the following statement is equivalent to the previous one:
INITIALIZE ANSI v_cust.* LIKE customer.*
In an ANSI-compliant database, you must qualify each table name with that of its owner (owner. table), if the application will be run by a user who does not own the table. For example, if you own tab1, and Lydia owns tab2, and Boris owns tab3, the following statement is valid:
INITIALIZE var1, var2, var3 LIKE tab1.var1, lydia.tab2.var2, boris.tab3.var3
4-156
INITIALIZE
You can include the owner name as a prex in a database that is not ANSIcompliant, but if the owner name that you specify is incorrect, you receive an error. For additional information, see the Informix Guide to SQL: Syntax. The INITIALIZE statement looks up the default values for database columns in the DEFAULT column of the syscolval table in the default database. Any changes to syscolval after compilation have no effect on the 4GL program, unless you recompile the program. To enter default values in this table, use the upscol utility, as described in Appendix B. If a column has no default value in the syscolval table, 4GL assigns NULL values to any variables initialized from that column. If the database is not ANSI-compliant, upscol creates a single syscolval table.
ANSI
In an ANSI-compliant database, each user can create an owner.syscolval table, which sets the default values only for the tables owned by that user. If you omit the owner of the table and you own the table, your syscolval table becomes the source for the defaults when you compile the program. If the owner.syscolval table does not exist, the LIKE clause of the INITIALIZE statement sets the values of the specied variables to NULL. You cannot use upscol to specify attributes or validation criteria for TEXT or BYTE columns. Therefore, you cannot use the LIKE clause of the INITIALIZE statement to assign non-NULL values to variables of these large data types. Use the TO NULL clause to assign a NULL value to a variable. The following statement initializes all variables in the v_orders record to NULL:
INITIALIZE v_orders.* TO NULL
You might wish to initialize variables to NULL for the following reasons:
s s
To assign an initial value to a variable that has no assigned value. To discard some existing value of a variable, which might be convenient if you want to reuse the same variable later in a program
To optimize performance, you might wish to limit the use of this statement. For example, the next program fragment uses INITIALIZE once to create a NULL record, and then uses the LET statement to initialize another record:
DATABASE stores2 MAIN DEFINE p_customer, n_customer RECORD LIKE customer.* INITIALIZE n_customer.* TO NULL LET p_customer.* = n_customer.*
INITIALIZE
References
DATABASE, DEFINE, GLOBALS, LET, VALIDATE
4-158
INPUT
INPUT
The INPUT statement supports data entry into elds of a screen form.
Binding Clause p. 4-161
INPUT
HELP number
END INPUT
Element number
Usage
The INPUT statement assigns to one or more variables the values that users enter into the elds of a screen form. INPUT can include statement blocks to be executed under conditions that you specify, such as screen cursor movement, or other user actions. The following steps describe how to use this statement:
1. 2. 3.
Specify elds in a form specication le, and compile the form. Declare variables with the DEFINE statement. Open and display the screen form in either of the following ways:
s s
The OPEN FORM and DISPLAY FORM statements An OPEN WINDOW statement that uses a WITH FORM clause
4.
Use the INPUT statement to assign values to the variables from data that the user enters into elds of the screen form.
INPUT
When the INPUT statement is encountered, 4GL takes the following actions:
1.
Displays any default values in the screen elds, unless you specify the WITHOUT DEFAULTS keywords (as described in The WITHOUT DEFAULTS Keywords on page 4-163) Moves the cursor to the rst eld explicitly or implicitly referenced in the binding clause, and waits for the user to enter data in the eld Assigns the user-entered eld value to a corresponding program variable when the user moves the cursor from the eld or presses the Accept key
2. 3.
The INPUT statement activates the current form (the form that was most recently displayed, or the form in the current 4GL window). When the INPUT statement completes execution, the form is deactivated. After the user presses the Accept key, the INSERT statement of SQL can insert values from the program variables into the appropriate database tables. The following topics are described in this section:
s s s s s s s s s s s s s
The Binding Clause on page 4-161 The ATTRIBUTE Clause on page 4-166 The HELP Clause on page 4-166 The INPUT Control Block on page 4-167 The CONTINUE INPUT Statement on page 4-177 The EXIT INPUT Statement on page 4-178 The END INPUT Keywords on page 4-178 Using Built-In Functions and Operators on page 4-178 Keyboard Interaction on page 4-180 Cursor Movement in Simple Fields on page 4-180 Multiple-Segment Fields on page 4-182 Using Large Data Types on page 4-185 Completing the INPUT Statement on page 185
4-160
INPUT
,
variable FROM WITHOUT DEFAULTS
,
Field Clause field (subset) p. 3-86
,
BY NAME variable
WITHOUT DEFAULTS
Element variable
Here variable supports the syntax of a receiving variable in the LET statement, but you can also use record.* or the THRU or THROUGH notation to specify all or some of the members of a program record. The eld names are declared in the ATTRIBUTES section of the form specication. These can be simple elds, members of screen records, WORDWRAP elds, and FORMONLY elds, but cannot include records from screen arrays.
INPUT statements supports two types of binding clauses:
s
In the special case where all of the variables have names that are identical (apart from qualiers) to the names of elds, you can specify INPUT BY NAME variable list to bind the specied variables to their namesake elds implicitly. (See also The BY NAME Clause on page 4-164.) In the general case, you can specify INPUT variable list FROM eld list to bind variables explicitly to elds.
INPUT
The DEFAULT attribute (from the form specication le) The DEFAULT column value (from the syscolval table)
4-162
INPUT
4GL assigns NULL values to all variables for which no default is set. But if you include the WITHOUT NULL INPUT option in the DATABASE section of the form specication le, 4GL assigns the following default values. Field Type Character Number Default Blank (= ASCII 32) 0 Field Type INTERVAL MONEY DATE DATETIME Default 0 $0.00 12/31/1899 1899-12-31 23:59:59.99999
Initialize the variables with whatever values you want to display. Call the built-in SET_COUNT( ) function so that 4GL can determine how many rows of data are currently stored in the program array. Use INPUTWITHOUT DEFAULTS to display the current values of the variables and to allow the user to change those values.
The following INPUT statement causes 4GL to display the character string "Send via air express" in the ship_instruct eld:
LET pr_orders.ship_instruct = "Send via air express" INPUT BY NAME pr_orders.order_date THRU pr_orders.paid_date WITHOUT DEFAULTS END INPUT
INPUT
The WITHOUT DEFAULTS option is useful when you want the user to be able to make changes to existing rows of the database. You can display the existing database values on the screen before the user begins editing the data. The FIELD_TOUCHED( ) operator (described briey in Using Built-In Functions and Operators on page 4-178, and in detail on FIELD_TOUCHED( ) on page 5-84) can help you to determine which elds have been altered and which ones therefore require updates to the database. If you omit the WITHOUT DEFAULTS clause, 4GL determines default values by looking in the following sources of information, in the order indicated:
1. 2.
The DEFAULT attribute from the form specication The DEFAULT column as stored in the syscolval table
4GL assigns NULL values for all variables for which no default is set.
4-164
INPUT
Because pr_customer.customer_num does not appear in the list of variables, the user cannot enter a value for it. A functionally equivalent statement is:
DEFINE pr_cust RECORD LIKE customer.* ... INPUT BY NAME pr_cust.fname THRU pr_cust.phone
The THRU (or THROUGH) keyword implicitly includes the variables between two specied member variables of a program record. For example, the next statement maps elds to all member variables from fname to phone:
INPUT pr_cust.fname THRU pr_cust.phone FROM fname, lname, company, address1, address2, city, state, zipcode, phone
If the form specication le declared a screen record as fname THRU phone, you can abbreviate this statement even further:
INPUT pr_cust.fname THRU pr_cust.phone FROM sc_cust.*
You cannot use the THRU or THROUGH keywords in the FROM clause.
INPUT
The ATTRIBUTE clause overrides display attributes specied in a DISPLAY FORM, OPTIONS, or OPEN WINDOW statement, and suppresses any default attributes specied in the syscolatt table of the upscol utility.
The next example tells 4GL to display message 12 if the user presses the Help key when the screen cursor is in either of two elds:
INPUT cust.fname, cust.lname FROM fname, lname HELP 12
4-166
INPUT
You create help messages in an ASCII le whose lename you specify in the HELP FILE clause of the OPTIONS statement. Use the mkmessage utility, as described in Appendix B, to create a runtime version of the help le. A runtime error occurs in the following situations:
s s s
You specify a number that is not in the help le. You specify a number outside the range from -32,767 to 32,767.
The help message corresponding to your HELP clause specication applies to the entire INPUT statement. To override this with eld-level help messages, specify the Help key in an ON KEY block that invokes the INFIELD( ) operator and SHOWHELP( ) function. (For more information, see The ON KEY Block on page 4-171.) If you provide messages to assist the user through an ON KEY clause, rather than by the HELP clause, the messages must be displayed in a 4GL window within the 4GL screen, rather than in the separate Help window.
The statements to execute before or after visiting specic screen elds The statements to execute when the user presses a key sequence The statements to execute before or after the INPUT statement The next eld to which to move the screen cursor When to terminate execution of the INPUT statement
s s s s
The activation clause can specify any one of the following items:
s s s
Pre- and post-INPUT actions (the BEFORE or AFTER INPUT clause) Keyboard sequence conditions (the ON KEY clause) Cursor movement conditions (the BEFORE or AFTER FIELD clause)
INPUT
The statement block can include any SQL or 4GL statements, as well as the following items:
s s s
Cursor movement instructions (the NEXT FIELD clause) Termination of the INPUT statement (the EXIT INPUT statement) Returning control to the user without terminating the INPUT statement (the CONTINUE INPUT statement)
The activation clause and the statement block correspond respectively to the left-hand and right-hand elements in the following syntax diagram.
INPUT Input Control Blocks BEFORE AFTER FIELD INPUT
,
Field Clause p. 3-86 NEXT FIELD statement eld NEXT
,
ON KEY ( key
EXIT CONTINUE
PREVIOUS INPUT
Description is the name of a eld (as described in Field Clause on page 3-86) in the current form. is one or more keywords to specify physical or logical keys. For details, see The ON KEY Block on page 4-171. is an SQL statement or other 4GL statement.
After BEFORE FIELD, AFTER FIELD, or NEXT FIELD, the eld clause species a eld that the binding clause referenced implicitly (in the BY NAME clause, or as record.* or array [line].*) or explicitly. You can qualify a eld name by a table reference, or the name of a screen record or a screen array or array [ line ]. If you include one or more control blocks, the END INPUT keywords must terminate the INPUT statement. If no control block is included, 4GL waits while the user enters values into the elds. When the user accepts the values in the form, the INPUT statement terminates.
4-168
INPUT
If you include a control block, 4GL executes or ignores the statements in that statement block, depending on the following items:
s s s
Whether you specify the BEFORE INPUT or AFTER INPUT keywords The elds to which and from which the user moves the screen cursor The keys that the user presses
4GL deactivates the form while executing statements in a control block. After executing the statements, 4GL reactivates the form, allowing the user to
You can list these blocks in any order. If you develop some consistent ordering, however, your code will be easier to read. Within these control blocks, you can include the NEXT FIELD keywords and the CONTINUE INPUT and EXIT INPUT statements, as well as most 4GL and SQL statements. See Nested and Recursive Statements on page 2-31 for information about including CONSTRUCT, PROMPT, INPUT, and INPUT ARRAY statements within an input control block. The activation clauses that you can specify in control blocks are described in their order of execution by 4GL. Descriptions of NEXT FIELD and EXIT INPUT follow the discussions of these activation clauses. No subsequent INPUT control block statements are executed if EXIT INPUT executes.
INPUT
4GL executes the BEFORE INPUT block after displaying the default values in the elds and before letting the user enter any values. (If you included the WITHOUT DEFAULTS clause, 4GL displays the current values of the variables, not the default values, before executing the BEFORE INPUT block.)
An INPUT statement can include no more than one BEFORE INPUT block. You cannot include the FIELD_TOUCHED( ) operator in the BEFORE INPUT block.
The following program fragment denes two BEFORE FIELD blocks. When the cursor enters the fname or lname eld, 4GL displays a message:
BEFORE FIELD fname MESSAGE "Enter first name of customer" BEFORE FIELD lname MESSAGE "Enter last name of customer"
You can use a NEXT FIELD clause within a BEFORE FIELD block to restrict access to a eld. You can also use a DISPLAY statement within a BEFORE FIELD block to display a default value in a eld.
4-170
INPUT
The following statement fragment causes 4GL to prompt the user for input when the cursor is in the stock_num, manu_code, or quantity eld:
INPUT p_items.* FROM s_items.* BEFORE FIELD stock_num MESSAGE "Enter a stock number." BEFORE FIELD manu_code MESSAGE "Enter the code for a manufacturer." BEFORE FIELD quantity MESSAGE "Enter a quantity." ... END INPUT
For example, the following ON KEY block displays a help message. The BEFORE INPUT clause informs the user how to access help:
BEFORE INPUT DISPLAY "Press CONTROL-W or CTRL-F for Help" ON KEY (CONTROL-W, CONTROL-F) CALL customer_help()
The next statement denes an ON KEY block for the CONTROL-B key. Whenever the user presses CONTROL-B, 4GL determines if the screen cursor is in the stock_num or manu_code eld. If it is in either one of these elds, 4GL calls the stock_help( ) function and sets quantity as the next eld.
INPUT p_items.* FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF
INPUT
Special Considerations You must specify another key as the Accept key in the OPTIONS statement, because this is the default Accept key. You must execute a DEFER INTERRUPT statement. If the user presses the Interrupt key under these conditions, 4GL executes the statements in the ON KEY block and sets int_ag to non-zero, but does not terminate the INPUT statement. 4GL also executes the statements in this ON KEY block if the DEFER QUIT statement has executed and the user presses the Quit key. In this case, 4GL sets quit_ag to non-zero. 4GL reserves these control keys for eld editing; see Cursor Movement in Simple Fields on page 4-180. The standard meaning of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user. Instead, the key is trapped by 4GL and activates the commands in the ON KEY block. For example, if CONTROL-M appears in an ON KEY block, the user cannot press RETURN to advance the cursor to the next eld. If you specify one of these keys in an ON KEY block, be careful to restrict the scope of the statement.
Interrupt
Quit
CTRL-char A, D, H, K, L, R, X I, J, M
You might not be able to use other keys that have special meaning to your version of the operating system. For example, CONTROL-C, CONTROL-Q, and CONTROL-S specify the Interrupt, XON, and XOFF signals on many systems. If you use the OPTIONS statement to redene the Accept or Help key, the keys assigned to these sequences cannot be used in an ON KEY clause. For example, if you redene the Accept key by using the following statement, you should not dene an ON KEY block for the key sequence CONTROL-B:
OPTIONS ACCEPT KEY (CONTROL-B)
When the user presses CONTROL-B, 4GL will always perform the Accept key function, regardless of the presence of an ON KEY (CONTROL-B) block.
4-172
INPUT
If the user activates an ON KEY block while entering data in a eld, 4GL takes the following actions:
1. 2. 3. 4. 5.
Suspends input to the current eld Preserves the input buffer that contains the characters the user has typed Executes the statements in the current ON KEY block Restores the input buffer for the current screen eld Resumes input in the same eld, with the screen cursor at the end of the buffered list of characters
You can change this default behavior by performing the following tasks in the ON KEY block:
s s
Resuming input in another eld by using the NEXT FIELD statement Changing the input buffer value for the current eld by assigning a new value to the corresponding variable, and then displaying this value
This block can support accelerator keys for common functions, such as saving and deleting. You can use the INFIELD( ) operator in the ON KEY clause to support eld-specic actions. For example, you can implement eld-level help by using the INFIELD( ) operator and the built-in SHOWHELP( ) function.
INPUT
every time the cursor leaves the specied eld. Any of the following keys can cause the cursor to leave the eld:
s s s s s
The HOME or END key Any arrow key The RETURN or TAB key The Accept key The Interrupt or Quit key (if a supporting DEFER statement was included)
You can specify only one AFTER FIELD block for each eld. This AFTER FIELD block checks if the stock_num and manu_code elds contain values. If they contain values, 4GL calls the get_item( ) function:
AFTER FIELD stock_num, manu_code LET pa_curr = ARR_CURR() IF p_items[pa_curr].stock_num IS NOT NULL AND p_items[pa_curr].manu_code IS NOT NULL THEN CALL get_item() IF p_items[pa_curr].quantity IS NOT NULL THEN CALL get_total() END IF END IF
The following INPUT statement performs a NULL test to determine whether the user entered a value in the address1 eld, and returns to that eld if no value was entered:
INPUT p_addr.* FROM sc_addr.* AFTER FIELD address1 IF p_addr.address1 IS NULL THEN NEXT FIELD address1 END IF END INPUT
The user terminates the INPUT statement by pressing the Accept key when the cursor is in any eld, or by pressing the TAB or RETURN key after the last eld. You can use the AFTER FIELD block on the last eld to override this default termination. (Including the INPUT WRAP in the OPTIONS statement produces the same effect.)
4-174
INPUT
When the NEXT FIELD keywords appear in an AFTER FIELD block, the cursor moves to in the specied eld. If an AFTER FIELD block appears for each eld, and NEXT FIELD keywords are in each block, the user cannot leave the form.
statement is described inUsing Built-In Functions and Operators on page 4-178.) The next example uses the AFTER INPUT block to require that a rst name be specied for any customers with the last name Smith:
INPUT BY NAME p_customer.fname THRU p_customer.phone AFTER INPUT IF p_customer.lname="Smith" THEN IF NOT FIELD_TOUCHED(p_customer.fname) THEN CALL mess("You must enter a first name.") NEXT FIELD fname END IF END IF END INPUT
4GL executes the AFTER INPUT block only when the INPUT statement is terminated by the user pressing one of the following keys:
s s s
The Accept key The Interrupt key (if the DEFER INTERRUPT statement has executed) The Quit key (if the DEFER QUIT statement has executed)
The user presses the Interrupt or Quit key when the DEFER INTERRUPT or DEFER QUIT statement, respectively, has not executed. In either case, the program terminates immediately. The EXIT INPUT statement terminates the INPUT statement.
You can place the NEXT FIELD clause in this block to return the cursor to the form. If you place a NEXT FIELD clause in the AFTER INPUT block, use it in a conditional statement. Otherwise, the user cannot exit from the form.
INPUT
No more than one AFTER INPUT block can appear in an INPUT statement.
For example, this NEXT FIELD clause places the cursor in the previous eld:
NEXT FIELD PREVIOUS
The following INPUT statement includes a NEXT FIELD clause in an ON KEY block. If the user presses CONTROL-B when the cursor is in the stock_num or manu_code eld, 4GL moves the cursor to quantity as the next eld:
INPUT p_items.* FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF ... END INPUT
4GL immediately positions the cursor in the form when it encounters the NEXT FIELD clause; it does not execute any statements that follow the NEXT FIELD clause in the control block.
4-176
INPUT
For example, 4GL cannot invoke function qty_help( ) in the next example:
ON KEY (CONTROL-B, F4) IF INFIELD(stock_num) OR INFIELD(manufact) THEN CALL stock_help() NEXT FIELD quantity CALL qty_help() -- function is never called END IF
You can use the NEXT FIELD clause in any INPUT input control block. The NEXT FIELD clause typically appears in a conditional statement. In an AFTER INPUT clause, the NEXT FIELD statement must appear in a conditional statement; otherwise, the user cannot exit from the form. To restrict access to a eld, use the NEXT FIELD statement in a BEFORE FIELD clause. The following example demonstrates using the NEXT FIELD clause in an ON KEY control block. 4GL executes the ON KEY block if the user presses CONTROL-W. If the cursor is in the city eld, 4GL displays San Francisco in the city eld and CA in the state eld, and then moves the cursor to the zipcode eld.
ON KEY (CONTROL-W) IF INFIELD(city) THEN LET p_addr.city = "San Francisco" DISPLAY p_addr.city TO city LET p_addr.state = "CA" DISPLAY p_addr.state TO state NEXT FIELD zipcode END IF
To wrap from the last eld of a form to the rst eld of a form, use the NEXT FIELD statement after an AFTER FIELD clause for the last eld of the form. (The INPUT WRAP option of the OPTIONS statement has the same effect.)
INPUT
Skips all statements between the EXIT INPUT and END INPUT keywords Deactivates the form Resumes execution at the rst statement after the END INPUT keywords
s s
4GL ignores any statements in an AFTER INPUT control block if the EXIT INPUT statement is executed.
FIELD_TOUCHED( ) Returns TRUE if the user has touched (made a change to) a screen eld whose name is passed as an operand. Moving the screen cursor through a eld (with the RETURN, TAB, or arrow keys) does not mark a eld as touched. This operator also ignores the effect of statements that appear in the BEFORE INPUT control block. For example, you can assign values to elds in the BEFORE INPUT control block without having the elds marked as touched. GET_FLDBUF( ) Returns the character values of the contents of one or more elds in the currently active form (1 of 2)
4-178
INPUT
Description Waits for a key to be pressed, and then returns an INTEGER corresponding to the raw value of the key that was pressed. Returns an INTEGER corresponding to the most recent keystroke executed by the user while in the screen form. Returns TRUE if the name of the eld that is specied as its operand is the name of the current eld. (2 of 2)
Each eld has only one eld buffer, and a buffer cannot be used by two different statements simultaneously. If you plan to display the same form with data entry elds more than once, you should open a new 4GL window and open and display a second copy of the form. 4GL allocates a separate set of buffers to each form, so this avoids overwriting eld buffers when more than one INPUT, INPUT ARRAY, or CONSTRUCT statement accepts input. The next example of an INPUT statement uses the INFIELD( ) operator to determine if the cursor is in the stock_num or manu_code eld. If the cursor is in one of these elds, 4GL calls the stock_help( ) function and sets quantity as the next eld:
INPUT p_items.* FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF
The INFIELD(eld) expression returns TRUE if the current eld is eld and FALSE otherwise. Use this function for eld-dependent actions when the user presses a key in the ON KEY block. In the following INPUT statement, the BEFORE FIELD clause for the city eld displays a message advising the user to press a control key to enter the value San Francisco into the eld:
INPUT p_customer.fname THRU p_customer.phone FROM sc_cust.* ATTRIBUTE(REVERSE) BEFORE FIELD city MESSAGE "Press CONTROL-F to enter San Francisco" ON KEY (CONTROL-F) IF INFIELD(city) THEN LET p_customer.city = "San Francisco"
INPUT
DISPLAY p_customer.city TO city LET p_customer.state = "CA" DISPLAY p_customer.state TO state NEXT FIELD zipcode END IF END INPUT
If the user presses CONTROL-F while the cursor is in the city eld, the ON KEY clause in this example changes the screen display in three ways:
1. 2. 3.
Displays the value San Francisco in the city eld Displays CA in the state eld Moves the cursor to the rst character position in the zipcode eld
Keyboard Interaction
The user of the 4GL application can position the visual cursor during the INPUT statement by keyboard actions. Some keys are sensitive to what kind of eld the cursor occupies:
s s
For INPUT BY NAME, 4GL uses the order implied by the sequence of program variables specied in the binding clause. Otherwise, 4GL uses the order of the screen elds specied in the FROM clause of the INPUT statement.
4-180
INPUT
The user can press the arrow keys to position the screen cursor.
Arrow Effect By default, DOWN ARROW moves the cursor to the next eld. If you specify FIELD ORDER UNCONSTRAINED in the OPTIONS statement, this key moves the cursor to the eld below the current eld. If no eld is below the current eld and a eld exists to the left of the current eld, 4GL moves the cursor to the eld to the left. By default, UP ARROW moves the cursor to the previous eld. If you specify the FIELD ORDER UNCONSTRAINED option of the OPTIONS statement, this key moves the cursor to the eld above the current eld. If no eld is above the current eld and a eld exists to the left of the current eld, 4GL moves the cursor to the eld to the left.
RIGHT ARROW moves the cursor one space to the right inside a screen eld, without erasing the current character. At the end of the eld, 4GL moves the cursor to the rst character position of the next screen eld. RIGHT ARROW is equivalent to the CONTROL-L editing key. LEFT ARROW moves the cursor one space to the left inside a screen eld without erasing the current character. At the beginning of the eld, 4GL moves the cursor to the rst character position of the previous eld. LEFT ARROW is equivalent to the CONTROL-H editing key.
Unless a eld has the NOENTRY attribute, the user can press the following keys during an INPUT statement to edit values in a screen eld.
Editing Key
CONTROL-A CONTROL-D
Effect Toggles between insert and type-over mode Deletes characters from the current cursor position to the end of the eld Moves the cursor nondestructively one space to the left; equivalent to pressing left arrow (1 of 2)
CONTROL-H
INPUT
Editing Key
CONTROL-L
Effect Moves the cursor nondestructively one space to the right; equivalent to pressing right arrow Redisplays the screen Deletes the character beneath the cursor (2 of 2)
CONTROL-R CONTROL-X
Multiple-Segment Fields
For an explanation of how you can create a multiple-segment eld to display long character strings, see Multiple-Segment Fields on page 6-31. These elds supercially resemble a screen array, but the successive lines are segments of the same eld, rather than screen records. If the data string is too long to t in the rst segment, 4GL divides it at a blank character (if possible), padding the rest of the segment on the right with blank (ASCII 32) characters, and continues the display in the next eld segment. If necessary, this process is repeated until all of the segments are lled, or until the last text character is displayed (whichever happens rst). If the user inserts or deletes characters while editing a multiple-segment eld, the WORDWRAP attribute can move down subsequent characters as needed. Blank characters that the WORDWRAP editor uses as padding are called editor blanks. The COMPRESS keyword in the form specication can prevent storage of editor blanks in the database. Characters that users enter or that 4GL retrieves from the database are called intentional characters. If the cursor enters a multiple-segment eld, additional features of a multiple line editor become available to the user. The user must press CONTROL-M for NEWLINE, because RETURN moves the cursor to the next eld.
4-182
INPUT
Effect Leaves the entire multiple-segment eld, and goes to the rst character of the next eld. Moves left one character, unless at the left edge of a eld segment. From the beginning of the rst segment, these move to the rst character of the preceding eld (if INPUT WRAP is in effect), or beep (if INPUT NO WRAP; see the OPTIONS statement). From the left edge of a lower eld segment, these keys move to the last intentional character of the previous eld segment. Moves right one character, unless at the right-most intentional character in a segment. From the right-most intentional character of the last segment, this either moves to the rst character of the next eld, or only beeps, depending on INPUT WRAP mode. From the last intentional character of a higher segment, this moves to the rst intentional character in a lower segment. Moves from the top-most segment to the rst character of the preceding eld. From a lower segment, this moves to the character in the same column of the next higher segment, jogging left, if required, to avoid editor blanks, or if it encounters a tab. (1 of 2)
RIGHT ARROW
UP ARROW
INPUT
Key
DOWN ARROW
Effect Moves from the lowest segment to the rst character of the next eld. From a higher segment, moves to the character in the same column in the next lower segment, jogging left if required to avoid editor blanks, or if it encounters a tab. Enters a tab character, in insert mode, and moves the cursor to the next tab stop. This can cause following text to jump right to align at a tab stop. In type-over mode, this moves the cursor to the next tab stop that falls on an intentional character, going to the next eld segment if required. (2 of 2)
TAB
The character keys enter data. Any following data shifts right, and words can move down to subsequent segments. This can result in characters being discarded from the nal eld segment. These keystrokes can also alter data.
Key
CONTROL-A CONTROL-X
Effect Switches between type-over and insert mode. Deletes the character under the cursor, possibly causing words to be pulled up from subsequent segments. Deletes all text from the cursor to the end of the multiple-line eld (not merely to the end of the current eld segment). Inserts a NEWLINE character, causing subsequent text to align at the rst column of the next segment of the eld, and possibly moving words down to subsequent segments. This can result in characters being discarded from the nal segment of the eld.
CONTROL-D
CONTROL-N
The editing keys (described in Editing Keys on page 4-220) have the same effect in a multiple-segment eld, except that CONTROL-H can move to the last intentional character of the previous segment of the same eld, if the cursor is on the rst intentional character. Also, CONTROL-L can move to the rst intentional character of the next segment of the same eld from the last intentional character of a segment.
4-184
INPUT
Use a simple eld. (You can display part of a TEXT value in a multiplesegment eld, but the WORDWRAP editor cannot process a TEXT value.) If the form specication le assigns an appropriate attribute to a BYTE or TEXT eld, the user can invoke an external program by pressing the exclamation point ( ! ) key when the cursor is in the eld. This external program is typically an editor to allow the user to edit character (TEXT) or graphics (BYTE) data. To implement this feature, specify the PROGRAM attribute as part of the eld description in the form specication le, identifying the external program to execute. (For more information on using the PROGRAM attribute, see the description of that eld attribute in Chapter 6.) The external program takes over the entire screen. Any key sequence that you have specied in the ON KEY clause is ignored by the external program. When the external program terminates, 4GL performs the following tasks:
1. 2. 3.
Restores the screen to its state before the external program began Resumes the INPUT statement at the BYTE or TEXT eld Reactivates any key sequences specied in the ON KEY clause
The Accept, Interrupt, or Quit key The RETURN or TAB key from the last eld (and INPUT WRAP is not currently set by the OPTIONS statement)
INPUT
By default, the Accept, Interrupt, and Quit keys terminate the INPUT statement. Each of these actions also deactivates the form. (But pressing the Interrupt or Quit key can immediately terminate the program, unless the program also includes the DEFER INTERRUPT and DEFER QUIT statements.) The user must press the Accept key explicitly to complete the INPUT statement under the following conditions:
s s
An AFTER FIELD block for the last eld includes a NEXT FIELD clause.
If 4GL previously executed a DEFER INTERRUPT statement in the program, the Interrupt key causes 4GL to take the following actions:
s s
Set the global variable int_ag to a non-zero value. Terminate the INPUT statement, but not the 4GL program.
If 4GL previously executed a DEFER QUIT statement in the program, a Quit signal causes 4GL to take the following actions:
s s
Set the global variable quit_ag to a non-zero value. Terminate the INPUT statement, but not the 4GL program.
The AFTER FIELD clause for the current eld The AFTER INPUT clause
If INPUT terminates by an EXIT INPUT statement, or by pressing the Interrupt or Quit key, 4GL does not execute any of these clauses. If a NEXT FIELD statement appears in one of these clauses, 4GL places the cursor in the specied eld and returns control to the user.
References
DEFER, DISPLAY ARRAY, INPUT ARRAY, OPEN WINDOW, OPTIONS
4-186
INPUT ARRAY
INPUT ARRAY
The INPUT ARRAY statement supports data entry by users into a screen array, and stores the entered data in a program array of records.
Binding Clause p. 4-189 HELP number ATTRIBUTE Clause p. 3-96 INPUT ARRAY Input Control Block p. 4-197 END INPUT
INPUT ARRAY
Element number
Usage
The INPUT ARRAY statement assigns to variables in one or more program records the values that the user enters into the elds of a screen array. This statement can include statement blocks to be executed under conditions that you specify, such as screen cursor movement, or other user actions. The following outline describes how to use the INPUT ARRAY statement:
1. 2. 3.
Create a screen array in the form specication, and compile the form. Declare an ARRAY OF RECORD with the DEFINE statement. Open and display the screen form in either of the following ways:
s s
Using the OPEN FORM and DISPLAY FORM statements Using an OPEN WINDOW statement with the WITH FORM clause
4.
Use the INPUT ARRAY statement to assign values to the program array from data that the user enters into elds of the screen array.
INPUT ARRAY
When the INPUT ARRAY statement is encountered, 4GL performs the following tasks:
1. 2. 3.
Displays any default values in the screen elds, unless you specify the WITHOUT DEFAULTS keywords (as described on page 4-191) Moves the cursor to the rst eld and waits for input from the user Assigns the user-entered value to a corresponding program variable
Assignment of the entered value to the variable occurs when the cursor moves from the eld or the user presses the Accept key (typically ESCAPE). The INPUT ARRAY statement activates the current form (the form that was most recently displayed or the form in the current 4GL window). When the INPUT ARRAY statement completes execution, the form is deactivated. After the user presses the Accept key, the INSERT statement of SQL can insert the values of the program variables into the appropriate database tables. The following topics are described in this section:
s s s s s s s s s s s
The Binding Clause on page 4-189 The ATTRIBUTE Clause on page 4-191 The HELP Clause on page 4-196 The INPUT ARRAY Input Control Blocks on page 4-197 The CONTINUE INPUT Statement on page 4-214 The EXIT INPUT Statement on page 4-214 The END INPUT Keywords on page 4-215 Using Built-In Functions and Operators on page 4-215 Using Large Data Types on page 4-218 Keyboard Interaction on page 4-219 Completing the INPUT ARRAY Statement on page 4-221
4-188
INPUT ARRAY
.*
Description is the name of an array of program records. is the name of an array of screen records.
You must declare the program array in a DEFINE statement within your 4GL program; the screen array must be declared in the form specication le.
INPUT ARRAY
The number of screen records in screen array determines how many rows the form can display at one time. The size of record array determines how many RECORD variables your program can store. If the size of a program array exceeds the size of its screen array, users can press the Next Page or Previous Page keys to scroll through the screen array. (For more information, see Keyboard Interaction on page 4-219.) The default order in which the screen cursor moves from eld to eld in the screen array is determined by the declared order of the corresponding member variables, beginning in the rst screen record. (See also the NEXT FIELD keywords in The NEXT FIELD Keywords on page 4-176, and the WRAP and FIELD ORDER options of the OPTIONS statement, as described in Cursor Movement in Interactive Statements on page 4-296.)
The DEFAULT attribute (from the form specication le) The DEFAULT column value (from the syscolval table)
4GL assigns NULL values to all variables for which no default is set. But if you include the WITHOUT NULL INPUT option in the DATABASE section of the form specication le, 4GL assigns these non-NULL default values. Field Type Character Number Default Blank (= ASCII 32) 0 Field Type INTERVAL MONEY DATE DATETIME Default 0 $0.00 12/31/1899 1899-12-31 23:59:59.99999
4-190
INPUT ARRAY
Initialize the variables with whatever values you want to display. Call the built-in SET_COUNT( ) function to tell 4GL how many rows are currently stored in the program array. Specify INPUT ARRAYWITHOUT DEFAULTS to display current values, and to allow the user to change those records.
The WITHOUT DEFAULTS clause is useful when you want the user to be able to make changes to existing rows of the database. You can display the existing database values on the screen before the user begins editing the data. The FIELD_TOUCHED( ) operator can help you to determine which elds have been altered, and which ones therefore require updates to the database. (This operator is described briey in Using Built-In Functions and Operators on page 4-215, and in detail in FIELD_TOUCHED( ) on page 5-84.)
INPUT ARRAY
The ATTRIBUTE clause temporarily overrides any default display attributes that were specied in an OPTIONS, DISPLAY FORM, or OPEN WINDOW statement for these elds. It also suppresses any default attributes that were specied in the syscolatt table by the upscol utility.
"
keyword
"
Element keyword
Description is zero or one of the color attribute keywords, and zero or more of the intensity attribute keywords (except DIM, INVISIBLE, and NORMAL) from the syntax diagram of The ATTRIBUTE Clause on page 4-41.
The comma-separated list of attributes within the quoted string is applied only to the current row of screen array. For example, the specication
INPUT ARRAY p_items FROM s_items.* ATTRIBUTE (RED, CURRENT ROW DISPLAY = "GREEN, REVERSE")
displays screen array in red, but with the current row (the row that contains the screen cursor) in reverse video and green. When the cursor moves to another row, the previously highlighted row reverts to red, and the attributes list is applied to the new current row. If screen array has only one row, the CURRENT ROW DISPLAY attribute list is applied to that row. If the quoted string includes no keyword, an error is issued.
4-192
INPUT ARRAY
number variable
Description is a non-negative literal integer, specifying how many records in the program array contain data. is an INT or SMALLINT variable that contains the value of number.
The specication
COUNT = 5
Both of these specications restrict the number of screen records that can be displayed in the current screen array to 5. You can use the COUNT attribute to control the screen array dynamically, as the next section illustrates.
INPUT ARRAY
number variable
Description is a non-negative literal integer, specifying how many records in the screen array can display data. is an INT or SMALLINT variable that contains the value of number.
The following example of an INPUT ARRAY statement species both the MAXCOUNT and COUNT attributes:
INPUT ARRAY prog_array WITHOUT DEFAULTS FROM scr_array.* ATTRIBUTE( MAXCOUNT = x, COUNT = y)
Here x and y are literal integers or integer variables. In this example, y is the number of records that contain data within the program array. The MAXCOUNT value of x determines the dynamic size of the screen array that displays the program array. If MAXCOUNT is specied as less than one or greater than the declared program array size, the original program array size is used as the MAXCOUNT value. You can specify both COUNT and MAXCOUNT in the same ATTRIBUTE clause:
CALL SET_COUNT(5) INPUT ARRAY prog_array WITHOUT DEFAULTS FROM scr_array.* ATTRIBUTE( MAXCOUNT = 10, COUNT = 6)
In this example, the COUNT attribute overrides the SET_COUNT( ) value. The number of rows displayed will be 6. Except for the new COUNT and MAXCOUNT attributes, ATTRIBUTE lists of 4GL can only support xed keywords or literal integers.
4-194
INPUT ARRAY
TRUE FALSE
When INSERT ROW = FALSE is specied, the user cannot use the Insert key to perform insert actions within the INPUT ARRAY statement. (The user can still perform insert actions by using the TAB, ARROW, and RETURN keys in the last initialized row.) When INSERT ROW = TRUE is specied, the user is not prevented from using the Insert key to enter data. The default is TRUE, which corresponds to the behavior of previous 4GL releases.
TRUE FALSE
When DELETE ROW = FALSE is specied, the user cannot perform any DELETE actions within the INPUT ARRAY statement. When DELETE ROW = TRUE is specied, the user is not prevented from using the Delete key to delete data. The default is TRUE, which corresponds to the behavior of previous 4GL releases.
INPUT ARRAY
The following example disables the Insert and Delete keys on rows of the screen array:
INPUT ARRAY arrayname WITHOUT DEFAULTS FROM s_array.* ATTRIBUTE(INSERT ROW = FALSE, DELETE ROW = FALSE)
You create help messages in an ASCII le whose lename you specify in the HELP FILE clause of the OPTIONS statement (see The HELP FILE Option on page 4-299). Use the mkmessage utility to create a compiled version of the help le. A runtime error occurs in the following situations:
s s s
You specify a number that is not in the help le. You specify a number outside the range from -32,767 to 32,767.
The help message specied in your HELP clause applies to the entire INPUT ARRAY statement. To override this with eld-level help messages, specify an ON KEY block (see The ON KEY Block on page 4-171) that invokes the INFIELD( ) operator and SHOW_HELP( ) function, as described in Chapter 5. If you do this, the messages must be displayed in a 4GL window within the 4GL screen, rather than in the separate Help window.
4-196
INPUT ARRAY
The statements to execute before or after visiting specic screen elds The statements to execute when the user presses a key sequence The statements to execute before or after the INPUT ARRAY statement The next eld to which to move the screen cursor When to terminate execution of the INPUT ARRAY statement
s s s s
The activation clause can specify any one of the following items:
s s s s s
Pre- and post-INPUT actions (the BEFORE or AFTER INPUT clause) Pre- and post-INSERT actions (the BEFORE or AFTER INSERT clause) Pre- and post-DELETE actions (the BEFORE or AFTER DELETE clause) Keyboard sequence conditions (the ON KEY clause) Cursor movement conditions (the BEFORE or AFTER FIELD clause, and the BEFORE or AFTER ROW clause)
The statement block can include any SQL or 4GL statements, as well as the following items:
s
Cursor movement instructions (the NEXT FIELD or NEXT ROW clause) Termination of the INPUT ARRAY statement (the EXIT INPUT statement) Returning control to the user without terminating the INPUT ARRAY statement (the CONTINUE INPUT statement)
If you include one or more control blocks, the END INPUT keywords must terminate the INPUT ARRAY statement. If no control block is included, 4GL waits while the user enters values into the elds. When the user presses the Accept key, the INPUT ARRAY statement terminates.
INPUT ARRAY
The activation clause and the statement block correspond respectively to the left-hand and right-hand elements in the following syntax diagram.
INPUT ARRAY Input Control Block BEFORE AFTER FIELD INPUT DELETE NEXT INSERT ROW EXIT CONTINUE PREVIOUS INPUT
,
Field Clause p. 3-86 statement NEXT FIELD Field Clause field p. 3-86
,
ON KEY
key
Description is one or more keywords to specify physical or logical keys. For details, see The ON KEY Block on page 4-171. is an SQL statement or other 4GL statement.
After BEFORE FIELD, AFTER FIELD, or NEXT FIELD, the eld clause species a eld that the binding clause referenced implicitly (in the BY NAME clause, or as record.* or array [line].*) or explicitly. You can qualify a eld name by a table reference, or the name of a screen record or a screen array or array [ line ]. The BEFORE FIELD screen-array or AFTER FIELD screen-array activation clause applies to the entire screen array. BEFORE FIELD screen-array.eld or AFTER FIELD screen-array. eld applies to the specied eld in the screen array, as in the following example, which represents part of a screen form.
eld1 eld2
[ [ [
] ] ]
[ [ [
] ] ]
Screen array
4-198
INPUT ARRAY
If you specify BEFORE FIELD screen-array.eld1, 4GL executes the statement block if the cursor moves into the eld1 eld of any screen record of screenarray, but not after movement to a eld2 eld. You can specify BEFORE FIELD screen-array if you want the statement block to be executed if the cursor enters any eld of screen-array. If you include a control block, 4GL executes or ignores the statements in a control block, depending on:
s s s
whether you specify the BEFORE INPUT or AFTER INPUT keywords. the elds to which and from which the user moves the screen cursor. the keys that the user presses.
4GL deactivates the form while executing statements in a control block. After executing the statements, 4GL reactivates the form, allowing the user to
BEFORE ROW
BEFORE INSERT, BEFORE DELETE BEFORE FIELD screen-array BEFORE FIELD screen-array. eld ON KEY AFTER FIELD screen-array. eld AFTER FIELD screen-array AFTER INSERT, AFTER DELETE AFTER ROW AFTER INPUT
These blocks are described in the sections that follow. You can list these blocks in any order. If you develop some consistent ordering, however, your code might be easier to read.
INPUT ARRAY
Within these blocks, you can include the NEXT FIELD keywords (as described in The NEXT FIELD Keywords on page 4-176) and EXIT INPUT statement (described in The EXIT INPUT Statement on page 4-178), as well as most 4GL and SQL statements. See Nested and Recursive Statements on page 2-31 for information about including CONSTRUCT, PROMPT, INPUT, and INPUT ARRAY statements within an input control block. The activation clauses of INPUT ARRAY control blocks are described in their order of execution by 4GL. Descriptions of NEXT FIELD and EXIT INPUT follow the discussions of these activation clauses. No subsequent control block statements are executed if EXIT INPUT executes.
4GL executes the BEFORE INPUT block after displaying the default values in the elds and before allowing the user to enter values. (If you include the WITHOUT DEFAULTS clause, 4GL displays the current values of the variables, not the default values, before executing the BEFORE INPUT block.)
4-200
INPUT ARRAY
The following list describes how this program fragment uses the DISPLAY statement in the BEFORE INPUT block to populate the elds of a single screen array:
1. 2. 3. 4.
Call SET_COUNT(1) to initialize the array with a nondefault record. Include WITHOUT DEFAULTS in the INPUT ARRAY binding clause. Within the BEFORE INPUT block, use LET statements to assign values to the variables. Use DISPLAY to display the variable to the screen.
An INPUT ARRAY statement can include no more than one BEFORE INPUT control block. You cannot include the FIELD_TOUCHED( ) operator in the BEFORE INPUT block.
The cursor moves into a new line of the screen form. An INSERT statement fails because of lack of space. An INSERT statement is terminated by the Interrupt or Quit key. The user presses the Delete key.
INPUT ARRAY
Element statement
Description is an SQL statement or other 4GL statement that is valid within a BEFORE DELETE control block of INPUT ARRAY.
The cancelled Delete operation has no effect on the active set of rows that INPUT ARRAY is processing. See also Cancelling Insert Operations on page 4-204 for the parallel syntax of CANCEL INSERT within the BEFORE INSERT control block. If CANCEL INSERT or CANCEL DELETE is executed, the current BEFORE INSERT or BEFORE DELETE control block is terminated, and control of program execution passes to the next statement that follows the terminated control block. An error is issued if you specify CANCEL DELETE outside the context of the BEFORE DELETE control block.
4-202
INPUT ARRAY
Similarly, an error is issued if you specify CANCEL INSERT outside the context of the BEFORE INSERT control block. As an example, the programmer might want to implement a system where the user is allowed to delete all but one of the rows, but once a row is deleted, a replacement row cannot be inserted in its place. The following code implements this design:
DEFINE n_rows INTEGER DEFINE arrayname ARRAY[100] OF RECORD . . . INPUT ARRAY arrayname WITHOUT DEFAULTS FROM s_array.* ATTRIBUTES(COUNT = n_rows, MAXCOUNT = n_rows, INSERT ROW = FALSE, DELETE ROW = TRUE BEFORE INSERT CANCEL INSERT BEFORE DELETE LET n_rows = n_rows - 1 IF n_rows <= 0 THEN CANCEL DELETE END IF END INPUT
The user begins entering new records into the array. The user presses the Insert key to insert a new record between existing records of a screen array, but before the record is added to the array. The user moves the cursor to a blank record at the end of an array.
4GL executes the statements in this block before the user enters data for each
successive screen record that the Insert key creates. The following BEFORE INSERT block calls the get_item_num( ) function before inserting a new empty record into the screen array:
BEFORE INSERT CALL get_item_num()
INPUT ARRAY
Element statement
Description is an SQL statement or other 4GL statement that is valid within a BEFORE INSERT control block of INPUT ARRAY.
If CANCEL INSERT is specied, the user is prevented from entering rows by using the Insert key. This feature also prevents the user from entering rows by using an arrow key, TAB, RETURN, or (in Dynamic 4GL) ENTER to move the screen cursor past the last initialized row. The following example disables the Insert key for only the third row:
INPUT ARRAY ... BEFORE INSERT IF ARR_CURR() == 3 THEN CANCEL INSERT END IF END INPUT
4-204
INPUT ARRAY
You can use a NEXT FIELD clause within a BEFORE FIELD block to restrict access to a eld. You can also use a DISPLAY statement within a BEFORE FIELD block to display a default value in a eld. The following statement fragment causes 4GL to prompt the user for input when the cursor is in the stock_num, manu_code, or quantity eld:
INPUT ARRAY p_items FROM s_items.* BEFORE FIELD stock_num MESSAGE "Enter a stock number." BEFORE FIELD manu_code MESSAGE "Enter the code for a manufacturer." BEFORE FIELD quantity MESSAGE "Enter a quantity." ... END INPUT
The list of keys that can activate the ON KEY control block must be enclosed in parentheses, with commas separating the names of keys.
INFORMIX-4GL Statements 4-205
INPUT ARRAY
The next example denes an ON KEY block for CONTROL-B. When the user presses CONTROL-B, 4GL determines if the screen cursor is in the stock_num or manu_code eld. If it is in either one of these elds, 4GL calls the stock_help( ) function and sets quantity as the next eld.
INPUT ARRAY p_items FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF
The following ON KEY block displays a help message. The BEFORE INPUT clause informs the user how to access help:
BEFORE INPUT DISPLAY "Press CTRL-W for help" ON KEY (CONTROL-W, CONTROL-F) CALL customer_help()
Special Considerations You must specify another key as the Accept key in the OPTIONS statement, because this is the default Accept key. You must execute a DEFER INTERRUPT statement. If the user presses the Interrupt key under these conditions, 4GL executes the statements in the ON KEY block and sets int_ag to non-zero, but does not terminate the INPUT statement. 4GL also executes the statements in this ON KEY block if the DEFER QUIT statement has executed and the user presses the Quit key. In this case, 4GL sets quit_ag to non-zero. You must specify another key as the Insert key in the OPTIONS statement because CONTROL-W is the default Insert key. You must specify another key as the Delete key in the OPTIONS statement, because F2 is the default Delete key. You must specify another key as the Next Page key in the OPTIONS statement, because F3 is the default Next Page key. You must specify another key as the Previous Page key in the OPTIONS statement, because F4 is the default for that key. (1 of 2)
Interrupt
Quit
F1
F2
F3
F4
4-206
INPUT ARRAY
Key
CONTROL-char A, D, H, K, L, R, and X I, J, and M
Special Considerations
4GL reserves these keys for eld editing. The standard meaning of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user. Instead, the key is trapped by 4GL and used to activate the ON KEY block. For example, if CONTROL-M appears in an ON KEY block, the user cannot press RETURN to advance the cursor to the next eld. If you include one of these keys in an ON KEY block, be careful to restrict the scope of the block to specic elds. This is the default Help key, so use OPTIONS to declare another. (2 of 2)
You might not be able to use other keys that have special meaning to your operating system, such as CONTROL-Z on many BSD UNIX systems. Similarly, CONTROL-C, CONTROL-Q, and CONTROL-S specify the Interrupt, XON, and XOFF signals on many UNIX systems. If you use the OPTIONS statement to redene the Accept or Help key, the keys assigned to these sequences cannot be used in an ON KEY clause. For example, if you redene the Accept key by using the following statement, you should not dene an ON KEY block for the key sequence CONTROL-B:
OPTIONS ACCEPT KEY (CONTROL-B)
When the user presses CONTROL-B, 4GL will always perform the Accept key function, regardless of the presence of an ON KEY (CONTROL-B) block. If the user activates an ON KEY block while entering data in a eld, 4GL takes the following actions:
1. 2. 3.
Suspends input to the current eld Preserves the input buffer containing characters that the user typed Executes the statements in the current ON KEY block
INPUT ARRAY
4. 5.
Restores the input buffer for the current screen eld Resumes input in the same eld, with the screen cursor at the end of the buffered list of characters
You can change this default behavior by performing the following tasks in the ON KEY block:
s s
Resuming input in another eld by using the NEXT FIELD statement Changing the input buffer value for the current eld by assigning a new value to the corresponding variable and then displaying this value
You can also use this block to provide accelerator keys for common functions, such as saving and deleting. The INFIELD( ) operator can control eld-specic responses in the action for an ON KEY clause. You can implement eld-level help by using the INFIELD( ) operator and SHOWHELP( ) function.
every time the cursor leaves the eld. Any of the following keys can cause the cursor to leave the eld:
s s s s
Any arrow key The RETURN or TAB key The Accept key The Interrupt or Quit key (if a supporting DEFER statement was executed)
You can specify only one AFTER FIELD block for each eld. This AFTER FIELD block checks if the stock_num and manu_code elds contain values. If they contain values, 4GL calls the get_item( ) function:
AFTER FIELD stock_num, manu_code LET pa_curr = ARR_CURR() IF p_items[pa_curr].stock_num IS NOT NULL AND p_items[pa_curr].manu_code IS NOT NULL THEN CALL get_item() IF p_items[pa_curr].quantity IS NOT NULL THEN CALL get_total() END IF END IF
4-208
INPUT ARRAY
The following statement makes sure that the user enters an address line:
INPUT ARRAY p_addr FROM sc_addr.* AFTER FIELD address1 IF p_addr.address1 IS NULL THEN NEXT FIELD address1 END IF END INPUT
The user terminates the INPUT ARRAY statement by pressing the Accept key when the screen cursor is in any eld, or by pressing RETURN or TAB after the last eld. You can use the AFTER FIELD block on the last eld to override this default termination. (Including INPUT WRAP in the OPTIONS statement produces the same effect.) When the NEXT FIELD keywords appear in an AFTER FIELD block, the cursor moves to the specied eld. If an AFTER FIELD block appears for each eld, and the NEXT FIELD keywords are in each block, the user cannot leave the form.
Entering information in all the required elds of the current record Moving the cursor out of the last input eld by using one of these keys:
s s s s
Any arrow key The RETURN or TAB key The Accept key The HOME or END key
Tip: The Insert key does not by itself activate the AFTER INSERT block; the user must also move the cursor from the newly inserted record. The following AFTER INSERT block calls the renum_items( ) function after the user inserts a new blank screen record into the items screen array:
AFTER INSERT OF items CALL renum_items()
INPUT ARRAY
Deletes the record from the screen array Executes the statements in the AFTER DELETE block Executes the statements in the AFTER ROW block, if one is specied
The user must also press the Accept key to make corresponding changes to the variables in the array of program records. The following AFTER DELETE block calls the renum_items( ) function:
AFTER DELETE OF items CALL renum_items()
The cursor leaves the current row by using one of these keys:
Any arrow key The RETURN or TAB key The Accept key The Interrupt key (if DEFER INTERRUPT was also executed)
The INPUT ARRAY statement can specify only one AFTER ROW block. If you specify both an AFTER ROW and an AFTER INSERT block, 4GL executes the AFTER ROW block immediately after executing the AFTER INSERT block. The following AFTER ROW block calls the order_total( ) function after the screen cursor leaves a row, and the row is inserted:
AFTER ROW CALL order_total()
4-210
INPUT ARRAY
If you include a NEXT FIELD statement in an AFTER ROW block, 4GL moves the cursor to the next eld of the next row, not to the row which the cursor has just left. For example, if values in the elds in that row are in conict, the developer could detour the user back to the conicting elds before allowing the INPUT statement to complete, by having conditional NEXT FIELD statements in the AFTER INPUT block. For example:
INPUT ARRAY p_items from s_items.* ... AFTER ROW LET pa_curr = arr_curr() IF p_items[pa_curr].manu_code = "PNG" THEN MESSAGE "NOTE: PNG products are currently on hold" NEXT FIELD manu_code END IF ... END INPUT
The NEXT FIELD statement in the AFTER ROW control block, if executed, now keeps the user entry in the current row, with the cursor in the manu_code eld, regardless of what navigation key you use to leave that row (for example UP ARROW, DOWN ARROW, TAB, RETURN, or ACCEPT).
The Accept key The Interrupt key (if the DEFER INTERRUPT statement has executed) The Quit key (if the DEFER QUIT statement has executed)
The user presses the Interrupt or Quit key and the DEFER INTERRUPT or DEFER QUIT statement, respectively, has not executed. In either case, the program terminates immediately. The EXIT INPUT statement terminates the INPUT ARRAY statement.
INPUT ARRAY
By using the GET_FLDBUF( ) or FIELD_TOUCHED( ) built-in operators within the AFTER INPUT block, you can use the AFTER INPUT block to validate, save, or alter values that the user entered. The NEXT FIELD statement in the AFTER INPUT control block gives the 4GL developer the ability to prevent the user from completing the INPUT statement if some programmer-dened semantic criteria are not satised. The following example uses this block to require that a rst name be specied for any customers with the last name Smith:
CALL SET_COUNT(1) INPUT ARRAY p_customer FROM sc_customer.* AFTER INPUT IF p_customer.lname="Smith" THEN IF NOT FIELD_TOUCHED(p_customer.fname) THEN CALL mess("You must enter a first name.") NEXT FIELD fname END IF END IF END INPUT
You can place the NEXT FIELD clause in this block to return the cursor to the form. If you place a NEXT FIELD clause in the AFTER INPUT block, use it in a conditional statement. Otherwise, the user cannot exit from the form. You can include no more than one AFTER INPUT control block.
4-212
INPUT ARRAY
For example, this NEXT FIELD clause places the cursor in the previous eld:
NEXT FIELD PREVIOUS
The following INPUT ARRAY statement includes a NEXT FIELD clause in an ON KEY block. If the user presses CONTROL-B when the screen cursor is in the stock_num or manu_code eld, 4GL sets quantity as the next eld:
INPUT ARRAY p_items FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF ... END INPUT
In releases of 4GL prior to 6.03, the NEXT FIELD statement was ignored except to choose the active eld in the target row. If the ACCEPT key was used, the NEXT FIELD was ignored because the INPUT ARRAY statement had been completed (except for AFTER INPUT processing, if any). In most situations, the NEXT FIELD should appear in a conditional statement. The NEXT FIELD statement must appear in a conditional statement when it appears in an AFTER INPUT clause; otherwise, the user cannot exit the form.
4GL immediately positions the screen cursor in the form when it encounters the NEXT FIELD clause; it does not execute any statements that follow the NEXT FIELD clause in the control block. For example, 4GL does not invoke the
You can use the NEXT FIELD clause in any INPUT ARRAY control block. The NEXT FIELD clause typically appears in a conditional statement. In an AFTER INPUT clause, the NEXT FIELD statement must appear in a conditional statement; otherwise, the user cannot exit from the form. To restrict access to a eld, use the NEXT FIELD statement in a BEFORE FIELD clause.
INPUT ARRAY
The following example demonstrates using the NEXT FIELD clause in an ON KEY control block, which 4GL executes if the user presses CONTROL-W. If the cursor is in the city eld, 4GL displays San Francisco in the city eld and CA in the state eld, and then moves the cursor to the zipcode eld.
ON KEY (CONTROL-W) IF INFIELD(city) THEN LET p_addr.city = "San Francisco" DISPLAY p_addr.city TO city LET p_addr.state = "CA" DISPLAY p_addr.state TO state NEXT FIELD zipcode END IF
To wrap from the last eld of a form to the rst eld of a form, use the NEXT FIELD statement after an AFTER FIELD clause for the last eld of the form. (The INPUT WRAP option of the OPTIONS statement has the same effect.)
Skips all statements between EXIT INPUT and END INPUT Deactivates the form Resumes execution at the rst statement after END INPUT
4GL ignores any statements in an AFTER INPUT control block if the EXIT INPUT ARRAY statement is executed.
4-214
INPUT ARRAY
ARR_COUNT( ) FGL_SCR_SIZE( )
SCR_LINE( )
SET_COUNT( )
INPUT ARRAY
These functions and operators access eld buffers and keystroke buffers.
Feature FIELD_TOUCHED( ) Description Returns TRUE when the user has touched (made a change to) a screen eld whose name is passed as an operand. Moving the screen cursor through a eld (with the RETURN, TAB, or arrow keys) does not mark a eld as touched. This function also ignores the effect of statements that appear in the BEFORE INPUT control block. For example, you can assign values to elds in the BEFORE INPUT control block without having the elds marked as touched. Returns the character values of the contents of one or more elds in the currently active form. Waits for a key to be pressed, and then returns an INTEGER value corresponding to the raw value of the key that was pressed. Returns an INTEGER value corresponding to the most recent keystroke executed by the user in the screen form. Returns TRUE if the name of the eld that is specied as its operand is the name of the current eld.
GET_FLDBUF( ) FGL_GETKEY( )
FGL_LASTKEY( ) INFIELD( )
Each eld has only one eld buffer; two statements cannot use a buffer simultaneously. To display the same form with data entry elds more than once, open a new 4GL window, and open and display a second copy of the form. (4GL allocates a separate set of buffers to each form, so this avoids overwritting buffers when two or more concurrent statements accept input.) The following statement uses the INFIELD( ) operator to determine if the cursor is in the stock_num or manu_code eld. If the cursor is in one of these elds, 4GL calls the stock_help( ) function and sets quantity as the next eld:
INPUT ARRAY p_items FROM s_items.* ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN CALL stock_help() NEXT FIELD quantity END IF
4-216
INPUT ARRAY
The INFIELD(eld) expression returns TRUE if the current eld is eld and FALSE otherwise. You can use this function to control eld-dependent actions when the user presses a specied key in the ON KEY control block. In the following INPUT ARRAY statement, the BEFORE FIELD control block for the city eld displays a message identifying a key that the user can press to enter the character string "San Francisco" into the eld:
INPUT ARRAY pr_customer FROM sc_cust.* ATTRIBUTE(REVERSE) BEFORE FIELD city MESSAGE "Press CTRL-F for default city, San Francisco" ON KEY (CONTROL-F) IF INFIELD(city) THEN LET p_customer.city = "San Francisco" DISPLAY p_customer.city TO city LET p_customer.state = "CA" DISPLAY p_customer.state TO state NEXT FIELD zipcode END IF END INPUT
If the user presses CONTROL-F while the cursor is in the city eld, the ON KEY clause in this example changes the screen display in three ways:
1. 2. 3.
Displays the value San Francisco in the city eld Displays CA in the state eld Moves the cursor to the rst character position in the zipcode eld
For more about the built-in 4GL functions and operators, see Chapter 5.
INPUT ARRAY
If the form specication le assigns an appropriate attribute to a BYTE or TEXT eld, the user can invoke an external program by pressing the exclamation point ( ! ) key when the cursor is in the eld. This external program is typically an editor that allows the user to edit large string (TEXT) or graphics (BYTE) data. To implement this feature, specify the PROGRAM attribute as part of the eld description in the form specication le, identifying the external program to execute. (For more information on using the PROGRAM attribute, see the description of that eld attribute in Chapter 6.) The external program takes over the entire screen. Any key sequence that you have specied in the ON KEY clause is ignored by the external program. When the external program terminates, 4GL takes the following actions:
1. 2. 3.
Restores the screen to its state before the external program began Resumes the INPUT statement at the BYTE or TEXT eld Reactivates any key sequences specied in the ON KEY clause
4-218
INPUT ARRAY
Keyboard Interaction
The user of your 4GL application can use the keyboard to position the cursor during an INPUT ARRAY statement, to scroll the screen array, and to edit data in screen records. By default, the user can move the cursor within a screen array and scroll the displayed rows by clicking the arrow keys, the PAGE UP or PAGE DOWN key, and the F3 and F4 function keys. The following table describes these keys.
Key Effect
RIGHT ARROW moves the cursor one space to the right inside a screen eld
without erasing the current character. At the end of the eld, 4GL moves the cursor to the rst character position of the next screen eld. This key is equivalent to the CONTROL-L editing key.
LEFT ARROW moves the cursor one character position to the left in a screen
eld without erasing the current character. At the end of the eld, the cursor moves to the rst character position of the previous screen eld. This key is equivalent to the CONTROL-H editing key.
DOWN ARROW moves the cursor to the same display eld one line down on the screen. If the cursor was on the last line of the screen array before DOWN ARROW was used, 4GL scrolls the program array data up one line. If the last program array record is already on the last line of the screen array, DOWN ARROW generates a message indicating that there are no more rows in that direction. UP ARROW moves the cursor to the same eld one line up on the screen. If the cursor is on the rst line of the screen array, 4GL scrolls the program array data down one line. If the rst program array record is already on the rst screen array line, UP ARROW generates a message indicating that there are no more rows in that direction. F3 scrolls the display to the next full page of program records. The NEXT KEY clause of the OPTIONS statement can reset this key. F4 scrolls the display to the previous full page of program records. The PREVIOUS KEY clause of the OPTIONS statement can reset this key.
F3
F4
INPUT ARRAY
Editing Keys
Unless a eld has the NOENTRY attribute, the user can press the following keys during an INPUT ARRAY statement to edit values in a eld.
Key
CONTROL-A CONTROL-D
Effect Toggles between insert and type-over mode Deletes characters from current cursor position to the end of the eld Moves the cursor nondestructively one space to the left. It is equivalent to pressing left arrow Moves the cursor nondestructively one space to the right. It is equivalent to pressing right arrow Redisplays the screen Deletes the character beneath the cursor
CONTROL-H
CONTROL-L
CONTROL-R CONTROL-X
4-220
INPUT ARRAY
Effect Inserts a new blank screen record into the screen array at the line below the cursor. Any displayed values in lower records move down one line, and the cursor moves to the beginning of the rst eld of the new blank record. This key is not needed to insert rows at the end of the screen array. If the user attempts to insert more rows than the declared size of the program array, 4GL displays a message that the array is full. The OPTIONS statement can specify a different physical key as the Insert key. Deletes the current record from the screen array. 4GL adjusts any subsequent rows to ll the gap. The OPTIONS statement can specify a different physical key as the Delete key.
F2
Pressing the Accept key makes corresponding changes in the program array. You can then use the ARR_COUNT( ) function to determine how many records (possibly including blank records) remain in the program array after the user has pressed the Insert or Delete key and the Accept key. See also The BEFORE DELETE Block on page 4-201, The BEFORE INSERT Block on page 4-203, The AFTER INSERT Block on page 4-209, and The AFTER DELETE Block on page 4-210.
The Accept, Interrupt, or Quit key The RETURN or TAB key from the last eld (and INPUT WRAP is not currently set by the OPTIONS statement)
INPUT ARRAY
All of these conditions deactivate the form. Unlike the INPUT statement, the INPUT ARRAY statement is not terminated when the user presses the RETURN or TAB key in the last screen eld. By default, the Accept, Interrupt, and Quit keys terminate the INPUT ARRAY statement. Each of these actions also deactivates the form. (But pressing the Interrupt or Quit key can immediately terminate the program, unless the program also includes the DEFER INTERRUPT and DEFER QUIT statements.) The user must press the Accept key explicitly to complete the INPUT ARRAY statement under the following conditions:
s s
An AFTER FIELD block for the last eld includes a NEXT FIELD clause.
If 4GL previously executed a DEFER INTERRUPT statement in the program, an Interrupt signal causes 4GL to take the following actions:
s s
Sets the global variable int_ag to a non-zero value Terminates the INPUT ARRAY statement but not the 4GL program
If 4GL previously executed a DEFER QUIT statement in the program, a Quit signal causes 4GL to take the following actions:
s s
Sets the global variable quit_ag to a non-zero value Terminates the INPUT ARRAY statement but not the 4GL program
The AFTER FIELD clause for the current eld The AFTER ROW clause The AFTER INPUT clause
If INPUT ARRAY is terminated by the EXIT INPUT keywords, or by pressing the Interrupt or Quit key, 4GL does not execute any of these clauses. If a NEXT FIELD statement appears in one of these clauses, 4GL places the cursor in the specied eld and returns control to the user. The INPUT ARRAY statement in the example that follows supports data entry into a screen form.
4-222 IBM Informix 4GL Reference Manual
INPUT ARRAY
The BEFORE FIELD clauses display messages telling the user what to enter in the stock_num, manu_code, and quantity elds. The AFTER FIELD clauses check that user entered values for the stock_num, manu_code, and quantity elds. When the user enters item values for the stock_num and manu_code elds, 4GL calls get_item( ) to display a description and price of the item. When all three elds are specied, 4GL displays the total cost. In this example, the BEFORE INSERT, AFTER INSERT, and AFTER DELETE clauses call functions that ensure that the numbering of the items is accurate. Accurate numbering is necessary because the user can press the Insert and Delete keys at runtime to insert and to delete items within the screen form.
CALL SET_COUNT(1) INPUT ARRAY p_items FROM s_items.* BEFORE FIELD stock_num MESSAGE "Enter a stock number." BEFORE FIELD manu_code MESSAGE "Enter the code for a manufacturer." BEFORE FIELD quantity MESSAGE "Enter a quantity" AFTER FIELD stock_num, manu_code MESSAGE "" LET pa_Curr = arr_curr() IF p_items[pa_curr].stock_num IS NOT NULL AND p_items[pa_curr].manu_code IS NOT NULL THEN CALL get_item() IF p_items[pa_curr].quantity IS NOT NULL THEN CALL get_total() END IF END IF AFTER FIELD quantity MESSAGE "" LET pa_curr = arr_curr() IF p_items[pa_curr].stock_num IS NOT NULL AND p_items[pa_curr].manu_code IS NOT NULL AND p_items[pa_curr].quantity IS NOT NULL THEN CALL get_total() END IF BEFORE INSERT CALL get_item_num() AFTER INSERT CALL renum_items() AFTER DELETE CALL renum_items() END INPUT
References
DEFER, DISPLAY ARRAY, INPUT, OPEN WINDOW, OPTIONS, SCROLL INFORMIX-4GL Statements 4-223
LABEL
LABEL
The LABEL statement declares a statement label, marking the next statement as one to which a WHENEVER or GOTO statement can transfer program control.
LABEL label:
Element label
Usage
The LABEL statement indicates where to transfer control of program execution within the same program block. Upon executing a GOTO or WHENEVER statement that references the label identier, 4GL jumps to the statement immediately following the LABEL statement, skipping any intervening statements. (See also GOTO on page 4-151.) The following restrictions apply to the LABEL statement:
s s
The identier must be unique among labels in the program block. To jump to a label, the GOTO or WHENEVER statement must specify the same label identier as the LABEL statement. The GOTO (or WHENEVER) and LABEL statements must both be in the same MAIN, FUNCTION, or REPORT program block.
A colon ( : ) symbol must follow the last character in the label identier. This syntax contrasts with GOTO, where the colon is optional, and with WHENEVER, where the colon precedes the identier but is not required. You might wish to declare a meaningful name to indicate something about the purpose of the jump:
WHENEVER ERROR GO TO :l_error ... LABEL l_error: ERROR "Cannot complete processing." ROLLBACK WORK
4-224
LABEL
References
GOTO, WHENEVER
LET
LET
The LET statement assigns a value to a variable, or a set of values to a record. ||
,,
LET Receiving Variable large destination .* Receiving Variable =
= source . *
variable record
. ,
array
Description is a variable of the ARRAY data type. is a program record to be assigned values. is a variable of the BYTE or TEXT data type. is a variable of the RECORD data type. is a program record from which to copy values. is a variable of a simple data type, a simple member of a record, or a simple element of an array.
4-226
LET
Usage
After DEFINE declares a variable, the 4GL compiler allocates memory to that variable, and (for RDS) initializes the value to NULL. For the 4GL C Compiler, however, the contents of the variable is whatever happens to occupy that memory location. Do not use uninitialized variables in 4GL expressions. If you reference any variable without rst initializing it with an INITIALIZE or LET statement, the results are unlikely to be useful. The LET statement can assign a single value to a single variable, or it can assign all the values from a RECORD variable to another program record. To execute a LET statement, 4GL evaluates the expression on the right of the equal ( = ) sign and assigns the resulting value to the variable on the left. For example, the statements in the following example create a SELECT statement as text for a PREPARE statement. Here slash ( / ) embeds a quotation ( " ) mark within a string; the comma ( , ) and double pipe ( || ) symbols concatenate successive elements of the statement text:
DEFINE sel_stmt CHAR(80) LET sel_stmt = "SELECT * FROM customer" || "WHERE lname MATCHES \"" || last_name CLIPPED, "\"" PREPARE s1 FROM sel_stmt
You can use most of the 4GL built-in functions and character operators like CLIPPED and USING within the LET statement. For example, these statements use the ASCII operator to ring the terminal bell (= the ASCII value for 7):
DEFINE bell CHAR(1) LET bell = ASCII 7 DISPLAY bell
You cannot assign individual values to an entire program record or to a program array. You cannot use the THRU or THROUGH notation (described in THRU or THROUGH Keywords and .* Notation on page 3-92) in the LET statement, but you can assign all the values of one program record to another program record of the same size by using the asterisk ( * ) notation:
LET x.* = y.*
LET
This example copies the value of each member of the y record to consecutive members of the x record. The two records must have the same number of members, and corresponding members must be of compatible data types. (See Summary of Compatible 4GL Data Types on page 3-46.) No member of the record can be of the BYTE or TEXT data types. To reference substrings of CHAR or VARCHAR variables, specify the starting and ending character positions as integers. These substring positions must be enclosed within brackets and separated by a comma, as in this example:
DEFINE full_name CHAR(20), first_name CHAR(10) LET full_name[1,10] = new_first
For TEXT and BYTE variables, LET can assign only NULL values. To assign other values to TEXT and BYTE variables, you can take one of the following actions:
s
Use the INTO clause of the SELECT, FOREACH, OPEN, or FETCH statement Pass the name of the variable as an argument to a function
4-228
LET
Which separator you use should depend on how you want NULL strings handled when the list can include both NULL and non-NULL values.
4GL performs data type conversion on compatible data types (as described in
In nondefault locales, if you assign number or monetary values in the LET statement, the conversion process inserts locale-specic separators and currency symbols into the created strings, rather than U.S. English separators and currency symbols. This result occurs regardless of whether you include the USING operator in the LET statement. If DBFORMAT or DBMONEY is set, however, their settings override the default settings in the locale les.
References
FOREACH, GLOBALS, INITIALIZE
LOAD
LOAD
The LOAD statement inserts data from a le into an existing table.
LOAD FROM lename DELIMITER INSERT Clause INSERT INTO Table Qualier p. 3-89 table delimiter variable INSERT Clause
, (
column
Description is the name of a column in table, in parentheses. If you omit the list of column names, the default is all the columns of table. is a quoted string (or a CHAR or VARCHAR variable) containing a delimiter symbol. is a quoted string (or a CHAR or VARCHAR variable) specifying a le that contains the input data. This can include a pathname. is the name of a table, synonym, or view in the current database, or in a database specied in the table qualier. is a CHAR or VARCHAR variable containing an INSERT clause.
Usage
The LOAD statement must include an INSERT statement (either directly or as text in a variable) to specify where to store the data. LOAD appends the new rows to the specied table, synonym, or view, but does not overwrite existing data. It cannot add a row that has the same key as an existing row. You cannot use the PREPARE statement to preprocess a LOAD statement.
4-230
LOAD
The user who executes LOAD must have Insert privileges for table. (Database and table-level privileges are described in Informix Guide to SQL: Syntax.) For readers familiar with the ACE reports of INFORMIX-SQL, LOAD provides at-le input functionality, similar to that of the READ command of ACE.
DATETIME, INTERVAL values must be formatted year-month or else INTERVAL day hour:minute:second.fraction, or a contiguous subset thereof; DATETIME values must be in the format year-month-day hour:minute:second.fraction, or a contiguous subset, without DATETIME or INTERVAL keywords or qualiers. Time units outside the declared column precision can be omitted. DATETIME year must be a four-digit number; all other time units (except fraction) require two digits. MONEY Values can include currency symbols, but these are not required. (1 of 2) INFORMIX-4GL Statements 4-231
LOAD
Input Format Values can be represented as 0 to tell the database server to supply a new SERIAL value. You can specify a literal integer greater than zero, but if the column has a unique index, an error results if this number duplicates an existing value. Values must be ASCII-hexadecimals; no leading or trailing blanks. (2 of 2)
BYTE
Each set of data values in lename that represents a new row is called an input record. The NEWLINE character must terminate each input record in lename. Specify only values that 4GL can convert to the data type of the database column. For database columns of character data types, inserted values are truncated from the right if they exceed the declared length of the column.
NULL values of any data type must be represented by consecutive delimiters
in the input le; you cannot include anything between the delimiter symbols. This example shows two records in a hypothetical input le called nu_cus:
0|Jeffery|Padgett|Wheel Thrills|3450 El Camino|Suite 10|Palo Alto|CA|94306|| 0|Linda|Lane|Palo Alto Bicycles|2344 University||Palo Alto|CA|94301|(415)323-6440
The rst data value in each record is zero, because the database server should supply a value for a SERIAL column in the row of the database table. The pipe symbol ( | ), the default delimiter, separates consecutive values.
LOAD uses adjacent delimiters to assign NULL values to the phone column in the rst record and to the address2 column for the second record.
The following LOAD statement inserts all the values from the nu_cus le into a customer table that is owned by the user whose login is krystl:
LOAD FROM "nu_cus" INSERT INTO krystl.customer
4-232
LOAD
Each input record must contain the same number of delimited data values. If the INSERT clause has no list of columns, the sequence of values in each input record must match the columns of table in number and order. Each value must have the literal format of the column data type, or of a compatible data type. (See Summary of Compatible 4GL Data Types on page 3-46.) A le created by the UNLOAD statement can be used as input for the LOAD statement if its values are compatible with the schema of table. The onload and dbload utilities give you more exibility for the format of the input le. See your database server documentation for a description of onload, and see the INFORMIX-SE Administrators Guide for a description of dbload.
GLS
The LOAD statement expects incoming data in the format specied by environment variables DBFORMAT, DBMONEY, DBDATE, GL_DATE, and GL_DATETIME. The precedence of these format specications is consistent with forms and reports. If there is an inconsistency, an error is reported and the LOAD is cancelled. For more information, see Appendix E, Developing Applications with Global Language Support.
If you omit the DELIMITER clause, the default delimiter symbol is the value of the DBDELIMITER environment variable, or else a pipe ( | ) symbol (ASCII 124) if DBDELIMITER is not set. For details, see Appendix D.
s s s
Backslash ( \ )
LOAD
The backslash serves as an escape character to indicate that the next character is to be interpreted literally as part of the data, rather than as a delimiter or record separator or escape character. If any character value in the input le includes the delimiter or NEWLINE symbols without backslashes, the LOAD statement produces error -846; see Informix Error Messages in Answers OnLine. Important: When this error occurs, the SQLCA.SQLERRD[3] character is always set to 1, regardless of how many records (if any) were successfully loaded into the database. For this reason, unless the LOAD operation occurs within a transaction, recovery of the database after this error is not trivial. The UNLOAD statement automatically inserts a backslash before any literal delimiter or NEWLINE symbol in character values. When LOAD (or the onload or dbload utility) inserts output from UNLOAD into a database table, these escapist backslash symbols are automatically stripped from the data.
You are not inserting data into all of the columns of table. The input le does not match the default order of columns, as listed in the syscolumns table of the system catalog.
The following example identies the price and discount columns as the only columns into which to insert non-NULL data values:
LOAD FROM "/tmp/prices" DELIMITER "," INSERT INTO maggie.worktab(price,discount)
4-234
LOAD
Run LOAD as a singleton transaction, so that any error causes the entire LOAD statement to be automatically rolled back. Run LOAD within an explicit transaction, so that a data error merely stops the LOAD statement in place with the transaction still open.
LOAD
LOAD does not execute a COMMIT WORK or ROLLBACK WORK automatically unless LOAD was the rst statement of a new (implicit) transaction. For example, if the database is ANSI-compliant, a transaction is always in effect. LOAD would be the rst statement of a new transaction only if the immediately preceding SQL statement was a DATABASE statement, a COMMIT WORK statement, or a ROLLBACK WORK statement.
If the database is not ANSI-compliant but has a transaction log, a new transaction is indicated by a BEGIN WORK statement. LOAD is the rst statement of a new transaction only if the immediately preceding SQL statement was a BEGIN WORK statement. In either type of logged database, if LOAD is the rst statement of a new transaction, 4GL automatically commits the transaction if the load completes without errors. If errors are found, a rollback is automatically performed. If LOAD is not the rst statement of a new transaction, 4GL leaves the transaction open. This allows you to take one of the following actions:
s
COMMIT the successfully loaded rows, x the load records, and rerun LOAD with the balance of the records.
Abort the LOAD altogether by executing ROLLBACK WORK, followed by repeating the LOAD operation from the beginning.
The following 4GL script fragment illustrates a typical LOAD statement series using an explicit transaction in a database that is not ANSI-compliant:
create database mine with log in "/db/mine/trans.log"; create table mytab1 (col1 serial, col2 char(20), col3 date); create table loadlog (tabname char(18), loaddate date); begin work; insert into loadlog values ("mytab1", today); load from "mytab1.unl" insert into mytab1;
If the LOAD is successful, at this point you can execute COMMIT WORK or ROLLBACK WORK as appropriate. The next 4GL script fragment illustrates the same steps using an explicit transaction in an ANSI-compliant database:
create database mine_ansi with log in "/db/mine/trans.log" MODE ANSI; create table "user1".mytab1 (col1 serial, col2 char(20), col3 date); create table "user1".loadlog (tabname char(18), loaddate date); commit work; insert into "user1".loadlog values ("mytab1", today); load from "mytab1.unl" insert into "user1".mytab1;
4-236
LOAD
If the LOAD is successful, at this point you can execute COMMIT WORK or ROLLBACK WORK as appropriate. The third 4GL script fragment illustrates a typical LOAD statement (with an implicit transaction) in a database that is not ANSI-compliant:
create database mine with log in "/db/mine/trans.log"; create table mytab1 (col1 serial, col2 char(20), col3 date); close database; database mine; load from "mytab1.unl" insert into mytab1;
If the LOAD has no errors, the changes are committed. If error messages appear, the rows that were loaded before the error occurred are rolled back automatically. The nal 4GL script fragment illustrates a typical LOAD statement (with implicit transaction) in a database that is ANSI compliant:
create database mine_ansi with log in "/db/mine/trans.log" MODE ANSI; create table "user1".mytab1 (col1 serial, col2 char(20), col3 date); close database; database mine_ansi; load from "mytab1.unl" insert into "user1".mytab1;
If the LOAD has no errors, the changes are committed. If error messages appear, the rows that were loaded before the error occurred are rolled back automatically.
LOAD
Use SET INDEXDISABLED to disable any indexes on the table. Use SET CONSTRAINTDISABLED to disable any constraints. Use SET TRIGGERDISABLED to disable any triggers. Use LOAD to insert data into the table. Use SET INDEX ENABLED to restore any indexes on the table Use SET CONSTRAINTENABLED to restore any constraints. Use SET TRIGGER...ENABLED to restore any triggers.
(See Informix Guide to SQL: Syntax for the syntax of the SET INDEX, SET CONSTRAINT, and SET TRIGGER statements.) It is more efcient to follow these steps than to drop the indices, constraints, and triggers; perform the LOAD; and then recreate the indices, constraints, and triggers. Because the SET statement was introduced in the Informix implementation of the SQL language after the 4.10 release, these SET statements must be prepared, or else must be delimited by the SQL and END SQL keywords.
References
DATABASE, UNLOAD
4-238
LOCATE
LOCATE
The LOCATE statement species where to store a TEXT or BYTE value. ,
LOCATE BYTE or TEXT Variable List p. 4-240 IN MEMORY FILE
"lename"
variable
Description is the name of a le in which to store the TEXT or BYTE value. This specication can include a pathname and le extension. is the name of a CHAR or VARCHAR variable containing a lename specication.
Usage
The TEXT or BYTE data type can stores a large binary value. You must specify whether you want to store the value of the variable in memory or in a le. You can access a value from memory faster than from a le. If your program exceeds the available memory, however, 4GL automatically stores part of the TEXT or BYTE value in a le. To use a large variable, your program must include the following steps:
1. 2.
Declare the variable with a DEFINE statement. Use the LOCATE statement to specify the storage location. The LOCATE statement must appear within the scope of reference of the variable.
The List of Large Variables on page 4-240 The IN MEMORY Option on page 4-241 The IN FILE Option on page 4-241
LOCATE
s s
Passing Large Variables to Functions on page 4-243 Freeing the Storage Allocated to a Large Data Type on page 4-243
The LOCATE statement must follow any DEFINE statement that declares TEXT or BYTE variables, and it must appear in the same program block as a local TEXT or BYTE variable. If you try to access a TEXT or BYTE value before initializing its variable with a LOCATE statement, 4GL generates a runtime error.
.rst ,
THROUGH THRU
record
. last
array
integer
Description is the name of a structured variable of the ARRAY data type. is the name of a large member variable to be initialized. is a literal integer between 0 and the declared size of the array. is another member of record that was declared later than rst. is the name of a structured variable of the RECORD data type. is the name of a large variable of the TEXT or BYTE data type.
As in all 4GL statements that do not declare variables, any identier of an array, record, record member, or variable must have been previously declared and must be within its scope of reference. (The only 4GL statements that can declare variables are DEFINE and GLOBALS.)
4-240
LOCATE
You can then use most 4GL statements to access the variable. The LET statement can assign a NULL value to a TEXT or BYTE variable, but it cannot assign non-NULL values. The INTO clause of the SELECT statement can assign to a specied variable a TEXT or BYTE value from the database.
If the TEXT or BYTE variable has already been stored in memory, you can use the LOCATE statement again to reinitialize the variable. If a TEXT or BYTE variable has been initialized to memory or to a temporary le, you can use LOCATE to reinitialize the variable. You cannot reinitialize a TEXT or BYTE variable that is stored in a named le.
Omit a lename, so that 4GL places the value in a temporary le. Specify a variable that contains the name of a le in which to store the TEXT or BYTE value. The lename can include a pathname.
LOCATE
If the TEXT or BYTE variable has already been located in a temporary le, you can use the LOCATE statement again reinitializes the variable. You can specify multiple lenames by declaring an array of character variables. This example stores an array of lenames in an array of TEXT variables:
DEFINE flnames ARRAY[10] OF char(20), t_holds ARRAY[10] of TEXT i INTEGER FOR i = 1 TO 5 LET flnames[i] = "/u/db/profile", i, USING "<<&" LOCATE t_holds[i] IN FILE flnames[i] END FOR
Specifying a Filename
To place the TEXT or BYTE value in a specic le, the LOCATE statement can include either a literal lename, or else a character variable that contains the lename. This example uses a quoted string to specify the lename:
DEFINE analysis TEXT LOCATE analysis IN FILE "/u/db/analysis"
4-242
LOCATE
LOCATE
When it encounters the RETURN statement or the END FUNCTION or END REPORT keywords, 4GL frees any local TEXT or BYTE variables that are stored in memory or in a temporary le. 4GL does not, however, deallocate storage for TEXT and BYTE variables that are passed by reference as arguments to a function or to a report. Storage for such variables is deallocated when EXIT PROGRAM or END MAIN terminates the program. 4GL does not automatically remove a named le that is associated with a TEXT or BYTE variable. After you release the storage, you cannot access the TEXT or BYTE variable without executing a new LOCATE statement to initialize it. If you have named the le for the TEXT or BYTE value, and you want to retain the le, do not use the FREE statement. For information on the FREE statement, see the Informix Guide to SQL: Syntax.
LOCATE
References
DEFINE, EXIT, FUNCTION, GLOBALS, MAIN, INITIALIZE, REPORT, RETURN
4-244
MAIN
MAIN
The MAIN statement denes the MAIN program block.
MAIN
END MAIN
Element statement
Description is any SQL or other 4GL statement (except MAIN, FUNCTION, GLOBALS, NEED, PAUSE, PRINT, REPORT, RETURN, or SKIP).
Usage
Every 4GL program must have exactly one MAIN statement, which typically calls functions or reports to do the work of the application. The following fragment calls functions dened in the same module as the MAIN statement:
MAIN ... CALL get_states() CALL ring_menu() ... END MAIN FUNCTION get_states() ... END FUNCTION FUNCTION ring_menu() ... END FUNCTION
The MAIN statement cannot appear within another statement. It must be the rst program block of the module in which it appears, as in this example. The END MAIN keywords mark the end of the MAIN program block. The program terminates when it encounters these keywords.
INFORMIX-4GL Statements 4-245
MAIN
If it encounters the EXIT PROGRAM statement, the program terminates before END MAIN. The Interactive Debugger treats this as an abnormal termination.
A local variable has the highest precedence, so that within its scope, no identical identier of a global or module variable can be visible. Within the module in which it was declared, a module variable takes precedence over another with the same identier whose scope has been extended by the GLOBALS "lename" statement.
You should assign unique names to global and module variables that you intend to reference within the MAIN program block.
Any DATABASE statement that appears before the MAIN statement (but in the same module) species the default database at compile time. This database also becomes the current database at runtime, unless another DATABASE statement species a different database. Any DATABASE statement in the MAIN statement must follow the last DEFINE declaration. This database becomes the current database for subsequent SQL statements until the program ends, or until another DATABASE statement is encountered.
4-246
MAIN
References
DATABASE, DEFER, DEFINE, EXIT PROGRAM, FUNCTION, GLOBALS, REPORT
MENU
MENU
The MENU statement creates and displays a ring menu. From the keyboard, the user can choose menu options that execute blocks of statements.
MENU
"title"
variable
END MENU
Description is a quoted string that species a display label for the ring menu. If the string is empty, no menu title is displayed. is a CHAR or VARCHAR variable containing a display label.
Usage
This statement species and displays a ring menu that occupies two lines in the current 4GL window. You can use the MENU statement to accomplish these tasks:
s s s s s
Create and display a screen menu, including a title of the menu Dene and display a list of menu options that the user can select Specify a single-line description to display for each menu option Designate help message numbers for each menu option Specify a block of 4GL statements to execute for each menu option
Displays the menu title (and as many menu options as can t) in the Menu line of the current 4GL window. Moves the menu cursor to the rst option and displays its description The order of options is determined by the order of control blocks. The menu cursor marks the current menu option with a double border. (The term ring menu refers to a menu where moving the menu cursor beyond the last option returns it to the rst option.)
4-248
MENU
3.
Waits for the user to press the activation key for a MENU control block, or to terminate the MENU statement by pressing the Quit key or Interrupt key If the user presses an activation key, executes statements in the corresponding control block, until it encounters one of these statements:
s s
4.
EXIT MENU statement. 4GL then exits from the menu. CONTINUE MENU statement. 4GL skips any remaining statements in the MENU control block, and redisplays the menu.
Last statement in the MENU control block. 4GL redisplays the menu so that the user can choose another option.
A menu can appear above or below a screen form, but not within a form. 4GL displays the menu title and the menu options on the Menu line. This reserved line is positioned by the most recent MENU LINE specication in the OPTIONS or OPEN WINDOW statement. The default position is the rst line of the current 4GL window. Unless the title and at least one option can t on the screen or in the current 4GL window, a runtime error occurs. For information on multiple-page menus, and how the set of menu options acts like a ring for the menu cursor, see Scrolling the Menu Options on page 4-266. The title of a menu is just a display label; your program cannot reference a menu by name. To repeat the same menu and all its behavior in different parts of a program, you can include its MENU statement in a FUNCTION denition, so that you can invoke the function when you want the menu to appear. The following topics are described in this section:
s s s s s s s s s s
The MENU Control Blocks on page 4-250 Invisible Menu Options on page 4-257 The CONTINUE MENU Statement on page 4-259 The EXIT MENU Statement on page 4-259 The NEXT OPTION Clause on page 4-260 The HIDE OPTION and SHOW OPTION Keywords on page 4-260 Nested MENU Statements on page 4-262 The END MENU Keywords on page 4-263 Identiers in the MENU Statement on page 4-263 Choosing a Menu Option on page 4-265
INFORMIX-4GL Statements 4-249
MENU
s s
Completing the MENU Statement on page 4-268 COMMAND KEY Conicts on page 4-271
displayed)
s
an optional activation key to choose the option, and an optional help message number, identifying a help message to display if the user presses the Help key while this is the current option; 4GL executes the statements in this block when the user chooses the menu option)
s
Hidden option (a COMMAND clause that only species activation keys to execute a statement block if the key is pressed; no option name, description, nor help message number is specied)
The statement block can specify SQL or other 4GL statements to execute when a user presses a key sequence, as well as special MENU instructions:
s s
The next menu option to highlight with the menu cursor Whether to suppress or restore the display of one or more menu options Whether to exit from the MENU statement
4-250
MENU
MENU Control Block BEFORE MENU COMMAND Clause statement NEXT OPTION option
,
SHOW HIDE OPTION option ALL CONTINUE MENU EXIT MENU COMMAND Clause COMMAND option description HELP number
,
KEY
4 key
Description is a quoted string or the name of a CHAR or VARCHAR variable that contains an option description for the Menu help line. is a letter, a literal symbol in quotation marks, or a keyword. (Quotation marks are not required if key is a single letter of the alphabet.) This list of up to four activation keys must be enclosed in parentheses; see The KEY Clause on page 4-255. is an integer that identies the help message for this menu option. You must have used the OPTIONS statement previously to identify the help le containing the message. is a quoted string or the name of a CHAR or VARCHAR variable that contains the name of the menu option. This name cannot be longer than the width of the current 4GL window. is an SQL statement or other 4GL statement.
number
option
statement
The screen displays a ring menu of option names as menu options. The menu options appear in the same order in which you specify them in COMMAND clauses within the MENU statement.
MENU
You must include at least one non-hidden option (that is, one COMMAND clause with a non-null option) for each menu. Within the MENU control block that includes the COMMAND clause, you can include statements that perform the activity specied by the menu option. The description appears on the line below the menu when the option is current. The string length must not be longer than the width of the screen or 4GL window. See also Identiers in the MENU Statement on page 4-263.
Specifying values for variables used for the menu name, the names of options, and the strings containing descriptions of options Hiding or showing individual menu options Checking user access privileges
s s
If 4GL encounters the EXIT MENU statement here, no menu is displayed. The following program fragment includes statements that specify the name of the menu, the name of an option, and the option description at runtime:
DEFINE menu_name, opt_name CHAR(20) opt_desc CHAR(40), priv_flag SMALLINT LET menu_name = "SEARCH" LET opt_name = "Query" LET opt_desc = "Query for customers." IF ... LET priv_flag = 1 END IF MENU menu-name BEFORE MENU IF priv_flag THEN LET menu_name = "POWER SEARCH" LET opt_name = "Power Query" END IF COMMAND opt_name opt_desc HELP 12 IF priv_flag THEN CALL cust_find(1) ELSE CALL cust_find(2) END IF ... END MENU
4-252
MENU
The next BEFORE MENU clause initially hides all menu options. If the user is privileged, 4GL then displays all the menu options. If the user is not privileged, 4GL displays only the Query, Detail, Switch, and Exit menu options:
MENU menu_name BEFORE MENU HIDE OPTION ALL IF priv THEN LET menu_name = "PRIVILEGED SEARCH" SHOW OPTION ALL ELSE SHOW OPTION "Query", "Detail", "Switch", "Exit" END IF ... END MENU
,
KEY
4 key
For denitions of terms, see The MENU Control Blocks on page 4-250. Each COMMAND clause is part of a MENU control block whose statements perform the activity specied by the option description. To nest menus, you can include another MENU statement. The MENU control blocks might be easier to read if you use function calls to group statements. The COMMAND clause can optionally include a HELP clause to associate a help message number with the menu option. It can also include a KEY clause, to specify up to four activation keys that the user can press to choose the option; otherwise, 4GL recognizes default activation keys, based on the initial character of option. By default, when OPTION is highlighted, pressing the RETURN key has the same effect as pressing an activation key.
MENU
Optionally, you can include a description of the menu option in a COMMAND clause. The description appears on the line below the menu and is displayed when the option is highlighted.
4GL produces a runtime error if a menu option or its description exceeds the width of the screen or the width of the current 4GL window.
If the name and description of the menu option are omitted, the COMMAND clause produces no visual display, as described in Invisible Menu Options on page 4-257.
You can specify help messages (and their numbers) in an ASCII le whose lename appears in the HELP FILE clause of the OPTIONS statement. Use the mkmessage utility, as described in The mkmessage Utility on page B-2, to create a runtime version of the help le. A runtime error occurs if the help le cannot be opened, or if you specify a help number that is not dened in the help le, or that is greater than 32,767. An invisible menu option cannot have a Help clause.
4-254
MENU
One option is always marked as the current option. This option is marked by a double border, called the menu cursor.
MENU
The line under the menu options (the Menu help line) displays a description of the menu option, as specied in the COMMAND clause for that menu option. If the menu cursor moves to another option, the display in this line changes, unless you specify the same description for both menu options.
4GL executes the statements in the MENU control block if the user presses an activation key that you specify by key specication in the KEY clause:
s
Letters (Both upper- and lowercase letters are valid, but 4GL does not distinguish between them.) Symbols (such as !, @, or #) enclosed between quotation marks Any of the following keywords (in uppercase or lowercase letters):
DOWN INTERRUPT RETURN or ENTER ESC or ESCAPE LEFT RIGHT F1 through F64 CONTROL-char (except A, D, H, I, J, K, L, M, R, or X) TAB UP
s s
The following keys deserve special consideration before you assign them as activation keys in the KEY clause of a MENU statement.
Key
ESC or ESCAPE
Special Considerations You must use the OPTIONS statement to specify another key as the Accept key, because this is the default Accept key. You must include a DEFER INTERRUPT statement. When the user presses the Interrupt key under these conditions, 4GL executes the statements in the MENU control block and sets int_ag to non-zero, but does not terminate the MENU statement. 4GL also executes the statements in the control block if DEFER QUIT has been executed and the user presses the Quit key. In this case, 4GL sets quit_ag to non-zero. (1 of 2)
Interrupt
QUIT
4-256
MENU
Key
CONTROL-char A, D, H, K L, R, and X I, J, and M
Special Considerations
4GL reserves these keys for eld editing. The usual meanings of these keys (TAB, LINEFEED, and RETURN, respectively) are not available to the user. Instead, the key is trapped by 4GL and used to trigger the menu option. For example, if CONTROL-M appears in the KEY clause, the user cannot press RETURN to advance the cursor to the next eld. (2 of 2)
Some other control keys, such as S, Q, or Z also might not be allowed, depending on your implementation of UNIX. The key must be unique among all KEY clauses of the same MENU statement. You might not be able to specify other keys that have special meaning to your operating system. The key value also cannot be the default activation key of any other COMMAND clause. If you specify a letter here as the activation key, it must be different from the rst letter of any option of the same menu. See also COMMAND KEY Conicts on page 4-271.
key
Just as with visible options, the key value cannot be the activation key of any other COMMAND clause. If you specify a letter here as the activation key, it must be different from the rst letter of any option of the same menu.
MENU
The following MENU statement creates a menu named TOP LEVEL with six options, of which only ve appear in the menu display. The exclamation point ( ! ) key chooses an invisible option that is not displayed on the menu. Here a description and a help number are associated with each visible option:
MENU "TOP LEVEL" COMMAND "Add" "Add a row to the database" HELP 12 ... COMMAND "Find" "Find a row in the database" HELP 13 ... COMMAND "Change" "Update a row in the database" HELP 14 ... COMMAND "Delete" "Delete a row from the database" HELP 15 ... COMMAND KEY ("!") CALL bang() ... COMMAND "Exit" "Return to operating system" HELP 16 EXIT PROGRAM END MENU
At least one COMMAND clause, however, must include an option. You cannot specify a menu in which every option is invisible. If your application requires such a menu, the MENU statement can include a COMMAND clause in which the option is null (that is, an empty string), as in the following example:
MENU "" COMAND "" COMMAND KEY(UP) DISPLAY "Up " COMMAND KEY(DOWN) DISPLAY "Down " COMMAND KEY(LEFT) DISPLAY "Left " COMMAND KEY(RIGHT) DISPLAY "Right" COMMAND KEY(INTERRUPT) EXIT MENU END MENU
AT AT AT AT
This example would not be valid if the rst COMMAND clause were omitted.
4-258
MENU
Skips all statements between the EXIT MENU and END MENU keywords Deactivates the menu and erases the menu from the screen. Resumes execution at the rst statement after the END MENU keywords
s s
The following example demonstrates using the EXIT MENU keywords in the MENU block of a menu option named Exit:
MENU "CUSTOMER" ... COMMAND "Exit" "leave the CUSTOMER menu." HELP 5 EXIT MENU END MENU
MENU
(To exit from the current MENU control block without exiting from the MENU statement, use the CONTINUE MENU keywords rather than EXIT MENU.)
Without NEXT OPTION, 4GL would display Query as the current option; the user would have to make Modify the current option and then press RETURN. If you want the cursor to move among menu options in a certain order, list their dening COMMAND clauses in the desired order. Use the NEXT OPTION keywords only if you want to deviate from the default left-to-right order of the ring menu.
MENU
The following MENU statement creates a menu with seven options. The Long_menu option shows all options; the Short_menu options shows only the Query, Long_menu, and Exit options:
MENU "Order Management" COMMAND "Query" "Search for orders" CALL get_orders( ) COMMAND "Add" "Add a new order" CALL add_order( ) COMMAND "Update" "Update the current order" CALL upd_order( ) COMMAND "Delete" "Delete the current order" CALL del_order( ) COMMAND "Long_menu" "Display all menu options" SHOW OPTION ALL COMMAND "Short_menu" "Display a short menu" HIDE OPTION ALL SHOW OPTION "Query", "Long_menu", "Exit" COMMAND "Exit" "Exit from the Order Management Form" EXIT MENU END MENU
If you specify the options to hide by listing them in character variables, you must assign values to the variables before you can include the variables in a HIDE OPTION clause. (For more information about variables, see Identiers in the MENU Statement on page 4-263.) The ALL keyword in a SHOW OPTION or HIDE OPTION clause species all of the menu options that you created in any COMMAND clause. Use the SHOW OPTION keywords to restore a list of menu options that the HIDE OPTION keywords disabled. By default, 4GL displays all menu options. You only need to use this statement if you have previously specied the HIDE OPTIONS keywords to disable at least one menu option.
4GL displays menu options in the same order in which their COMMAND clauses dened them. The order in which a SHOW OPTION clause lists
options has no effect on the order of their subsequent appearance in the menu. Do not confuse hidden options with invisible options. Neither appears on the menu, but hidden options cannot be accessed by the user until after they have been enabled by the SHOW OPTION keywords. Invisible options have an activation key, but no command name. Their statement blocks can be accessed by pressing an activation key, but they do not appear in the menu.
MENU
The HIDE OPTION and SHOW OPTION keywords cannot affect invisible options, because (as their name suggests) invisible options are never displayed. Use some other approach to enable and disable invisible options; for example, you might specify their actions within a conditional statement. The following example MENU statement populates a menu with eight options. The Long_menu option shows all options; the Short_menu option shows only the Query, Details, Long_menu, and Exit options.
MENU "Order Management" COMMAND "Query" "Search for orders" CALL get_orders() COMMAND "Add" "Add a new order" CALL add_order() COMMAND "Update" "Update the current order" CALL upd_order() COMMAND "Delete" "Delete the current order" CALL del_order() COMMAND "Details" "Display details about current order" CALL det_order() COMMAND "Long_menu" "Display all menu options" SHOW OPTION ALL COMMAND "Short_menu" "Display a short menu" HIDE OPTION ALL SHOW OPTION "Query", "Details", "Long_menu", "Exit" COMMAND "Exit" "Exit the Order Management Form" EXIT MENU END MENU
The HIDE OPTION and SHOW OPTION keywords are valid in a BEFORE MENU clause or in a COMMAND clause. You must assign a value to a variable used to specify a menu option before you can include the variable in a HIDE OPTION statement.
4-262
MENU
The menu title The option name The option description The NEXT OPTION option name The SHOW OPTION or HIDE OPTION option name
Assignment statements can appear before 4GL executes the MENU statement or within the MENU statement. You can specify variable values in the BEFORE MENU block and in one or more of the subsequent MENU control blocks. Make sure, however, that a variable has a value before you include it in the MENU statement.
MENU
Keep the following considerations in mind if you change the value of a variable that was used as the menu title or as an option name in a MENU statement:
s
4GL determines the length of the menu title and of each option name
when it rst displays the menu. This length does not change during the MENU statement. If you subsequently assign a new value to a variable, 4GL displays as much of the new value as can t in the existing space. For example, suppose that you assign the string Short_Menu (10 characters) to a variable, and later specify that variable as a menu title. If a subsequent statement in a control block of the same MENU statement assigns the new value Very_Long_Menu (14 characters) to the variable, 4GL displays only the rst 10 characters of the new title. Similarly, if a second MENU control block assigns the value Menu (4 characters) to the variable that you specied as the menu title, 4GL displays the new title with 6 trailing blank spaces. For examples of using a variable as a menu title, an option name, and an option description in the MENU statement, see the program fragment in Completing the MENU Statement on page 4-268.
s
If you use an array element (for example, p_array[i]) as a variable in a MENU statement, be aware that 4GL calculates the value of the index variable only once, before it rst displays the menu. To index into the array, 4GL uses the value of the index variable after executing the BEFORE MENU block (if that block is included). Any subsequent changes to the index variable made in subsequent MENU CONTROL BLOCKS do not affect the way that 4GL evaluates the array element variable.
4GL produces a runtime error if the length of a variable or quoted string that
species a menu name, an option name, or an option description exceeds the width of the current 4GL window.
4-264
MENU
Using the arrow keys to position the menu cursor on the option and pressing RETURN (See also Scrolling the Menu Options on page 4-266.) Typing a key sequence that the KEY clause associated with the option Typing the rst letter or letters of the option name (regardless of whether the option is currently displayed on the screen)
s s
When the user types a letter, 4GL looks for a unique match among options:
s
If only one option begins with the letter, or only one option is associated in a KEY clause with the letter, the choice is unambiguous. 4GL executes the commands associated with the option. If more than one option begins with the same letter, 4GL clears the second line of the menu and prompts the user to clarify the choice. 4GL displays each keystroke, followed by the names of the menu options that begin with the typed letters. When 4GL identies a unique option, it closes this prompt line and executes the statements associated with the selected menu option.
For example, the next menu includes three options that begin with the letters Ma. The following screen is displayed when the user types the letter M:
Resorts: Oxnard Malaysia Malta Manteca Pittsburgh Portugal Exit Select: M Malay Malta Manteca
MENU
When the user types Mal, 4GL drops Manteca from the list and displays the two remaining options:
Resorts: Oxnard Malaysia Malta Manteca Pittsburgh Portugal Exit Select: Mal Malay Malta
At this point, the user can type an a to select Malay or a t to select Malta. The arrow keys have no effect when choosing among menu options that begin with the same letters. Pressing BACKSPACE deletes the keystroke to the left of the cursor.
4-266
MENU
If the user presses SPACEBAR or RIGHT ARROW to move past the right-most option (menu-option4 in this case), 4GL displays the next page of menu options. In the following example, the ellipses at both ends of the menu indicate that more menu options exist in both directions:
menu-name: ... menu-option5 menu-option6 menu-option7 menu-option8 ... optional Help line
If the user moves the highlight to the right past menu-option8 in this example, 4GL displays a page of menu options:
menu-name: ... menu-option9 menu-option10 menu-option11 menu-option12 optional Help line
Here no ellipsis appears at the right of the menu, because the user has come to the last page of the menu options. The user can display the previous page of menu options again by using to move the highlight past the left-most menu option, or can press to move past the right-most option to display the rst page, as if the rst option followed the last. (This is why 4GL menus are called ring menus.)
MENU
,
SPACEBAR
During interactive statements like INPUT, CONSTRUCT, or INPUT ARRAY, errors would be likely to result if the user could interrupt the interaction with menu choices. 4GL prevents this possibility by disabling the entire menu during the execution of these statements. The menu does not change its appearance when it is disabled.
By default, pressing the Interrupt key terminates program execution immediately. Unlike the CONSTRUCT, DISPLAY ARRAY, and INPUT statements, the MENU statement is not terminated by the Interrupt key if 4GL has executed the DEFER INTERRUPT statement. In these cases, an Interrupt signal causes 4GL to take the following actions:
s s
Set the global variable int_ag to a non-zero value. Remain in the MENU statement until EXIT MENU is encountered.
4-268
MENU
The EXIT MENU statement is typically included in a MENU control block that is activated when the user chooses an Exit or Quit option, as in the next example. If menus are nested, EXIT MENU terminates only the current MENU statement, passing control to the innermost enclosing MENU statement. In the following program fragment, the MENU statement uses variables for the menu name, command name, and option description:
DEFINE menu_name, command_name CHAR(10), option_desc CHAR(30), priv_flag SMALLINT LET menu_name = "NOVICE" LET command_name = "Expert" LET option_desc = "Display all menu options." IF ... THEN LET priv_flag = 1 END IF MENU menu_name BEFORE MENU HIDE OPTION ALL IF priv_flag THEN -- expert user LET menu_name = "EXPERT" LET command_name = "Novice" LET option_desc = "Display a short menu." SHOW OPTION ALL ELSE -- novice user SHOW OPTION "Query", "Detail", "Exit", command_name END IF COMMAND CALL COMMAND CALL COMMAND CALL NEXT "Query" "Search for rows." HELP 100 get_cust() "Add" "Add a new row." HELP 101 add_cust() "Update" "Update the current row." HELP 102 upd_cust() OPTION "Query"
COMMAND "Delete" "Delete the current row." HELP 103 CALL del_cust() NEXT OPTION "Query" COMMAND "Detail" "Get details." HELP 104 CALL det_ord() NEXT OPTION "Query" COMMAND command_name option_desc HELP 105 IF priv_flag THEN -- EXPERT menu visible LET menu_name = "NOVICE" LET command_name = "Expert" LET option_desc = "Display all menu options." HIDE OPTION ALL SHOW OPTION "Query", "Detail", "Exit", command_name LET priv_flag = 0 ELSE -- NOVICE menu visible LET menu_name = "EXPERT" LET command_name = "Novice" LET option_desc = "Display a short menu."
MENU
SHOW OPTION ALL LET priv_flag = 1 END IF COMMAND KEY ("!") CALL bang() COMMAND "Exit" "Leave the program." HELP 106 EXIT MENU END MENU
4-270
MENU
If the F3 key were pressed while this menu was active, the program entered an error state from which it could not recover. A submenu of the style used to resolve conicts of default activation keys in COMMAND option clauses (as illustrated in Choosing a Menu Option on page 4-265) appeared inappropriately with two invisible prompts:
Select: \072 (invisible) (invisible)
Such conicts between COMMAND KEY clauses always produced two (invisible) prompts, regardless of how many keys were acceptable to the COMMAND KEY clause. Any subsequent keystroke only rang the terminal bell, and so for the program to terminate, it had to be killed with a signal (such as the Interrupt or Quit key).
MENU
A related problem in 4GL releases earlier than 6.x is conict between a COMMAND clause and a COMMAND KEY clause, where the rst character of the COMMAND option, whether specied as a literal or as a variable, conicts with a printable character that can activate a COMMAND KEY clause. If the user pressed an ambiguous key (b in the following example), a submenu appeared with one side showing invisible:
MENU "main 1" COMMAND KEY (F3, "a", F22, F23) MESSAGE "This is F3, <a>, F22, or F23 only" SLEEP 1 COMMAND KEY (F4, "b") MESSAGE "This is F4 or <b> only" SLEEP 1 COMMAND "bark" "collides with command key (f4, b)" MESSAGE "This collides with command key (f4, b)" SLEEP 1
If the proper second letter was pressed (in this case), the menu proceeded normally; any other keystroke simply activated the terminal bell. In this release, the runtime menu library detects such collisions. If such a conict occurs, error -1176 is issued:
,A COMMAND KEY value occurs elsewhere in the current menu
and the program terminates. If you encounter error -1176, it means that a COMMAND KEY conict already exists in that menu. You need to revise the offending COMMAND KEY clauses to remove the conict.
References
CONTINUE, DEFER, OPEN WINDOW, OPTIONS
4-272
MESSAGE
MESSAGE
The MESSAGE statement displays a character string on the Message line. ,
MESSAGE
"string"
variable ATTRIBUTE Clause p. 3-96
Description is a quoted string that contains message text. is a CHAR or VARCHAR variable that contains message text.
Usage
You can specify any combination of variables and strings for the message text. 4GL generates the message to display by replacing any variables with their values and concatenating the strings. If the length of the message text exceeds the width of the screen or 4GL window, the text is truncated to t.
line according to default or explicit Message line specication for the program or for the current 4GL window, in this order of descending precedence:
1. 2. 3.
A MESSAGE LINE specication in the most recent OPTIONS statement A MESSAGE LINE specied in the most recent OPEN WINDOW statement The default Message line, or the second line of the current 4GL window
The message remains on the screen until you display a menu or another message.
INFORMIX-4GL Statements 4-273
MESSAGE
To clear the Message line, you can display a blank message, like this:
MESSAGE " "
You can include the CLIPPED and USING operators in a MESSAGE statement. For example, the following MESSAGE statement uses the CLIPPED operator to remove any trailing blanks from the string in the variable le_name:
DEFINE file_name CHAR(20) ... MESSAGE "Printing mailing labels to", file_name CLIPPED, " -- Please wait"
You can also use the ASCII and COLUMN operators. For information on using the 4GL built-in functions and operators, see Chapter 5. If you position the Message line so that it coincides with the Comment line, Menu line, or elds of a form, output from the MESSAGE statement is not visible. For example:
DATABASE stores MAIN DEFINE p_customer RECORD LIKE customer.* OPEN WINDOW r1 AT 4,1 WITH FORM "platonic" ATTRIBUTE (MESSAGE LINE LAST) MESSAGE "This is a word to the wise." INPUT BY NAME p_customer.* CLOSE WINDOW r1 END MAIN
This program does not display the text of the MESSAGE statement, because the default position of the Comment line is also the last line. If the ATTRIBUTE clause of OPEN WINDOW in the same example were revised to specify
ATTRIBUTE (MESSAGE LINE LAST, COMMENT LINE FIRST)
so that there was no conict between those reserved lines, the message text would appear when the MESSAGE statement was executed. For a description of the syntax used to position reserved lines, see the Positioning Reserved Lines sections of the OPEN WINDOW and OPTIONS statements.
4-274
MESSAGE
The default display attribute for the Message line is the NORMAL display. You can use the ATTRIBUTE clause to alter the default display attribute of the Message line. For example, the following statement changes the display attribute of the message text to reverse video:
MESSAGE "Please enter a value " ATTRIBUTE (REVERSE)
4GL ignores the INVISIBLE attribute if you include it in the ATTRIBUTE clause of the MESSAGE statement.
You can refer to substrings of CHAR, VARCHAR, and TEXT type variables by following the variable name with a pair of integers to indicate the starting and ending position of the substring, enclosed between brackets ( [ ] ) and separated by a comma. For example, the following MESSAGE statement displays a 10-character substring of the full_name variable:
MESSAGE "Customer ", full_name[11,20] CLIPPED, " added to the database"
Use a MESSAGE statement to clear the Message line of any text. Clear all the elds of the current form. Use a PROMPT statement to instruct the user to type a name. Assign the value of the entered string to the variable last_name. Use another MESSAGE statement to indicate to the user that the program is retrieving rows. Clear the second message after a three -second delay:
MESSAGE "" CLEAR FORM PROMPT "Enter a last name:" FOR last_name MESSAGE "Selecting rows for customer with last name ", last_name, ". . ." ATTRIBUTE (YELLOW) SLEEP 3 MESSAGE ""
References
DISPLAY, ERROR, OPEN WINDOW, OPTIONS, PROMPT
NEED
NEED
NEED is a conditional statement to control output from the PRINT statement. (The NEED statement can appear only in a REPORT program block.)
NEED lines LINES
Element lines
Description is an expression, as described in Integer Expressions on page 3-63, that species how many lines must remain in the current page between the line above the current character position and the bottom margin.
Usage
The NEED statement causes subsequent report output from the PRINT statement to start on the next page of the report, if fewer than the specied number of available lines remain between the current line of the page and the bottom margin. NEED has the effect of a conditional SKIP TO TOP OF PAGE, the condition being that the number returned by the integer expression must be greater than the number of lines that remain on the current page. The NEED statement can prevent 4GL from separating parts of the report that you want to keep together on a single page. In the following example, the NEED statement causes the PRINT statement to send output to the next page, unless at lease six lines remain on the current page:
AFTER GROUP OF r.order_num NEED 6 LINES PRINT " ",r.order_date, 7 SPACES, GROUP SUM(r.total_price) USING "$$$$,$$$,$$$.&&"
NEED does not include the BOTTOM MARGIN value in calculating the lines
available. If the number of lines remaining above the bottom margin on the page is less than lines, both the PAGE TRAILER and the PAGE HEADER are printed before the next PRINT statement is executed. You cannot include the NEED statement in the PAGE HEADER or PAGE TRAILER control blocks.
4-276
NEED
References
PAUSE, PRINT, REPORT, SKIP
OPEN FORM
OPEN FORM
The OPEN FORM statement declares the name of a compiled 4GL form.
OPEN FORM form FROM "lename"
Description is a quoted string that species the name of a le that contains the compiled screen form. This can also include a pathname. is a 4GL identier that you assign here as the name of the form.
Usage
The following steps describe how to display a form:
1. 2.
Create a form specication le (with a .per extension). Compile the form by using the Compile option of the Form menu in the Programmers Environment or by using the form4gl command. The compiled form le has .frm as its le extension. Declare the form name by using the OPEN FORM statement. Display the form by using the DISPLAY FORM statement.
3. 4.
Once 4GL displays the form, you can activate the form by executing the CONSTRUCT, DISPLAY ARRAY, INPUT, or INPUT ARRAY statement. When it executes the OPEN FORM statement, 4GL loads the compiled form into memory. (The CLOSE FORM statement is a memory-management feature to recover memory from forms that 4GL no longer displays on the screen.)
Specifying a Filename
The quoted string that follows the FROM keyword must specify the name of the le that contains the compiled screen form. This lename can include a pathname. You can omit or include the .frm extension:
OPEN FORM frmofmor FROM "/fomr/fmro.frm"
4-278
OPEN FORM
If you execute an OPEN FORM statement with the name of an open form, 4GL rst closes the existing form before opening the new form. The WITH FORM keywords of OPEN FORM both open and display a form in a 4GL window. You do not need to execute the OPEN FORM, DISPLAY FORM, and CLOSE FORM statements if you use the OPEN WINDOW statement to display the form. You also do not need to use the CLOSE FORM statement to release the memory allocated to the form. Instead, you can use the CLOSE WINDOW statement to close both the form and the 4GL window, and to release the memory. For example, the following statements open 4GL window w_cust2, call function cust_order( ), and then close the 4GL window:
OPEN WINDOW w_cust2 AT 10,15 WITH FORM "custorder" CALL cust_order() CLOSE WINDOW w_cust2
References
CLEAR, CLOSE FORM, CLOSE WINDOW, CURRENT WINDOW, OPEN WINDOW, OPTIONS INFORMIX-4GL Statements 4-279
OPEN WINDOW
OPEN WINDOW
The OPEN WINDOW statement declares and opens a 4GL window.
OPEN WINDOW window AT Clause WITH Clause OPEN WINDOW ATTRIBUTE Clause p. 4-284 AT top-line , left-offset
AT Clause
"lename"
variable
Description is a quoted string that species the le containing a compiled 4GL form. This can include a pathname and le extension. is an integer expression to specify the height, in lines. is an integer expression to specify the position of the left margin, in characters, where 0 = the left edge of the 4GL screen. is an integer expression to specify the position of the top line of the 4GL window, where 0 = the top of the 4GL screen. is a CHAR or VARCHAR variable that species the lename. is an integer expression to specify the width, in characters. is the identier declared here for the 4GL window to be opened.
4-280
OPEN WINDOW
Usage
A 4GL window is a rectangular area in the 4GL screen that can display a form, a menu, or output from the DISPLAY, MESSAGE, or PROMPT statement. The 4GL screen can display one or more 4GL windows concurrently. An OPEN WINDOW statement can have the following effects:
s s s s
Declares a name for the 4GL window Species the position of the 4GL window on the 4GL screen Denes the dimensions of the 4GL window, in lines and characters Species the display attributes of the 4GL window
The window identier must follow the rules for 4GL identiers (as described in 4GL Identiers on page 2-14) and be unique among 4GL windows in the program. Its scope is the entire program. You can use this identier to reference the same 4GL window in other statements (for example, CLEAR, CURRENT WINDOW, and CLOSE WINDOW). The following topics are described in this section:
s s s s s
The 4GL Window Stack on page 4-281 The AT Clause on page 4-282 The WITH ROWS, COLUMNS Clause on page 4-282 The WITH FORM Clause on page 4-283 The OPEN WINDOW ATTRIBUTE Clause on page 4-284
Saves any changes made to the current 4GL window Adds the new 4GL window to the window stack Makes the new 4GL window the current 4GL window
Other statements that can modify the window stack are CURRENT WINDOW and CLOSE WINDOW.
OPEN WINDOW
The AT Clause
The AT clause species the location of the top-left corner of the 4GL window. The location is relative to the entire 4GL screen and is independent of the position of any other 4GL windows. You must specify these coordinates as expressions that return positive integers within the following ranges:
s
The rst expression must return an integer between 1 and (max lines), where max is the maximum number of lines in the 4GL screen, and lines is the ROWS specication. The window begins on this line. The second expression must return a whole number between 1 and (length - characters), where length is the maximum number of characters that the 4GL screen can display on one line, and characters is the COLUMNS specication. This is the left margin.
A comma separates the two expressions in the AT clause. For example, the following statement opens a 4GL window with the top-left corner at the third line and the fth character position of the 4GL screen:
OPEN WINDOW o1 AT LENGTH("Mom"), 5 WITH 10 ROWS, 40 COLUMNS
The expression at the left of the ROWS keyword species the height of the 4GL window, in lines. This must be an integer between 1 and max, where max is the maximum number of lines that the 4GL screen can display. The integer expression after the comma at the left of the COLUMNS keyword species the width of the 4GL window, in characters. This must return a whole number between 1 and length, where length is the number of characters that your monitor can display on one line.
This statement opens a 4GL window 5 lines high and 74 characters wide:
OPEN WINDOW w2 AT 10, 12 WITH 5 ROWS, 74 COLUMNS
4-282
OPEN WINDOW
In addition to the lines needed for a form, allow room for the following reserved lines:
s
The Comment line. (By default, this is the last line of the 4GL window.) The Form line. (By default, this is line 3 of the 4GL window.) The Error line. (By default, this is the last line of the 4GL screen, not of the 4GL window.)
s s
4GL issues a runtime error if the 4GL window does not include sufcient lines in to display both the form and these additional reserved lines. To reduce the number of lines required by 4GL, you can dene the Form line as line 1 or 2, and change other reserved lines accordingly, such as the Prompt and Menu lines. For information on how to make these changes, see The OPEN WINDOW ATTRIBUTE Clause on page 4-284.
The minimum number of lines required to display a form in a 4GL window is the number of lines in the form, plus an additional line below the form for prompts, messages, and comments.
OPEN WINDOW
Here form line is the reserved line position on which to display the rst line of the form (by default, line 3) and form length is the number of lines in the screen layout of the SCREEN section of the form specication le. 4GL adds one line for the Comment line. Unless you specify FORM LINE in an ATTRIBUTE clause or in the OPTIONS statement, the default value of this sum is form length + 2. (For more information on screen layouts in 4GL forms, see SCREEN Section on page 6-15.) For example, the following statement opens a 4GL window called w1 and positions its top-left corner at the fth row and fth column of the 4GL screen. The WITH FORM clause opens and displays the custform form in this 4GL window. If custform were 10 lines long and the FORM LINE option were the default value (3), the height of w1 would be (10 + 3) = 13 lines:
OPEN WINDOW w1 AT 5, 5 WITH FORM "custform"
The WITH FORM clause is convenient if the 4GL window always displays the same form. If you use this clause, you do not need the OPEN FORM, DISPLAY FORM, or CLOSE FORM statement to open and close the form. The OPEN WINDOW WITH FORM statement opens and displays the form. The CLOSE WINDOW statement closes the 4GL window and the form. You cannot use the WITH FORM clause for the following purposes:
s s
To display more than one form in the same 4GL window To display a 4GL window larger than the default dimensions (as described earlier) when 4GL executes the WITH FORM clause
In these cases, you must specify explicit dimensions by using the WITH lines ROWS, characters COLUMNS clause. You must also execute the OPEN FORM, DISPLAY FORM, and CLOSE FORM statements to open, display, and close the form or forms explicitly. (You typically are not required to use the CLOSE FORM statement, which affects memory management, rather than the visual interface of your program.)
Specify a border for the 4GL window Display the 4GL window in reverse video or in a color Reposition the Prompt, Message, Menu, Form, and Comment lines
4-284
OPEN WINDOW
, (
WHITE YELLOW MAGENTA RED CYAN GREEN BLUE BLACK NORMAL BOLD DIM REVERSE BORDER PROMPT LINE FORM LINE MENU LINE MESSAGE LINE COMMENT LINE OFF Reserved Line Position p. 4-288
The color attributes are listed in the left-hand portion of the diagram. Besides these, you can also specify INVISIBLE as a color, but this specication has no effect in the OPEN WINDOW ATTRIBUTE clause. Without this clause, the attributes and reserved line positions have the following default values.
Attribute Color REVERSE BORDER PROMPT LINE line value MESSAGE LINE line value MENU LINE line value FORM LINE line value COMMENT LINE line value Default Setting The default foreground color on your terminal No reverse video No border FIRST (=1) FIRST + 1 (=2) FIRST (=1) FIRST + 2 (=3) LAST - 1 (for the 4GL screen) LAST (for all other 4GL windows)
OPEN WINDOW
For more information on valid reserved line values, see Positioning Reserved Lines on page 4-288. For more information about color and intensity attributes, see Chapter 3. If you specify a color or the REVERSE attribute in the ATTRIBUTE clause of an OPEN WINDOW statement, it becomes the default attribute for displays in the 4GL window, except for menus. You can override this default by specifying a different attribute in the ATTRIBUTE clause of the CONSTRUCT, DISPLAY, DISPLAY ARRAY, DISPLAY FORM, INPUT, or INPUT ARRAY statement.
For example, if you have a color monitor, the 4GL window specied in the following statement is displayed with the BLUE attribute:
OPEN WINDOW w2 AT 10, 12 WITH 5 ROWS, 40 COLUMNS ATTRIBUTE (BLUE)
4-286
OPEN WINDOW
The following diagram indicates the coordinates of the border enclosing the 5 x 30 4GL window that was specied in the preceding example:
(9,9) (9,40) +------------------------------+ | | | | | | | | | | +------------------------------+ (15,9) (15,40)
The coordinates of the top-left corner of the window border are 9, 9. The 4GL window itself starts at 10, 10.
4GL draws the window with the characters dened in the termcap or
terminfo le. You can specify alternative characters in these les. Otherwise, 4GL uses the hyphen (-) for horizontal lines, the vertical bar (|) for vertical lines, and the plus sign (+) for corners. Some termcap or terminfo les have settings that require additional rows and columns to display windows. For more information, see Appendix F, Modifying termcap and terminfo. If a window and its border exceed the physical limits of the screen, a runtime error occurs. See also the built-in FGL_DRAWBOX( ) function, which displays rectangles (in Chapter 5).
OPEN WINDOW
+
integer
LAST
Line values specied in the OPTIONS ATTRIBUTE clause of the most recently executed OPTIONS statement can position the Form, Prompt, Menu, Message, Comment, and Error lines. (For more information, see Positioning Reserved Lines on page 4-295.) If no line positions are specied in the OPTIONS ATTRIBUTE or OPEN WINDOW ATTRIBUTE clauses, the 4GL window uses the following default positions for its reserved lines.
Default Location First line Second line Third line Last line Reserved for Prompt line (output from PROMPT statement); also Menu line (command value from MENU statement) Message line (output from MESSAGE statement; also the description value output from MENU statement) Form line (output from DISPLAY FORM statement) Comment line in any 4GL window except SCREEN
These positional values are relative to the rst or last line of the 4GL window, rather than to the 4GL screen. (The Error line is always the last line of the 4GL screen.) When you open a new 4GL window, however, the OPEN WINDOW ATTRIBUTE clause can override these defaults for every reserved line (except the Error line). This disables the OPTIONS statement reserved line specications only for the specied 4GL window.
4-288
OPEN WINDOW
Except for the cases that are described later in this section, you can specify any of the following positions for the reserved lines of 4GL:
s s s s s
integer
LAST - integer LAST
Here integer is a literal or variable that returns a positive whole number, such that the LINE specication is no greater than the number of lines in the 4GL window. This is true for all reserved lines except:
s
The Menu line: do not specify LAST A menu requires two lines. The menu title and commands appear on the Menu line, and command description appears on the next line. To display a menu at the bottom of a 4GL window, specify MENU LINE LAST - 1.
FIRST is the rst line of the 4GL window (line 1), and LAST is the last line. The
If a 4GL window is not large enough to contain the specied value for one or more of these reserved lines, 4GL increases its line value to FIRST or decreases it to LAST, whichever is appropriate. If the 4GL window is not wide enough to display all the text that you specify, 4GL truncates the message. You can use these features to display text:
s s s s
PROMPT statement MESSAGE statement DISPLAY statement COMMENTS attribute of a screen form
OPEN WINDOW
Because the position of the Error line is relative to the 4GL screen, rather than to the current 4GL window, the ATTRIBUTE clause of an OPEN WINDOW statement cannot change the location of the Error line. Use the OPTIONS statement to change the position of the Error line. (For details, see Features Controlled by OPTIONS Clauses on page 4-292.) Because the INPUT statement clears both the Comment line and the Error line when moving between elds, do not use either of the following settings for the Message or Prompt line:
s s
The last line of the 4GL window (the default Comment line) The last line of the 4GL screen (the default Error line)
If you intend to use these lines for messages or prompts, be sure to redene the Comment and Error lines too.
If you use this syntax, the Comment line is hidden for that 4GL window and cannot display messages from the form specication, even if some elds of a form that this window displays have the COMMENTS attribute.
References
CLEAR, CLOSE FORM, CLOSE WINDOW, CURRENT WINDOW, DISPLAY, MESSAGE, OPEN FORM, OPTIONS, PROMPT
4-290
OPTIONS
OPTIONS
The OPTIONS statement sets default features of screen interaction statements. ,
OPTIONS COMMENT ERROR FORM MENU MESSAGE PROMPT ACCEPT DELETE INSERT NEXT PREVIOUS HELP DISPLAY INPUT FILE " lename " ATTRIBUTE WRAP NO WRAP FIELD ORDER UNCONSTRAINED CONSTRAINED SQL INTERRUPT PIPE RUN IN FORM MODE IN LINE MODE ON OFF OPTIONS ATTRIBUTE Clause p. 4-297 KEY key LAST LINE FIRST
+
number
Description is a quoted string that species the name of a le that contains the compiled help messages. This can include a pathname. is a keyword to specify a physical or logical key. is a literal integer to specify a line number. INFORMIX-4GL Statements 4-291
OPTIONS
Usage
The OPTIONS statement species default features for form-related statements and for other 4GL screen-interaction statements. The following topics are described in this section:
s s s s s s s s
Features Controlled by OPTIONS Clauses on page 4-292 Positioning Reserved Lines on page 4-295 Cursor Movement in Interactive Statements on page 4-296 The OPTIONS ATTRIBUTE Clause on page 4-297 The HELP FILE Option on page 4-299 Assigning Logical Keys on page 4-299 Interrupting SQL Statements on page 4-301 Setting Default Screen Modes on page 4-307
Positions of the reserved lines of 4GL Input and display attributes Logical key assignments The name of the Help le Whether SQL statements can be interrupted Field traversal constraints The default screen display mode
4-292
OPTIONS
If you omit the OPTIONS statement, 4GL uses defaults that are described in the following table.
Clause COMMENT LINE Effect Species the position of the Comment line. This displays messages dened with the COMMENT attribute in the form specication le. The default is (LAST - 1) for the 4GL screen, and LAST for all other 4GL windows. Species the position in the 4GL screen of the Error line that displays text from the ERROR statement. The default is the LAST line of the 4GL screen. Species the position of the rst line of a form. The default is (FIRST + 2), or line 3 of the current 4GL window. Species the position of the Menu line. This displays the menu name and options, as dened by the MENU statement. The default is the FIRST line of the 4GL window. Species the position of the Message line. This reserved line displays the text listed in the MESSAGE statement. The default is (FIRST + 1), or line 2 of the current 4GL window. Species the position of the Prompt line, to display text from PROMPT statements. The default value is the FIRST line of the 4GL window. Species the key to terminate an CONSTRUCT, INPUT, INPUT ARRAY, or DISPLAY ARRAY statement. The default is ESCAPE. Species the key in INPUT ARRAY statements to delete a screen record. The default Delete key is F2. Species the key to open a screen record for data entry in INPUT ARRAY. The default Insert key is F1. Species the key to scroll to the next page of a program array of records in an INPUT ARRAY or DISPLAY ARRAY statement. The default Next key is F3. (1 of 2)
ERROR LINE
FORM LINE
MENU LINE
MESSAGE LINE
PROMPT LINE
ACCEPT KEY
OPTIONS
Effect Species the key to scroll to the previous page of program records in an INPUT ARRAY or DISPLAY ARRAY statement. The default Previous key is F4. Species the key to display help messages. The default Help key is CONTROL-W. Species the le (produced by the mkmessage utility) containing programmer-dened help messages. Species default attributes to use during a DISPLAY or DISPLAY ARRAY statement when none is specied by those statements or in the form specication le. Species the attributes to use during a CONSTRUCT or INPUT statement when no attributes are specied by those statements or in the form specication le. Species that the cursor does not wrap. An INPUT or CONSTRUCT statement terminates when a user presses RETURN after the last eld. This is the default value. Species that the cursor wraps between the last and rst input elds during INPUT, INPUT ARRAY, and CONSTRUCT statements, until the user presses the Accept key. Pressing RETURN at the last eld does not deactivate the form. Species that the UP ARROW key moves the cursor to the previous eld and the DOWN ARROW key moves the cursor to the next eld when users enter values for CONSTRUCT or INPUT statements. Species that the UP ARROW key moves the cursor to the eld above the current position and the DOWN ARROW key moves the cursor to the eld below the current cursor position when users enter values for CONSTRUCT or INPUT statements. Species that the user can interrupt SQL statements as well as 4GL statements. Species that the user cannot interrupt SQL statements. (2 of 2)
INPUT ATTRIBUTE
INPUT NO WRAP
INPUT WRAP
4-294
OPTIONS
integer
LAST - integer LAST
Here integer is a variable or a literal that returns a positive whole number, such that the LINE specication is no greater than the number of lines in the 4GL window or 4GL screen, except for these reserved lines:
s s
The Form line: do not specify LAST or LAST - integer The Menu line: do not specify LAST
A menu requires two lines. The menu title and commands appear on the Menu line, and the command description appears on the following line. If you want a menu to appear at the bottom of a 4GL window, specify MENU LINE LAST - 1.
FIRST is the top line of the current 4GL window (line 1), and LAST is the last
line. For example, the following statement sets three reserved line positions:
OPTIONS MENU LINE 20, PROMPT LINE LAST-2, FORM LINE FIRST
The line position for the Error line is relative to the 4GL screen, rather than to the current 4GL window. The line value of any other reserved line is relative to the rst line of the current 4GL window (or to the 4GL screen, if that is the current 4GL window). If the 4GL window is not wide enough to display all the message text that you specify, 4GL truncates the message. You can use these features of 4GL to display message text:
s s s s s
PROMPT statement MESSAGE statement DISPLAY statement ERROR statement COMMENTS attribute of a form specication le
OPTIONS
Because the INPUT statement clears both the Comment line and the Error line when the cursor moves between elds, it is not a good idea to set the Message line or the Prompt line to either of the following positions:
s s
The last line of the current 4GL window (the default Comment line) The last line of the 4GL screen (the default Error line)
If a 4GL window is not large enough to contain the specied value for one or more of these reserved lines, 4GL automatically decreases the position value to FIRST or increases it to LAST, as appropriate. If the value that you specify for the Prompt line exceeds the number of rows in the current window, PROMPT LINE is set to its default value, the rst row of the window. Default line positions set by OPTIONS remain in effect until another OPTIONS statement redenes them. They can also be reset by the ATTRIBUTE clause of the OPEN WINDOW statement (as described in Positioning Reserved Lines on page 4-288), but only for the specied 4GL window; after it closes, the reserved line positions are restored to their values from the most recently executed OPTIONS statement.
4-296
OPTIONS
,
BLINK REVERSE UNDERLINE
This clause can specify features for input statements (CONSTRUCT, INPUT, and INPUT ARRAY) and for display statements (DISPLAY and DISPLAY ARRAY):
s s s
The attributes of the foreground of the 4GL window Whether to use input attributes of the current form or 4GL window Whether to use display attributes of the current form or 4GL window
OPTIONS
If this clause conicts with another attribute specication, 4GL applies the precedence rules that are listed in Precedence of Attributes on page 3-98. Any attribute dened by the OPTIONS statement remains in effect until 4GL encounters an ATTRIBUTES clause that redenes the same attribute in one of the following statements:
s s s
An ATTRIBUTE clause of an OPEN WINDOW, CONSTRUCT, INPUT, DISPLAY, or DISPLAY ARRAY statement only temporarily redenes the attributes. After the 4GL window closes (in the case of an OPEN WINDOW statement) or after the statement terminates (in the case of an input or display statement), 4GL restores the attributes from the most recent OPTIONS statement. The FORM keyword in INPUT ATTRIBUTE or DISPLAY ATTRIBUTE clauses instructs 4GL to use the input or display attributes of the current form. In the following example, 4GL uses the display attributes from the form specication le:
OPTIONS DISPLAY ATTRIBUTE (FORM)
Similarly, you can use the WINDOW keyword of the same options to instruct 4GL to use the input or display attributes of the current 4GL window. You cannot combine the FORM or WINDOW attributes with any other attributes.
4-298
OPTIONS
For example, this statement redenes the Next Page and Previous Page keys:
OPTIONS NEXT KEY CONTROL-N, PREVIOUS KEY CONTROL-P
The keyword NEXTPAGE is a synonym for NEXT in 4GL statements (like CONSTRUCT, DISPLAY ARRAY, INPUT, MENU, OPTIONS, and PROMPT) that reference the Next Page key. Similarly, the keyword PREVPAGE is a synonym for PREVIOUS in statements that reference the Previous Page key.
OPTIONS
The following table lists keys that require special consideration before you assign them in an OPTIONS statement.
Key
ESC or ESCAPE
Special Considerations You must specify another key as the Accept key because ESCAPE is the default Accept key. Reassign the Accept key in the OPTIONS statement. You must rst execute a DEFER INTERRUPT statement. When the user presses the Interrupt key under these conditions, 4GL executes the statements in the ON KEY block and sets the global variable int_ag to non-zero, but does not terminate the current statement. 4GL also executes the ON KEY statement block if the DEFER QUIT statement has executed and the user presses the Quit key. In this case, 4GL sets the quit_ag variable for the current task to non-zero.
Interrupt
4GL reserves these keys for eld editing. The standard meaning of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user. Instead, the key is trapped by 4GL and used to trigger the commands in the OPTIONS statement. For example, if CONTROL-M appears in an OPTIONS statement, the user cannot press RETURN to advance the cursor to the next eld. If you include one of these keys in an OPTIONS statement, also restrict the scope of the statement.
You might not be able to use other keys that have special meaning to your version of the operating system. For example, CONTROL-C, CONTROL-Q, and CONTROL-S specify the Interrupt, XON, and XOFF signals on many systems. To disable a key function, you can assign it to a control sequence that will never be executed. For example, the editing control sequences (CONTROL-A, -D, -H, -K, -L, -R, and -X) are always interpreted as eld editing commands. If you assign one of these control sequences to a key function, 4GL executes the editing sequence instead of the key function. For example, the following statement disables the Delete key:
OPTIONS DELETE KEY CONTROL-A
4-300
OPTIONS
After 4GL processes this statement, the user is no longer able to delete rows in a screen array.
If the program contains the DEFER INTERRUPT statement, 4GL sets the int_ag built-in variable to TRUE and continues execution. If the program does not contain DEFER INTERRUPT, 4GL terminates the program.
For more information on the actions of the DEFER INTERRUPT statement, see the DEFER statement on page 4-78. To enable the Interrupt key to interrupt SQL statements, your program must contain:
s s
the DEFER INTERRUPT statement. the OPTIONS statement with the SQL INTERRUPT ON option.
OPTIONS
When your program contains both these statements, 4GL takes the following actions when the user presses the Interrupt key:
1.
Tells the database server to terminate the current SQL statement. The SQL statements in the following table can be terminated.
SQL Statement ALTER INDEX ALTER TABLE CREATE INDEX DELETE FETCH INSERT OPEN SELECT UPDATE Includes implicit FETCH during a FOREACH Includes INSERT performed during a LOAD If SELECT stores all the data in a temporary table Includes SELECT performed during an UNLOAD Can be interrupted by Informix Dynamic Server only Considerations Can be interrupted by Informix Dynamic Server only
If the interrupted SQL statement is within a database transaction, the database server must handle the interrupted transaction. For more information, see Interrupting Transactions on page 4-303.
2. 3. 4.
Sets the built-in int_ag to TRUE. Sets the global SQLCA.SQLCODE and status variables to error code -213. Continues execution with the statement following the interrupted SQL statement, if your program has the WHENEVER ERROR CONTINUE compiler directive in effect; otherwise, the program terminates.
For SQL statements not listed in the preceding table, 4GL will allow the statement to complete before setting the built-in int_ag variable. It will then continue execution with the statement following the SQL statement (if your program has the WHENEVER ERROR CONTINUE compiler directive in effect).
4-302
OPTIONS
If the DEFER QUIT statement has been executed and the user presses the Quit key (or sends a SIGQUIT signal), 4GL takes the same four actions, except that it sets the global variable quit_ag, rather than int_ag. If you specify SQL INTERRUPT ON, but later in the program you wish to disable the SQL interruption feature, execute an OPTIONS SQL INTERRUPT OFF statement. This statement restores the default of uninterruptable SQL statements.
Interrupting Transactions
Interrupting an SQL statement has consequences for database transactions. In typical 4GL applications, the SQL INTERRUPT ON feature is of very limited value unless the database supports transaction logging. How to handle an interrupted SQL statement depends on whether the database is ANSIcompliant and on what type of transaction includes the SQL statement:
s
an explicit transaction. This starts with a BEGIN WORK statement and ends with either the COMMIT WORK (save the transaction) or ROLLBACK WORK (cancel the transaction) statement. a singleton transaction. An SQL statement that is not within an explicit transaction (preceded by BEGIN WORK) is in a transaction of its own. The transaction ends when the SQL statement completes.
In ANSI-compliant databases, a transaction is always in effect. Transactions in such databases are called implicit transactions.
In all three cases, the WORK keyword is optional in transaction management statements. Your code might be easier to read, however, if you include it.
In ANSI-compliant databases, a transaction is always in effect. BEGIN WORK is not needed because any COMMIT WORK or ROLLBACK WORK statement that ends a transaction automatically marks the beginning of a new implicit transaction. No SQL statement can be executed outside of a transaction. If a user interrupts an implicit transaction, no automatic ROLLBACK WORK occurs. The current transaction is still in progress.
INFORMIX-4GL Statements 4-303
OPTIONS
Informix Dynamic Server All interruptable SQL statements: automatic undo of SQL statement. INFORMIX-SE All interruptable SQL statements (ALTER INDEX and CREATE INDEX are not interruptable): no automatic undo for current SQL statement (interrupted statement can be in a partially completed state). The current transaction is still in progress.
4-304
OPTIONS
The int_ag built-in variable: if your program contains the DEFER INTERRUPT statement, int_ag will have a value of TRUE if the user presses the Interrupt key during an interruptable SQL statement. The SQLCA.SQLCODE or status built-in variables, if the interruptable SQL statement is preceded by the WHENEVER ERROR CONTINUE statement. This variable will have the value of -213 if the SQL statement failed due to user interruption.
If the database is in an unknown state, your program should explicitly perform a ROLLBACK WORK statement. The ROLLBACK WORK statement reverses the current transaction while the COMMIT WORK statement commits all modications made to the database since the beginning of the transaction. To begin a new transaction, you must use the BEGIN WORK statement.
ANSI
In ANSI-compliant databases, the ROLLBACK WORK statement reverses the current implicit transaction and automatically begins a new transaction. No BEGIN WORK statement is needed. Avoid use of the COMMIT WORK statement when the database is in an unknown state. The following code fragment checks for an interrupted DELETE statement. This fragment assumes that the database server is not ANSI-compliant but that it supports transaction logging. Therefore the current transaction is explicit (not a singleton).
DEFER INTERRUPT OPTIONS SQL INTERRUPT ON ... OPEN WINDOW w_purge AT 2,2 WITH 10 ROWS, 50 COLUMNS ATTRIBUTE (BORDER, PROMPT LINE 9) DISPLAY "ACCOUNT PURGE" AT 1, 2 DISPLAY "Purging customer account of last year's info...." AT 3, 2 DISPLAY "Press Cancel to interrupt." AT 4, 2
OPTIONS
LET cancelled = FALSE LET tx_status = 0 BEGIN WORK UNLOAD TO filename SELECT * FROM accthistory WHERE customer_num = cust_num AND tx_date < start_fiscal IF int_flag THEN LET int_flag = FALSE IF (SQLCA.SQLCODE < 0) THEN IF (SQLCA.SQLCODE = -213) THEN LET cancelled = TRUE ELSE LET tx_status = SQLCA.SQLCODE END IF END IF ELSE DELETE FROM accthistory WHERE customer_num = cust_num AND tx_date < start_fiscal IF int_flag THEN IF (SQLCA.SQLCODE < IF (SQLCA.SQLCODE LET cancelled = ELSE LET tx_status = END IF END IF END IF END IF
IF (tx_status < 0) OR cancelled THEN ROLLBACK WORK IF cancelled THEN ERROR "Account purge terminated at user request. ", " No information purged." ELSE ERROR "Account purge terminated (status=", tx_status USING "-<<<<<<<<<<<", "). No information purged." END IF ELSE COMMIT WORK MESSAGE "Account purge complete." END IF CLOSE WINDOW w_purge
For more information on data integrity, refer to the Informix Guide to SQL: Syntax.
4-306 IBM Informix 4GL Reference Manual
OPTIONS
After IN LINE MODE is specied, the terminal is in the same state (in terms of stty options) as when the program began. This usually means that the terminal input is in cooked mode, with interrupts enabled, and input not becoming available until after a newline character is typed. The IN FORM MODE keywords specify raw mode, in which each character of input becomes available to the program as it is typed or read. By default, 4GL programs operate in line mode, but so many statements take it into formatted mode (including OPTIONS statements that set keys, DISPLAY AT, OPEN WINDOW, DISPLAY FORM, and other screen interaction statements), that typical 4GL programs are actually in formatted mode most of the time. The default behavior for PIPE is IN FORM MODE (in which the screen is not cleared), for compatibility with releases earlier than INFORMIX-4GL 6.0. This mode is the opposite of the default screen mode for RUN specications. When the OPTIONS statement species RUN IN FORM MODE, the program remains in formatted mode if it currently is in formatted mode, but it does not enter formatted mode if it is currently in line mode. When the OPTIONS statement species RUN IN LINE MODE, the program remains in line mode if it is currently in line mode, and it switches to line mode if it is currently in formatted mode.
References
CONSTRUCT, DISPLAY, DISPLAY ARRAY, DISPLAY FORM, ERROR, INPUT, INPUT ARRAY, MENU, MESSAGE, OPEN FORM, OPEN WINDOW, PROMPT
OUTPUT TO REPORT
OUTPUT TO REPORT
The OUTPUT TO REPORT statement passes a single set of data values (called an input record) to a REPORT statement. ,
OUTPUT TO REPORT report
Description is the name of a TEXT or BYTE variable to be passed to the report. is the name of a 4GL report by which to format the input record. You must also declare this identier in a REPORT statement and invoke the report with a previous START REPORT statement.
Usage
The OUTPUT TO REPORT statement passes data to a report and instructs 4GL to process and format the data as the next input record of the report. An input record is the ordered set of values returned by the expressions that you list between the parentheses. Returned values are passed to the specied report, as part of the input record. The input record can correspond to a retrieved row from the database, or to a 4GL program record, but 4GL does not require this correspondence. The members of the input record that you specify in the expression list of the OUTPUT TO REPORT statement must correspond to elements of the formal argument list in the REPORT denition in their number and their position, and must be of compatible data types (see Summary of Compatible 4GL Data Types on page 3-46).
4-308
OUTPUT TO REPORT
Arguments of the TEXT and BYTE data types are passed by reference rather than by value; arguments of other data types are passed by value. A report can use the WORDWRAP operator with the PRINT statement to display TEXT values. (For more information, see The WORDWRAP Operator on page 7-65.) A report cannot display BYTE values; the character string <byte value> in output from the report indicates a BYTE value. You typically include the OUTPUT TO REPORT statement within a WHILE, FOR, or FOREACH loop, so that the program passes data to the report one input record at a time. The portion of the 4GL program that includes START REPORT, OUTPUT TO REPORT, and FINISH REPORT statements that reference the same report is sometimes called the report driver. (For more information about 4GL reports, see Chapter 7.)The following program fragment uses a FOREACH loop to pass input records to a report:
START REPORT cust_list ... FOREACH q_curs INTO p_customer.lname, p_customer.company OUTPUT TO REPORT cust_list (p_customer.lname, p_customer.company, "San Francisco", TODAY) END FOREACH
The lname and company values from columns of a database table The literal string constant "San Francisco" The DATE value returned by the TODAY operator
The following program creates a report, with default formatting, of all the customers in the customer table, and sends the resulting output to a le:
DATABASE stores7 MAIN DEFINE p_customer RECORD LIKE customer.* DECLARE q_curs CURSOR FOR SELECT * FROM customer START REPORT cust_list TO "cust_listing" FOREACH q_curs INTO p_customer.* OUTPUT TO REPORT cust_list(p_customer.*) FINISH REPORT cust_list END MAIN REPORT cust_list(r_customer) DEFINE r_customer RECORD LIKE customer.* FORMAT EVERY ROW END REPORT
OUTPUT TO REPORT
If OUTPUT TO REPORT is not executed, no control blocks of the report denition are executed, even if your report driver also includes the START REPORT and FINISH REPORT statements.
References
CALL, FINISH REPORT, PAUSE, REPORT, START REPORT, TERMINATE REPORT
4-310
PAUSE
PAUSE
The PAUSE statement suspends the display of output from a 4GL report to the 4GL screen. The PAUSE statement can only appear in the FORMAT section of a REPORT program block and only affects report output sent to the screen.
PAUSE
"string "
Element string Description is a quoted string.
Usage
The PAUSE statement affects the behavior of the report output in the 4GL screen as follows. It has no effect on the formatted report output.
s
If a PAUSE statement appears in the REPORT denition, the report displays a screenful of output and then pauses. The user needs to press RETURN to view the next screenful of output. If a quoted string is specied, its text appears on the 4GL screen. In the absence of a PAUSE statement, the report output scrolls down the 4GL screen.
The PAUSE statement has no effect if you include a REPORT TO clause in the OUTPUT section, or a TO clause in the START REPORT statement.
References
NEED, PRINT, REPORT, SCROLL, SKIP, START REPORT
PREPARE
PREPARE
Use the PREPARE statement to parse, validate, and generate an execution plan for SQL statements in a 4GL program at runtime. ,
PREPARE statement identier FROM
"string"
variable
Description is an SQL statement identier. This must be unique (within its scope) among the names of prepared statements and cursors. is a quoted string containing part or all of the text of one or more SQL statements to be prepared. is a variable containing text of one or more SQL statements to be prepared.
Usage
This statement assembles the text of an SQL statement at runtime and makes it executable. This dynamic form of SQL is accomplished in three steps:
1. PREPARE accepts SQL statement text as input, either as a quoted
string or stored within a character variable; this text can contain question mark ( ?) placeholders to represent data values that the user must specify at runtime when the statement is executed.
2.
The EXECUTE or OPEN statement can supply input values in the USING clause and can execute the prepared statement once or many times. Resources allocated to the prepared statement can be released later by the FREE statement.
3.
For more about FREE, EXECUTE, and OPEN, see the documentation of your Informix database server. See also SQL on page 4-349, which describes an alternative to PREPARE for using SQL statements in 4GL programs.
4-312
PREPARE
Important: You cannot reference a 4GL variable in the text of a prepared statement. Use an SQLEND SQL block, rather than PREPARE, for SQL statements that cannot be embedded, but that require host variables as input or output parameters. The number of prepared objects in a single program is limited only by available memory. Prepared objects include both statement identiers named in PREPARE statements and cursor declarations that incorporate SELECT, EXECUTE PROCEDURE, or INSERT statements. (To deallocate these objects, you can use a FREE statement to release some statements or cursors.) The following topics are described in this section:
s s s s s s s s s s
Statement Identier on page 4-313 Statement Text on page 4-314 Preparing a SELECT Statement on page 4-315 Statements That Can or Must Be Prepared on page 4-315 Statements That Cannot Be Prepared on page 4-317 Using Parameters in Prepared Statements on page 4-319 Preparing Statements with SQL Identiers on page 4-321 Preparing Sequences of Multiple SQL Statements on page 4-321 Runtime Errors in Multistatement Texts on page 4-322 Using Prepared Statements for Efciency on page 4-323
Statement Identier
The PREPARE statement sends statement text to the database server where it is analyzed. If it contains no syntax errors, the text is converted to an internal form. This translated statement is saved for later execution in a data structure that the PREPARE statement allocates. The structure has the name specied by the statement identier in the PREPARE statement. Subsequent SQL statements can refer to the prepared statement by using the statement identier. By default, the scope of reference of a statement identier is the 4GL module in which it was declared. The identier of a statement that was prepared in one 4GL module cannot be referenced from another module. To reference a statement identier outside the module in which it was declared, compile the module in which it is declared with the -globcurs option.
PREPARE
For some database servers, unless you use the -global command-line option to compile your program, the name cannot be longer than nine characters. Read the documentation for your database server to see if this restriction on the length of statement identiers affects your application. A subsequent FREE statement identier statement releases the resources allocated to the prepared statement. After FREE releases it, the statement identier cannot be referenced by a cursor, or by the EXECUTE statement, until you prepare the statement again. A statement identier can represent only one SQL statement (or one sequence of statements) at a time. You can execute a new PREPARE statement with an existing statement identier if you wish to assign the text of a different SQL statement to the statement identier.
Statement Text
The statement text can be a quoted string or text stored in a variable. The following restrictions apply to the statement text:
s
Text can contain only SQL or SPL statements. Not valid are 4GL statements that are not SQL statements, C or C++ statements, or SQL statements that cannot be prepared (as listed in Statements That Cannot Be Prepared on page 4-317). The text can contain either a single SQL statement or a sequence of statements. If the text contains more than a single statement, successive statements must be separated by semicolons. Comments preceded by two hyphens (-- ), or enclosed in braces ( { } ) are allowed in the statement text. The comment ends at the end of the line (after -- ) or at the right-brace ( } ); see also Comments on page 2-8. The pound sign ( # ) symbol is not valid here as a comment indicator. Comment text is restricted to the code set of the locale. The only valid identiers are SQL names of database entities, such as tables and columns. You cannot prepare a SELECT statement that contains an INTO variable clause, which requires a 4GL variable. The question mark (?) placeholder can indicate where a data value (but not an SQL identier) needs to be supplied at runtime.
4-314
PREPARE
The following example includes placeholders for values that are to be input:
PREPARE nt FROM "INSERT INTO cust(fname,lname) VALUES(?,?)"
PREPARE
You must prepare most SQL statements that include syntax introduced after Version 4.1 of Informix database servers. Thus, the ON DELETE CASCADE clause in the CREATE TABLE statement requires PREPARE. But you do not need to prepare the following statements, if they include only Informix 4.1 syntax.
ALTER TABLE CREATE INDEX CREATE TABLE CREATE SCHEMA CREATE SYNONYM DROP TABLE DROP VIEW GRANT INSERT INTO REVOKE UPDATE STATISTICS
4-316
PREPARE
ALLOCATE COLLECTION ALLOCATE DESCRIPTOR ALLOCATE ROW CHECK TABLE CLOSE CONNECT CREATE PROCEDURE FROM DEALLOCATE COLLECTION DEALLOCATE DESCRIPTOR DEALLOCATE ROW DECLARE DESCRIBE DISCONNECT EXECUTE EXECUTE IMMEDIATE FETCH FLUSH
FREE GET DESCRIPTOR GET DIAGNOSTICS INFO LOAD OPEN OUTPUT PREPARE PUT REPAIR TABLE SET AUTOFREE SET CONNECTION SET DEFERRED_PREPARE SET DESCRIPTOR UNLOAD WHENEVER
PREPARE
Additionally, you cannot use the following statements in prepared statement text that contains multiple SQL statements separated by semicolons.
CLOSE DATABASE CREATE DATABASE DATABASE DROP DATABASE SELECT START DATABASE
Thus, the SELECT statement (except for SELECT INTO TEMP) is not valid within the text of a multistatement PREPARE. In addition, statements that could cause the current database to be closed during execution of the sequence of prepared statements (such as CONNECT, DISCONNECT, and SET CONNECTION) are also not valid in this context. For general information about multistatement prepares, see Preparing Sequences of Multiple SQL Statements on page 4-321.
Put the text of the CREATE PROCEDURE statement in a separate le. Use SPL statements to dene the procedure. Directly embed a CREATE PROCEDURE FROM lename statement that references the text le created in step 1. Use a PREPARE statement to prepare the text of an EXECUTE PROCEDURE statement to execute the same stored procedure. Use an EXECUTE statement to execute the EXECUTE PROCEDURE statement that you prepared in step 3.
2. 3. 4.
Warning: The Stored Procedure Language (SPL) is not a part of the 4GL language. Attempting to include SPL statements directly within a 4GL program, rather than through a CREATE PROCEDURE FROM lename statement, causes compile errors. You can also invoke a stored procedure implicitly through a reference to that procedure within the context of an SQL expression. For example, the reference to avg_price( ) in the following SELECT statement implicitly invokes the stored procedure called avg_price:
SELECT manu_code, unit_price, (avg_price(1) - unit_price) FROM stock WHERE stock_num = 1
4-318
PREPARE
Such implicit references to stored procedures do not require the statement to be prepared, because the database server processes them in a manner that is transparent to the 4GL program. The Informix Guide to SQL: Tutorial describes how to create and execute stored procedures. See the Informix Guide to SQL: Syntax for complete descriptions of the CREATE PROCEDURE and CREATE PROCEDURE FROM statements.
PREPARE
The PREPARE statements in the following example show some uses of question mark placeholders:
PREPARE s3 FROM "SELECT * FROM customer WHERE state MATCHES ?" PREPARE in1 FROM "INSERT INTO manufact VALUES (?,?,?)" PREPARE update2 FROM "UPDATE customer SET zipcode = ?", "WHERE CURRENT OF zip_cursor"
You can use a placeholder only to supply a value for an expression. You cannot use a question mark placeholder to represent an SQL identier such as a database name, a table name, or a column name. The USING clause is available in both OPEN statements (for statements associated with a cursor) and EXECUTE statements (for all other prepared statements). For example:
DEFINE zip LIKE customer.zipcode PREPARE zip_sel FROM "SELECT * FROM customer WHERE zipcode MATCHES ?" DECLARE zip_curs CURSOR FOR zip_sel PROMPT "Enter a zipcode: " FOR zip OPEN zip_curs USING zip
If the prepared SELECT statement contains a question mark placeholder, you cannot execute the statement with a FOREACH statement; you must use the OPEN, FETCH, and CLOSE group of statements.
4-320
PREPARE
PROMPT "Enter column name: " FOR column_name LET del_str = "DELETE FROM customer WHERE ", column_name CLIPPED, " = ?" PREPARE de4 FROM del_str PROMPT "Enter search value in column ",column_name, ":" FOR column_value EXECUTE de4 USING column_value
PREPARE
The following example updates the stores7 database by replacing existing manufacturer codes with new codes. Because the manu_code columns are potential join columns that link four of the tables, the new codes must replace the old codes in three tables:
DATABASE stores7 MAIN DEFINE code_chnge RECORD new_code LIKE manufact.manu_code, old_code LIKE manufact.manu_code END RECORD sqlmulti CHAR(250) PROMPT "Enter new manufacturer code: " FOR code_chnge.new_code PROMPT "Enter old manufacturer code: " FOR code_chnge.old_code LET sqlmulti = "UPDATE manufact SET manu_code = ? WHERE manu_code = ?;", "UPDATE stock SET menu_code = ? WHERE manu_code = ?;", "UPDATE items SET manu_code = ? WHERE manu_code = ?;", "UPDATE catalog SET manu_code = ? WHERE manu_code = ?;" PREPARE exmulti FROM sqlmulti EXECUTE exmulti USING code_chnge.*, code_chnge.*, code_chnge.* code_chnge.* END MAIN
4-322
PREPARE
References
See the DECLARE, DESCRIBE, EXECUTE, FREE, and OPEN statements in the Informix Guide to SQL: Syntax. See also SQL on page 4-349.
PRINT
The PRINT statement produces output from a report denition.
,
PRINT 4GL Expression p. 3-49 COLUMN left offset PAGENO LINENO BYTE variable Integer Expression p. 3-63 Aggregate Report Functions p. 5-14 Character Expression p. 3-69 TEXT variable FILE "lename" SPACE SPACES
WORDWRAP
Description is the identier of a 4GL variable of data type BYTE. is a quoted string that species the name of a text le to include in the output from the report. This can include a pathname. is an expression that return a positive whole number. It species a character position offset (from the left margin) no greater than the difference (right margin - left margin). is an expression that evaluates to a positive whole number. It species the absolute position of a temporary right margin. is the identier of an 4GL variable of the TEXT data type.
For details of the syntax and usage of the PRINT statement in 4GL report denitions, see PRINT on page 7-55.
4-324
PROMPT
PROMPT
The PROMPT statement can assign a user-supplied value to a variable. ,
PROMPT variable FOR ATTRIBUTE Clause p. 3-96 response HELP number CHAR
"string "
,
key
statement
END PROMPT
Description is a keyword to specify an activation key. (For more information, see The ON KEY Blocks on page 4-329.) is a literal integer (as described in Literal Integers on page 3-65) to specify a help message number. is the name of a variable to store the response of the user to the PROMPT character string. This cannot be of data type TEXT or BYTE. is an SQL statement or other 4GL statement. is a quoted string that 4GL displays on the Prompt line. is a CHAR or VARCHAR variable that contains all or part of a message to the user, typically prompting the user to enter a value.
Usage
The PROMPT statement displays the specied character string on the Prompt line, and then waits for input from the user. What the user types is saved in the response variable, unless what the user typed was one of the keys that an ON KEY clause specied as its activation key.
PROMPT
Replaces any variables with their current values Concatenates the list of values into a single prompt string (The total length of this string, plus the length of the response that the user enters, cannot exceed 80 bytes.)
3. 4. 5.
Displays the resulting string on the Prompt line of the current form (or in the line mode overlay, if it currently covers the 4GL screen) Waits for the user to enter a value Reads whatever value was entered until the user presses RETURN, and then stores this value in response variable.
The prompt string remains visible until the user enters a response. The following topics are described in this section:
s s s s s s s
The Response Variable on page 4-327 The FOR Clause on page 4-327
The ATTRIBUTE Clauses on page 327
The HELP Clause on page 4-329 The ON KEY Blocks on page 4-329 The END PROMPT Keywords on page 4-331
If PROMPT is the next interactive statement after a line mode DISPLAY statement, the prompt string appears in the bottom line of the line mode overlay. The prompt string does not scroll with any subsequent output from line mode DISPLAY statements. (See Sending Output to the Line Mode Overlay on page 4-91.) If the 4GL screen or any other 4GL window is visible, the prompt string appears on the Prompt line of the current 4GL window. (If this is not as wide as the prompt string, runtime error -1146 occurs.)
4-326
PROMPT
The rst ATTRIBUTE clause species display attributes of the prompt string text. The default display attribute for this text is NORMAL. The second ATTRIBUTE clause species display attributes of the response. The default is REVERSE.
PROMPT
The CENTURY attribute species how to expand abbreviated one- and twodigit year specications in a DATE and DATETIME eld. Expansion is based on this setting (and on the year value from the system clock at runtime).
CENTURY
into four-digit year values that end with the same digits (or digit) that the user entered. CENTURY supports the same settings as the DBCENTURY environment variable, but with a scope that is restricted to a single eld.
Symbol
C or c F or f P or p R or r
Algorithm for Expanding Abbreviated Years Use the past, future, or current year closest to the current date. Use the nearest year in the future to expand the entered value. Use the nearest year in the past to expand the entered value. Prex the entered value with the rst two digits of the current year.
Here past, closest, current, and future are all relative to the system clock. Unlike DBCENTURY, which sets a global rule for expanding abbreviated year values in DATE and DATETIME elds that do not have the CENTURY attribute, CENTURY is not case-sensitive; you can substitute lowercase letters ( r, c, f, p) for these uppercase letters. If you specify anything else, an error (-2018) is issued. If the CENTURY and DBCENTURY settings are different, CENTURY takes precedence. For example, the following statement prompts for a delivery date:
PROMPT "Enter the preferred delivery day for ", customer_num, " "ATTRIBUTE (YELLOW) FOR del_day ATTRIBUTE (BLUE, CENTURY = "F") ... END PROMPT
4-328
PROMPT
Here the prompt string appears in yellow on color monitors or in bold on monochrome monitors. The delivery date that the user enters appears in blue on color monitors and in dim on monochrome monitors. If the year is entered as two digits, 4GL assigns to the variable the nearest future date that matches the unabbreviated portion of the response. (For more information about 4GL display attributes, see ATTRIBUTE Clause on page 3-96.)
You specify a number that is not in the help le. You specify a number outside the range from -32,767 to 32,767.
PROMPT
Here you can substitute NEXTPAGE for NEXT, and PREVPAGE for PREVIOUS. The following table lists keys that require special consideration before you assign them in an ON KEY clause.
Key
ESC or ESCAPE
Special Considerations You must use the OPTIONS statement to specify another key as the Accept key because ESCAPE is the default Accept key. You must execute a DEFER INTERRUPT statement. When the user presses the Interrupt key under these conditions, 4GL executes the ON KEY block statements and sets int_ag to nonzero, but does not terminate the PROMPT statement. 4GL also executes the statements in this ON KEY clause if the DEFER QUIT statement has executed and the user presses the Quit key. In this case, 4GL sets quit_ag to non-zero.
Interrupt
Quit
CONTROL-char A, D, H, K, 4GL reserves these keys for eld editing. L, R, and X I, J, and M
The usual meaning of these keys (TAB, LINEFEED, and RETURN, respectively) is not available to the user, because 4GL traps the key and uses it to activate the commands in the ON KEY clause. For example, if CONTROL-M appears in an ON KEY clause, the user cannot press RETURN to advance the cursor to the next eld. If you must include one of these keys in an ON KEY clause, be careful to restrict the scope of the clause to specic elds.
You might not be able to use other keys that have special meaning to your version of the operating system. For example, CONTROL-C, CONTROL-Q, and CONTROL-S specify the Interrupt, XON, and XOFF signals on many systems. The next example species two ON KEY clauses:
PROMPT "Enter the preferred delivery day for ", customer_num, " " ATTRIBUTE (YELLOW) FOR del_day ON KEY (CONTROL_B) LET del_day = set_day() ON KEY (F6, CONTROL_F) CALL delivery_help() END PROMPT
In this example, if the user presses CONTROL-B, 4GL calls the set_day( ) function and sets the del_day variable to the value returned by set_day. If the user presses F6 or CONTROL-F, the delivery_help( ) function is invoked.
4-330 IBM Informix 4GL Reference Manual
PROMPT
A PROMPT LINE specication in the OPEN WINDOW statement A PROMPT LINE specication in the OPTIONS statement
If PROMPT LINE assigns a position that is outside the range of lines in the current window, the position defaults to the rst line. For example, the next program increments the position of the PROMPT LINE in a WHILE loop:
MAIN DEFINE ans CHAR(1) DEFINE pline INTEGER DEFINE flag CHAR(1) LET pline = 7 OPTIONS PROMPT LINE pline WHILE pline <> 10 OPEN WINDOW wdw AT 4,6 WITH 7 ROWS, 60 COLUMNS ATTRIBUTE (BORDER) DISPLAY " winrowsize = 7, PROMPT LINE is set to ", pline at 2, 6 PROMPT "123456789012345678901234567890abcdef" FOR CHAR ans CLOSE WINDOW wdw LET pline = pline + 1 OPTIONS PROMPT LINE pline END WHILE END MAIN
When the incremented value of the PROMPT LINE becomes 8, 4GL detects that this value is larger than the vertical size of the window and silently resets the value of PROMPT LINE to the default value (that is, to the rst line of the window).
References
DISPLAY, DISPLAY ARRAY, INPUT, INPUT ARRAY, OPEN WINDOW, OPTIONS
REPORT
REPORT
The REPORT statement declares the identier and denes the format of a 4GL report. (For details of its syntax and usage, see Chapter 7.)
REPORT report (
) ,
argument
END REPORT
Element argument
Description is the name of a formal argument in each input record. The list can include arguments of the RECORD data type, but the record.* notation and ARRAY data type are not valid here. is the 4GL identier that you declare here for the report.
report
Usage
This statement denes a REPORT program block, just as the FUNCTION statement denes a function. You can execute a report from the MAIN program block or from a function, but the REPORT statement cannot appear within the MAIN statement, in a FUNCTION denition, or in another REPORT statement. Creating a 4GL report is a two-step process:
1. 2.
Use the REPORT statement to dene how to format data in the report. Write a report driver that passes data to the report.
The report driver typically uses a loop (such as WHILE, FOR, or FOREACH) with the following 4GL statements to process the report:
s s
START REPORT (invokes the REPORT routine) OUTPUT TO REPORT (sends data to the REPORT for formatting)
4-332
REPORT
s s
FINISH REPORT (to complete execution of the REPORT routine) TERMINATE REPORT (to stop processing and exit from the REPORT
routine, typically after an exceptional condition has been detected) Unlike a FUNCTION program block, a REPORT routine is not reentrant. If a START REPORT statement references a report that is already running, the report is reinitialized, and any output might be unpredictable. If OUTPUT TO REPORT is not executed, no control blocks of the report are executed, even if your program includes the START REPORT and FINISH REPORT statements.
REPORT
All the values for each row sent to the report in the following cases:
If you include an ORDER BY section or GROUP PERCENT(*) function If you use a global aggregate function (one over all rows of the report) anywhere in the report, except in the ON LAST ROW control block If you specify the FORMAT EVERY ROW default format
AFTER GROUP OF
BEFORE GROUP OF
Two-Pass Reports
A two-pass report is one that creates a temporary table. The REPORT statement creates a temporary table if it includes any of the following items:
s s s
An ORDER BY section without the EXTERNAL keyword The GROUP PERCENT(*) aggregate function anywhere in the report Any aggregate function that has no GROUP keyword in any control block other than ON LAST ROW.
The FINISH REPORT statement uses values from these tables to calculate any global aggregates, and then deletes the tables.
4-334
REPORT
A two-pass report requires that the 4GL program be connected to a database when the report runs. See the DATABASE statement for information on how to specify a current database at runtime (as described in The Current Database at Runtime on page 4-74). If the DEFINE section uses the LIKE keyword to declare local variables of the report indirectly, you must also include a DATABASE statement in the same module as the REPORT statement, but before the rst program block, to specify a default database at compile time. (See The Default Database at Compile Time on page 4-73.) An error occurs if you close the current database, or if you connect to another database, while a two-pass report is running. Even if none of the input records that the report formats are retrieved from a database, a two-pass report requires a current database to store the temporary tables.
Terminates the processing of the current report Deletes any intermediate les or temporary tables that were created in processing the REPORT statement
You cannot use the RETURN statement as a substitute for EXIT REPORT. An error is issued if RETURN is encountered within the denition of a 4GL report.
REPORT
References
DATABASE, DEFINE, FINISH REPORT, OUTPUT TO REPORT, START REPORT, TERMINATE REPORT
4-336
RETURN
RETURN
The RETURN statement transfers control of execution from a FUNCTION program block. It can also return values to the calling routine. (This statement can appear only within a FUNCTION program block.)
RETURN
,
4GL Expression p. 3-49
Usage
The RETURN statement can appear only in the denition of a function. This statement tells 4GL to exit from the function and to return program control to the calling routine. (The calling routine is the MAIN, FUNCTION, or REPORT program block that contains the statement that invoked the function.) You can use the RETURN statement in either of two ways:
s s
Without values, to control the ow of program execution With a list of one or more values, to control the ow of program execution and to return values to the calling statement
If 4GL does not encounter a RETURN statement, it exits from the function after encountering the END FUNCTION keywords. An error is issued if RETURN appears within the MAIN statement or within a REPORT denition. To terminate execution of MAIN or REPORT from within the same program block, use PROGRAM or EXIT REPORT, respectively.
RETURN
Explicitly execute a CALL statement with a RETURNING clause. Invoke the function implicitly within an expression (in the same way that you would specify a variable or a list of variables).
If the function does not return any values, you must use the CALL statement (without the RETURNING clause) to invoke the function.
list in number or position, or if data types are incompatible (see Summary of Compatible 4GL Data Types on page 3-46). Similarly, if the function is invoked implicitly in an expression (as described in Function Calls as Operands on page 3-58), the RETURN statement is checked for agreement with the number and data types of the values that are required by the context of the calling statement. You cannot return variables of the ARRAY data type, nor RECORD variables that contain ARRAY members. You can, however, return records that do not include ARRAY members. The following example returns the values of whole_price and ret_price to the CALL statement. 4GL then assigns the whole_price and ret_price variables to the wholesale and retail variables in the price record.
MAIN DEFINE price RECORD wholesale, retail MONEY END RECORD ... CALL get_cust() RETURNING price.* ...
4-338
RETURN
END MAIN FUNCTION get_cust() DEFINE whole_price, ret_price MONEY ... RETURN whole_price, ret_price END FUNCTION
You cannot specify variables of the BYTE or TEXT data types in the RETURN statement, just as you cannot include those data types in the RETURNING clause of a CALL statement. Because 4GL passes variables of large data types by reference, any changes made to a BYTE or TEXT variable within a function become visible within the calling routine without being returned.
4GL allocates 5 kilobytes of memory to store character strings returned by
functions, in 10 blocks of 512 bytes. A returned character value can be no larger than 511 bytes (because every string requires a terminating ASCII 0), and no more than 10 of these 511-byte strings can be returned. You can use TEXT variables to pass longer character values by reference (as described in Passing Arguments by Reference on page 4-18), rather than using the RETURN statement.
References
CALL, EXIT PROGRAM, EXIT REPORT, FUNCTION, WHENEVER
RUN
RUN
The RUN statement executes an operating system command line.
RUN command IN FORM MODE IN LINE MODE WITHOUT WAITING RETURNING variable
Description is a quoted string (or a CHAR or VARCHAR variable) that contains a command line for the operating system to execute. is the identier of an INT or SMALLINT variable.
Usage
The RUN statement executes an operating system command line. You can even run a second 4GL application as a secondary process. When the command terminates, 4GL resumes execution. For example, the following statement executes the command line specied by the element i of the array variable charval, where i is an INT or SMALLINT variable:
RUN charval[i]
Unless you specify WITHOUT WAITING, RUN also has these effects:
1. 2. 3.
Causes execution of the current 4GL program to pause Displays any output from the specied command in a new 4GL window After that command completes execution, closes the new 4GL window and restores the previous display in the 4GL screen
If you specify WITHOUT WAITING, all of these effects except the last are suppressed, so that the command line typically executes without any effect on the visual display. (For more information, see The WITHOUT WAITING Clause on page 4-343.)
4-340
RUN
The default behavior for RUN is IN LINE MODE (so that the screen is cleared), for compatibility with releases earlier than 4GL 6.0. This mode is the opposite of the default screen mode for PIPE specications. If no screen mode is specied, the current value from the OPTIONS statement is used. After IN LINE MODE is specied, the terminal is in the same state (in terms of stty options) as when the program began. Usually the terminal input is in cooked mode, with interrupts enabled and input not becoming available until after a newline character is typed. The IN FORM MODE keywords specify raw mode, in which each character of input becomes available to the program as it is typed or read. By default, 4GL programs operate in line mode, but so many statements take it into formatted mode (including OPTIONS statements that set keys, DISPLAY AT, OPEN WINDOW, DISPLAY FORM, and other screen interaction statements) that typical 4GL programs are actually in formatted mode most of the time. When the RUN statement species IN FORM MODE, the program remains in formatted mode if it currently is in formatted mode, but it does not enter formatted mode if it is currently in line mode. When the prevailing RUN option species IN LINE MODE, the program remains in line mode if it is currently in line mode, and it switches to line mode if it is currently in formatted mode. The same comments apply to the PIPE option.
RUN
You can only use this clause if RUN invokes a 4GL program that contains an EXIT PROGRAM statement. When this program completes execution, the integer variable contains two bytes of termination status information:
s
The low byte contains the termination status of whatever RUN executes. You can recover the value of the status code by calculating the value of the integer variable modulo 256. The high byte contains the low byte from the EXIT PROGRAM statement of the 4GL program that RUN executes. You can recover this returned code by dividing the integer variable by 256.
The following program fragment uses RUN to invoke the compiled version of the previous program, whose lename is stored in variable prog1:
DEFINE expg_code, stat_code, ret_int INT, prog1 CHAR(20) . . . RUN prog1 RETURNING ret_int LET stat_code = (ret_int MOD 256) IF stat_code <> 0 THEN MESSAGE "Unable to run the ", prog1, " program." END IF LET expg_code = (ret_int/256) DISPLAY " Code from the ", prog1, " program is ", expg_code
Unless an error or signal terminates the program before the EXIT PROGRAM statement is encountered, the displayed value of expg_code is 5. Exercise caution in interpreting the integer variable, however, because under some circumstances the quotient (variable)/256 might not be the actual status code value that the command line returned. If an Interrupt signal terminates the program, the integer value is 256. If a Quit signal causes the termination, the integer value is (3*256), or 758. If a 4GL program that RUN executes can be terminated by actions of the user, you could include several EXIT PROGRAM (number) statements with different number values in different parts of the program. Examination of the code returned by RUN could indicate which EXIT PROGRAM statement (if any) was encountered during execution.
4-342 IBM Informix 4GL Reference Manual
RUN
Each 4GL application must have its own MAIN routine. The two programs cannot share variable scope. Each must be independently terminated, either by executing an END MAIN or EXIT PROGRAM statement in 4GL. The WITHOUT WAITING clause is useful if you know that the command will take some time to execute, and your 4GL program does not need the result to continue. Because RUN WITHOUT WAITING executes the specied command line as a background process, it generally does not affect the visual display. A common way to use RUN WITHOUT WAITING is to execute 4GL reports in the background.
References
CALL, FUNCTION, START REPORT
SCROLL
SCROLL
The SCROLL statement species vertical movement of displayed values in all or some of the elds of a screen array within the current form.
,
SCROLL Field Clause p. 3-86 DOWN UP BY lines
Element lines
Description is a literal integer (as described in Literal Integers on page 3-65), or the name of a variable containing an integer value, that species how far (in lines) to scroll the display.
Usage
Here 1 lines size, where size is the number of lines in the screen array, and lines is the positive whole number specied in the BY clause, indicating how many lines to move the displayed values vertically in the specied elds of a screen array. If you omit the BY lines specication, the default is one line. Specify UP to scroll the data toward the top of the form, or DOWN to scroll toward the bottom of the form. For example, the following statement moves up by one line all the displayed values in the sc_item screen array and lls with blanks all the elds of the last (that is, the bottom) screen record:
SCROLL sc_item.* UP
The BY clause indicates how many lines upwards or downwards to move the data; if you omit it, as in the previous example, the default is one line in the specied direction. This following example moves values in two elds down by three lines:
SCROLL stock_num, manu_code DOWN BY 3
The SCROLL statement ignores any bracket notation (like sc_item[3].*) that references a single record within the array; 4GL always scrolls values in the specied elds of every screen record.
4-344 IBM Informix 4GL Reference Manual
SCROLL
If you use SCROLL, you need to keep track of the data that is left on the screen. Many developers prefer to have the user rely on the scrolling keys of the INPUT ARRAY statement (described in Keyboard Interaction on page 4-219) or the DISPLAY ARRAY statement (described in Scrolling During the DISPLAY ARRAY Statement on page 4-111), rather than the SCROLL statement, to scroll through screen records programmatically.
References
DISPLAY ARRAY, INPUT ARRAY
SKIP
SKIP
The SKIP statement inserts blank lines into a report, or nishes the current page. (It can appear only in the FORMAT section of a REPORT program block.)
SKIP TO TOP OF PAGE integer LINE LINES
Element integer
Usage
The SKIP statement inserts blank lines into REPORT output or advances the current print position to the top of the next page. The LINE and LINES keywords are synonyms in the SKIP statement. (They are not keywords in any other statement.) Output from any PAGE TRAILER or PAGE HEADER block appears in its usual location. The next program fragment produces a list of names and addresses:
FIRST PAGE HEADER PRINT COLUMN 30, "CUSTOMER LIST" SKIP 2 LINES PRINT "Listings for the State of ", thisstate SKIP 2 LINES PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE PAGE HEADER PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE ON EVERY ROW PRINT customer_num USING "####", COLUMN 12, fname CLIPPED, 1 SPACE, lname CLIPPED, COLUMN 35, city CLIPPED, ", " , state COLUMN 57, zipc ode, COLUMN 65, phone
The SKIP LINES statement cannot appear within a CASE statement, a FOR loop, or a WHILE loop. The SKIP TO TOP OF PAGE statement cannot appear in a FIRST PAGE HEADER, PAGE HEADER, or PAGE TRAILER control block.
4-346 IBM Informix 4GL Reference Manual
SKIP
References
NEED, OUTPUT TO REPORT, PAUSE, PRINT, REPORT, START REPORT
SLEEP
SLEEP
The SLEEP statement suspends execution of the 4GL program for a specied number of seconds.
Integer Expression p. 3-63
SLEEP
Usage
The SLEEP statement causes the program to pause for the specied number of seconds. This can be useful, for example, when you want a screen display to remain visible long enough for the user to read it. The following statement displays a screen message, and then waits three seconds before erasing it:
MESSAGE "Row has been added." SLEEP 3 MESSAGE " "
In contexts where the PROMPT statement is valid, an alternative to SLEEP is the PROMPT statement. The following example suspends program execution until the user acknowledges a screen message by providing keyboard input:
PROMPT "Row was added. Press RETURN to continue:" FOR reply
Here the screen display remains visible until the user presses RETURN (or enters anything), rather than for a xed time interval. Entered keystrokes are stored in the reply variable, but their actual value can be ignored.
References
DISPLAY, EXPRESSION, MESSAGE, PROMPT
4-348
SQL
SQL
The SQLEND SQL keywords prepare, execute, and free an SQL statement.
SQL statement END SQL
;
Element statement Description is a preparable SQL statement that the database server supports.
Usage
Most SQL statements that Informix 4.10 databases support can be directly embedded in 4GL source code, as well as few post-4.10 statements, such as
CONNECT, CREATE PROCEDURE FROM, CREATE TRIGGER, DISCONNECT, FOREACHWITH REOPTIMIZATION, OPENWITH REOPTIMIZATION, and SET CONNECTION. Other SQL statements that include syntax later than 4.10
must be prepared, if the database server can prepare and execute them. The SQLEND SQL delimiters provide an alternative facility by which an SQL statement is automatically prepared, executed, and freed. For example, this ALTER TABLE statement includes the DISABLED keyword, which was introduced to the Informix implementation of SQL after the 4.10 release:
SQL ALTER TABLE cust_fax MODIFY (lname CHAR(15) NOT NULL CONSTRAINT lname_notblank DISABLED) END SQL
A statement like this, which has no input nor output parameters, is simply placed between the SQL and END SQL keywords. It resembles an embedded SQL statement, except that its post-4.10 syntax would have produced a compilation error if the SQLEND SQL delimiters were absent. Only one SQL statement can appear in each delimited SQL statement block.
SQL
Host Variables
Unlike the PREPARE statement, delimited SQL blocks can include SQL statements that accept host variables as input or output parameters. The 4GL host variables must be prexed by a dollar sign ( $ ). You can include white space between the $ symbol and the name of the variable. In the next example, element is a host variable member of a RECORD variable whose index is specied by the value of SMALLINT variable j in the ARRAY OF RECORD arr in an INSERT statement, and str is another host variable:
SQL INSERT INTO someTable(Column1, Column2) SELECT TRIM(A.firstname) || " " || TRIM(A.lastname), B.whatever FROM table1 A, Table2 B WHERE A.PkColumn = B.FkColumn AND A.Filter = $arr[j].element AND B.Filter MATCHES $str END SQL
Here the $ symbol marks arr[j].element and str as host variables, rather than database entities. (Standard 4GL notation can prex some SQL identiers with the @ symbol to distinguish them from 4GL identiers.)
Returned Values
The SELECT INTO and EXECUTE PROCEDURE INTO SQL statements can return values to the 4GL program. For example, the following statement executes a stored procedure that returns two values to the 4GL program:
SQL EXECUTE PROCEDURE someProcedure(12) INTO $rv1, $rv2 END SQL
SQL statements that have both host variables and returned values follow the same rules, as the next example of a SELECT INTO statement illustrates:
SQL SELECT someProcedure(colName, $inval), otherColumn INTO $x, $y FROM someTable WHERE PkColumn=$pkval END SQL
Although you cannot prepare EXECUTE PROCEDURE INTO and SELECT INTO variable statements, they can appear within an SQL block. These statements are exceptions to the rule that only preparable statements can appear in an SQL block. SQL blocks can support 4GL variables; PREPARE cannot.
4-350 IBM Informix 4GL Reference Manual
SQL
that the application resolves cursor-name conicts before you include statements that reference a local cursor within the SQL block. The DECLARE statement can declare a cursor for a prepared statement, but it can also include SELECT directly (or an INSERT statement, for INSERT cursor). In these cases, the cursor declaration must precede the SQL block, as follows:
DECLARE c_su SCROLL CURSOR WITH HOLD FOR SQL SELECT TRIM(Firstname)||" " || TRIM (Lastname) INTO $var1 FROM someTable WHERE PkColumn > $pkvar END SQL
In this example, part of the DECLARE statement precedes the beginning of the SQL block, and part of it follows the END SQL delimiters.
Excluded Statements
Statements in the SQL block must be preparable. The SQL block cannot include 4GL statements that are not SQL or SPL statements. In addition, the following SQL statements, which are supported in some releases of Informix database servers, cannot appear within an SQL block.
ALLOCATE COLLECTION ALLOCATE DESCRIPTOR ALLOCATE ROW CHECK TABLE CLOSE CONNECT CREATE PROCEDURE FROM DEALLOCATE COLLECTION DEALLOCATE DESCRIPTOR DEALLOCATE ROW DECLARE DESCRIBE DISCONNECT EXECUTE EXECUTE IMMEDIATE FETCH FLUSH
FREE GET DESCRIPTOR GET DIAGNOSTICS INFO LOAD OPEN OUTPUT PREPARE PUT REPAIR TABLE SET AUTOFREE SET CONNECTION SET DEFERRED_PREPARE SET DESCRIPTOR UNLOAD WHENEVER
SQL
The SQL statements that are marked by the symbol cannot be embedded (and are also not valid in SQL blocks, nor as text within PREPARE statements).
SQL blocks do not support CREATE PROCEDURE statements. Use instead directly-embedded CREATE PROCEDURE FROM lename statements.
Additional Restrictions
You cannot include an SQL block within a PREPARE statement, nor a PREPARE statement within an SQL block. Question mark ( ? ) placeholders within SQL blocks are valid in strings that are prepared, but not in other contexts. Thus, the following code generates a syntax error:
DECLARE cname CURSOR FOR SQL SELECT * FROM SomeWhere WHERE SomeColumn BETWEEN ? AND ? END SQL
-- Invalid!!!
Trailing semicolon ( ; ) delimiters are valid after the SQL statement but have no effect. Semicolons that separate two statements within the SQL block cause the compilation to fail with a syntax violation error message.
Here {+ begins an optimizer directive (to use a hash join on the dept table) that is terminated by the } symbol at the end of the rst line. Such directives can immediately follow the DELETE, SELECT, or UPDATE keywords in SQL data manipulation statements. The + symbol must be the rst character following the comment indicator that begins an optimizer directive. The # symbol is not a valid comment indicator in this context, but { } or -- comment indicators are valid within an SQL block. For more information, see the Informix Guide to SQL: Syntax.
4-352
SQL
References
PREPARE
START REPORT
START REPORT
The START REPORT statement begins processing a 4GL report and can specify the dimensions and destination of its output. (For more information, see Chapter 7.)
START REPORT report TO Clause p. 4-355 Page Dimensions WITH Page Dimensions
,
1 PAGE LENGTH 1 TOP 1 BOTTOM 1 RIGHT 1 LEFT 1 TOP OF PAGE MARGIN size
= "string "
Description is the identier of a report, as declared in a REPORT statement. is an integer expression that species the height (in lines) or width (in characters) of a page of output from report, or of its margins. is a quoted string that species the page-eject character sequence.
Usage
The START REPORT statement begins processing a report with these actions:
s s s
Identies a REPORT denition by which to format the input records. Species a destination and page dimensions for output of the report. Initializes any page headers in the FORMAT section of the report.
Only the name of the report denition is required, if you are satised with the default destination and page dimensions. START REPORT specications supersede the OUTPUT section of the report denition, if these are different.
4-354 IBM Informix 4GL Reference Manual
START REPORT
Do not use the START REPORT statement to reference a report that is already running. If you do, any output will be unpredictable.
START REPORT typically precedes a FOR, FOREACH, or WHILE loop in which OUTPUT TO REPORT sends input records to the report. After the loop terminates, FINISH REPORT completes the processing of output. (See Report
The TO Clause
The TO clause can specify a destination for output from the report. Values in this clause supersede any REPORT TO clause in the REPORT denition.
TO Clause TO FILE PIPE OUTPUT SCREEN PRINTER lename program DESTINATION Clause IN FORM IN LINE MODE
DESTINATION Clause
variable
"FILE "PIPE
IN FORM IN LINE
variable
"SCREEN" "PRINTER"
program
"
MODE" DESTINATION
lename
Description is a quoted string (or a character variable), specifying a le to receive output from report. This can also include a pathname. is a quoted string (or a character variable), specifying a program, a shell script, or a command line to receive output from report. is a character variable that species SCREEN, PRINTER, FILE, PIPE, PIPE IN LINE MODE, or PIPE IN FORM MODE.
START REPORT
If you omit the TO clause, 4GL sends report output to the destination specied in the REPORT denition, as described in The REPORT TO Clause on page 7-17. If neither START REPORT nor the REPORT denition species any destination, output is sent by default to the Report window (as described in Sending Report Output to the Screen on page 7-19). This default is equivalent to specifying the SCREEN keyword in the TO clause. If the OUTPUT TO REPORT statement sends an empty set of data records to the report, the report produces no output and the TO clause has no effect, even if headers, footers, and other formatting control blocks are specied in the FORMAT section of the report denition. The TO clause can send the report output to any of the following destinations:
s s s s
To the screen (using the SCREEN keyword) To a printer (using PRINTER) To a le (using FILE) To another program, command line, or shell script (using PIPE)
If FILE or PIPE is known as the destination at compile time, the TO FILE option can specify the lename (or the TO PIPE option can specify the program) as a character variable that is dened at runtime. If the destination is determined at runtime, the TO OUTPUT option can specify SCREEN, PRINTER, FILE, or PIPE as the destination by using a character variable that is dened at runtime. If this variable species FILE or PIPE , you can also specify a lename or program in a character variable that follows the DESTINATION keyword.
You can also specify the program or lename that follows the FILE or PIPE options as a quoted string.
4-356
START REPORT
Except for DESTINATION, keywords following the OUTPUT keyword within the TO clause must be delimited by quotation ( " ) marks. The DESTINATION keyword is not required (and is ignored, if specied) when SCREEN or PRINTER is specied by the quoted string or variable that follows the TO OUTPUT keywords.
The following statement has the same effect but uses a DESTINATION clause:
START REPORT cust_list TO OUTPUT "SCREEN"
Tip: If you intend to read output from a report that uses SCREEN as its explicit or default destination, you might want to set a PAGE LENGTH value no larger than the number of lines that the screen of your terminal can display. (Also include PAUSE statements in the FORMAT section of the report denition, so that the output remains on the screen long enough for users to examine it.)
The following statement has the same effect but uses a DESTINATION clause:
START REPORT cust_list TO OUTPUT "PRINTER"
START REPORT
To send the output to a printer other than the default printer, you have the following options:
s s
Set DBPRINT to the desired value and use the TO PRINTER option. Use the TO "lename" option (or equivalently, TO FILE "lename" or TO OUTPUT "FILE" DESTINATION "lename") to send the report output to a le, and then send the le to a printer. Use the TO PIPE "program" option (or equivalently, TO OUTPUT "PIPE" DESTINATION "program") to direct output to a command line or to a shell script that sends output to a printer directly, or to send the output to a text editor for further processing before it is printed.
The following statement has the same effect but uses a DESTINATION clause:
START REPORT cu_list TO OUTPUT "FILE" DESTINATION "outfile"
The FILE keyword is not required, but you can include it to make your code more readable. (See also OUTPUT Section on page 7-12 for information about how to set the default destination of output from a report within the report denition.) The following program creates a report with default formatting, describing all the customers in the customer table, and saves it in the cust_lst le.
DATABASE stores7 MAIN DEFINE p_customer RECORD LIKE customer.* DECLARE q_curs CURSOR FOR SELECT * FROM customer START REPORT cust_list TO "cust_lst" FOREACH q_curs INTO p_customer.* OUTPUT TO REPORT cust_list(p_customer.*) END FOREACH FINISH REPORT cu _list
4-358
START REPORT
END MAIN REPORT cust_lst(r_customer) DEFINE r_customer RECORD LIKE customer.* OUTPUT REPORT TO PRINTER FORMAT EVERY ROW END REPORT
4GL ignores the OUTPUT REPORT TO PRINTER specication in the REPORT denition because the TO "lename" clause of the START REPORT statement overrides any default destination that REPORT species. But if the same cust_list report were referenced in another START REPORT statement that had no TO clause, its output would go to the default printer.
The following statement has the same effect but uses a DESTINATION clause:
START REPORT cust_list TO OUTPUT "PIPE" DESTINATION "/usr/ucb/more"
Like the OUTPUT section of a REPORT denition, the TO clause can also specify whether the program is in line mode or in formatted mode when output from a report is sent to a pipe. The following statement species PIPE output in formatted mode:
START REPORT cust_list TO PIPE "/usr/ucb/more" IN FORM MODE
If neither IN LINE MODE nor IN FORM MODE is included as the screen mode specication, IN FORM MODE is the default unless a previous OPTIONS statement has set IN LINE MODE as the default. See Screen Display Modes on page 4-341 for more information about line mode and formatted mode in 4GL operations that produce screen output.
INFORMIX-4GL Statements 4-359
START REPORT
The LEFT MARGIN clause species how many blank spaces to include at the start of each new line of output. The default is 5. The RIGHT MARGIN clause species the maximum number of characters in each line of output, including the left margin. If you omit this but specify FORMAT EVERY ROW, the default is 132. The TOP MARGIN clause species how many blank lines appear above the rst line of text on each page of output. The default is 3. The BOTTOM MARGIN clause species how many blank lines follow the last line of output on each page. The default is 3. The PAGE LENGTH clause species the total number of lines on each page, including data, the margins, and any page headers or page trailers from the FORMAT section. The default page length is 66 lines.
4-360
START REPORT
LEFT MARGIN size (default = 5 characters) TOP MARGIN size (default = 3 lines)
BOTTOM MARGIN size (default = 3 lines) RIGHT MARGIN size (default = 132 characters) (for default reports or PRINT WORDWRAP only)
In addition to these ve clauses, the TOP OF PAGE clause can specify a pageeject sequence for a printer. On some systems, specifying this value can reduce the time required for a large report to produce output, because SKIP TO TOP OF PAGE can substitute this value for multiple linefeeds.
START REPORT
Report Drivers
The START REPORT statement is logically part of a report driver, the portion of a 4GL application that invokes a 4GL report, retrieves data, and sends the data (as input records) to be formatted by the REPORT denition. The following diagram shows the basic elements of a report driver. These elements can appear in the same or different program blocks, typically embedded within a FOR, WHILE, or FOREACH loop that uses a database cursor to pass rows from a database to the OUTPUT TO REPORT statement for formatting.
START REPORT p. 4-354 OUTPUT TO REPORT p. 4-308 FINISH REPORT p. 4-125 TERMINATE REPORT page 4-364
You must use START REPORT, rather than the CALL statement, to invoke a 4GL report. If OUTPUT TO REPORT is not executed, no control blocks of the report are executed even if your program includes the START REPORT statement. The driver also must include the FINISH REPORT statement to instruct the report when to stop processing. (You can optionally use TERMINATE REPORT to do this, as described in the next section, usually after an exception condition has been detected. Control logic within the report denition can also terminate execution of the report by using the EXIT REPORT statement.) A report cannot invoke itself. The report driver must be in a different program block from the REPORT denition. See also The Report Driver on page 7-5 for additional information about report drivers.
4-362
START REPORT
References
DEFINE, EXIT REPORT, FINISH REPORT, FOR, FOREACH, NEED, OUTPUT TO REPORT, PAUSE, PRINT, REPORT, SKIP, TERMINATE REPORT, WHILE
TERMINATE REPORT
TERMINATE REPORT
The TERMINATE REPORT statement stops processing a currently running 4GL report, typically because some error has been detected. (Use FINISH REPORT instead for the normal termination of report processing.)
TERMINATE REPORT report
Element report
Usage
The TERMINATE REPORT statement causes 4GL to terminate the currently executing report driver without completing the normal processing of the report. TERMINATE REPORT must be the last statement in the report driver, and it must follow a START REPORT statement that species the name of the same report. (For more information about 4GL report denitions and report drivers, see Chapter 7, INFORMIX-4GL Reports.) The TERMINATE REPORT statement has the following effects:
s s
Terminates the processing of the report Deletes any intermediate les or tables that were created in processing a REPORT statement
Unlike the FINISH REPORT statement (page 4-125), TERMINATE REPORT does not format any values from aggregate functions and does not execute any statements in the ON LAST ROW section of the specied REPORT routine. If the report includes an ORDER BY section that sorts the input records within the report (rather than specifying the ORDER EXTERNAL BY option), the effect of the TERMINATE REPORT statement is to produce an empty report.
4-364
TERMINATE REPORT
This statement is useful if you are not interested in output that is missing some input records, but your code detects a condition that prevents some report data from being processed. For example, an SQL statement in the report driver returns an error, the designated printer fails, or something disables a process to which the report sends output through a pipe. In general, the TERMINATE REPORT statements should be conditional on detection of an error, as in the following example. Otherwise, you would normally execute FINISH REPORT rather than TERMINATE REPORT. The following program species a report on data from the customer table:
DATABASE stores DEFINE trouble INT MAIN DEFINE p_customer RECORD LIKE customer.* DECLARE q_curs CURSOR FOR SELECT * FROM customer LET trouble = 0 START REPORT cust_list TO "cust_listing" FOREACH q_curs INTO p_customer.* OUTPUT TO REPORT cust_list(p_customer.*) IF status !=0 THEN LET trouble = trouble + 1 EXIT FOREACH END IF END FOREACH IF trouble > 0 THEN TERMINATE REPORT cust_list ELSE FINISH REPORT cust_list END IF END MAIN REPORT cust_list(r_customer) DEFINE r_customer RECORD LIKE customer.* FORMAT PAGE HEADER PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE ON EVERY ROW PRINT r_customer.customer_num USING "####", COLUMN 12, r_customer.fname CLIPPED, 1 SPACE, r_customer.lname CLIPPED, COLUMN 35, r_customer.city CLIPPED, ", " , r_customer.state, COLUMN 57, r_customer.zipcode, COLUMN 65, r_customer.phone ON LAST ROW SKIP 1 LINE PRINT COLUMN 12, "TOTAL NUMBER OF CUSTOMERS:", COLUMN 57, COUNT(*) USING "##" END REPORT
TERMINATE REPORT
If the module variable trouble has a non-zero value when the FOREACH loop terminates, the TERMINATE REPORT statement is executed rather than FINISH REPORT. In this case, no statements in the ON LAST ROW control block are executed, and the aggregate COUNT(*) function is not evaluated.
References
EXIT REPORT, FINISH REPORT, OUTPUT TO REPORT, REPORT, START REPORT
4-366
UNLOAD
UNLOAD
The UNLOAD statement copies data from the current database to a le.
UNLOAD TO lename DELIMITER delimiter variable SELECT Statement see SQL:S
Element delimiter
Description is a literal delimiter symbol, enclosed in quotation marks, or a CHAR or VARCHAR variable that contains a single delimiter symbol to separate adjacent columns in the character-string representation of each row from the database in the output le. is a quoted string (or CHAR or VARCHAR variable) that species the name of an output le in which to store the rows retrieved by the SELECT statement. This string can include a pathname. is a CHAR or VARCHAR variable that contains a SELECT statement. (See the Informix Guide to SQL: Syntax for the syntax of SELECT.)
lename
variable
Usage
The UNLOAD statement must include a SELECT statement (directly, or in a variable) to specify what rows to copy into lename. UNLOAD does not delete the copied data. The user must have SELECT privileges on every column specied in the SELECT statement. (For details of database-level and tablelevel privileges, see the GRANT statement in Informix Guide to SQL: Syntax.) The DATABASE or CONNECT statement must rst open the database that SELECT accesses before UNLOAD can be executed. You cannot use the PREPARE statement to preprocess an UNLOAD statement.
UNLOAD
DATETIME, INTERVAL
4-368
UNLOAD
Null values of any data type are represented by consecutive delimiters in the output le, without any characters between the delimiter symbols. Quotation marks ( " ) are required around a literal lename. The following statement copies any rows where the value of customer.customer_num is greater than or equal to 138, and stores them in a le called cust_le:
UNLOAD TO "cust_file" DELIMITER "!" SELECT * FROM customer WHERE customer_num> = 138
GLS
UNLOAD uses the environment variables DBFORMAT, DBMONEY, DBDATE, GL_DATE, and GL_DATETIME to determine the format of the output le. The precedence of these format specications is consistent with that of 4GL forms
and reports. For additional information about environment variables that are used in global language support, see Appendix E.
If you omit the DELIMITER clause, the default delimiter symbol is the value of the DBDELIMITER environment variable, or else a pipe ( | ) symbol ( = ASCII 124) if DBDELIMITER is not set. For details, see Appendix D.
UNLOAD
Hexadecimal numbers (0 through 9, a through f, or A through F) Newline character or CONTROL-J The backslash ( \ )
Host Variables
Do not attempt to substitute question marks ( ? ) in place of host variables to make the SELECT statement dynamic, because this usage has binding problems. The following 4GL code is an example of this (unsupported) syntax:
FUNCTION func_unload()
CHAR(250) CHAR(20) CHAR(1) INTEGER, j INTEGER, k INTEGER 100 30 400 ";" "/dev/tty"
i j k del file
LET query = "select * from systables where tabid >= ?" " and ncols >= ? and rowsize >= ?" UNLOAD TO file DELIMITER del query END FUNCTION
4-370
UNLOAD
UNLOAD TO file DELIMITER del SELECT * FROM Systables WHERE tabid >= i AND ncols >= j AND rowsize >= k END FUNCTION
The backslash character appears anywhere in a value from a CHAR, VARCHAR, or TEXT column. The delimiter character appears anywhere in a value from a CHAR, VARCHAR, or TEXT column. The newline character appears anywhere in a value from a VARCHAR column or as the last character in a TEXT column.
If LOAD (or tbload or onload) inserts output from UNLOAD into the database, all backslash symbols that were used as escape characters are automatically stripped from the values that are inserted into the database. See also the description of UNLOAD in the Informix Guide to SQL: Syntax.
References
DATABASE, LOAD
VALIDATE
VALIDATE
The VALIDATE statement tests whether the value of a variable is within the range of values for a corresponding column in the syscolval table. ,
VALIDATE Variable List LIKE Table Qualier p. 3-89 table
.column .*
Variable List
,
variable
.
record
.* . rst ,
THROUGH THRU record . last
array
Description is a variable of the ARRAY data type. is the name of a column of table for which an INCLUDE value exists in the syscolval table of the default database. is the name of a member variable of record to be validated. is another member that was declared later than rst in record. is the name of a program record to be validated. is the name or synonym of the table or view that contains column. is the name of a variable (of a simple data type) to be validated.
4-372
VALIDATE
Usage
If your program inserts data from a screen form, 4GL automatically checks for validation criteria that the form attributes specify. If your program inserts data into the database from sources other than a screen form, you can use the VALIDATE statement to apply validation criteria from the syscolval table. (For more information, see Default Attributes on page 6-80.) This statement has no effect unless the upscol utility has assigned INCLUDE values in the syscolval table for at least one of the database columns in the column list of the VALIDATE statement. If the value of a variable does not conform with the INCLUDE value in the syscolval table, 4GL sets the status variable to -1321. If you specify a list of variables and receive a negative status value, you must test the variables individually to detect the nonconforming value. Because INCLUDE can specify values only for columns of simple data types, the list of variables cannot include BYTE or TEXT variables. You can, however, include members of RECORD variables or elements of ARRAY variables if these members or elements are of simple data types.
In an ANSI-compliant database, you must qualify each table name with that of the owner of the table (owner.table). The only exception is that you can omit the owner prex for any tables that you own. For example, if you own tab1, Krystl owns tab2, and Nick owns tab3, you could use this statement:
VALIDATE var1, var2, var3 LIKE tab1.var1, krystl.tab2.var2, nick.tab3.var3
VALIDATE
You can also reference columns in tables outside the default database. See Table Qualiers on page 3-89 for more information. Even if you specify the name of a database in the table qualier, however, you must also include a DATABASE statement before the rst program block in the same module to specify a default database at compile time. (For more information, see The Default Database at Compile Time on page 4-73.)
In an ANSI-compliant database, each user of the upscol utility creates an owner.syscolval table, which stores validation criteria only for the tables owned by that user. If you omit the owner qualier for a table that you own, your syscolval table becomes the source for validation criteria when you compile the program. If the owner.syscolval table does not exist, the VALIDATE statement takes no action. (You can also include the owner name in a database that is not ANSI-compliant. If the owner value is incorrect, however, 4GL issues an error.) The compiler looks in the default database for syscolval. Any changes to syscolval after compilation have no effect on the 4GL program, unless you recompile the program. This example assumes that the state eld in the customer table has validation criteria in syscolval that limit the valid states to those in the Western region:
INPUT BY NAME p_customer.* ... AFTER FIELD zipcode CALL check_zip(p_customer.zipcode) RETURNING state_zip WHENEVER ERROR CONTINUE VALIDATE state_zip LIKE customer.state WHENEVER ERROR STOP IF (status < 0) THEN ERROR "This zipcode is not in the Western region." END IF ... END INPUT
4-374
VALIDATE
References
DATABASE, DEFINE, INITIALIZE, INPUT, INPUT ARRAY, WHENEVER
WHENEVER
WHENEVER
The WHENEVER statement traps SQL and 4GL errors, warnings, and end-ofdata conditions that might occur during program execution.
WHENEVER NOT FOUND CONTINUE
: label
label
Description is the identier of a function (with no parentheses and no argument list) to be invoked if the specied exceptional condition occurs. is a statement label (in the same program block) to which 4GL transfers control when the specied exceptional condition occurs.
Usage
WHENEVER can appear only within a MAIN, REPORT, or FUNCTION program block. It can trap errors, warnings, and the NOT FOUND condition at runtime.
Some type of exceptional condition An action to take if the specied exceptional condition is detected
These specications correspond respectively to the left-hand (conditions) and right-hand (actions) portions of the preceding syntax diagram.
4-376
WHENEVER
Using WHENEVER is equivalent to including code after every SQL statement, and (optionally) after certain other 4GL statements, instructing 4GL to take the specied action at runtime if the exceptional condition is detected. If you use WHENEVER ERROR with any option but STOP or CONTINUE, 4GL tests for errors by polling the global variable status. The following topics are discussed in this section:
s s s s s s s s s
The Scope of the WHENEVER Statement on page 4-377 The ERROR Condition on page 4-378 The ANY ERROR Condition on page 4-378 The NOT FOUND Condition on page 4-379 The WARNING Condition on page 4-379 The GOTO Option on page 4-379 The CALL Option on page 4-380 The CONTINUE Option on page 4-381 The STOP Option on page 4-381
WHENEVER
PRINT "Program will now attempt second insert." --9 INSERT INTO test_color VALUES ("blue") --10 CLOSE DATABASE --11 PRINT "Program over." --12 END MAIN --13
If you do not use any WHENEVER statements, the default action for WHENEVER ERROR (or for any other condition) is CONTINUE. Besides checking for errors after SQL statements, the WHENEVER ERROR statement also checks for errors after screen interaction statements and after VALIDATE statements. (In a WHENEVER statement, and only in this context, SQLERROR is a synonym for ERROR. You cannot, for example, substitute SQLERROR for ERROR in an OPTIONS or ERROR statement.)
4-378
WHENEVER
A FETCH statement attempts to retrieve a row beyond the rst or last row in the active set. A SELECT statement returns no rows.
In both cases, the sqlcode variable is set to 100. The following statement calls the no_rows( ) function whenever the NOT FOUND condition is detected:
WHENEVER NOT FOUND CALL no_rows
Although both NOT FOUND and NOTFOUND indicate the same condition, you cannot use them interchangeably. Use NOTFOUND (one word) in testing status, and use NOT FOUND (two words) in the WHENEVER statement.
WHENEVER
The label that follows the GOTO keyword must be declared by a LABEL statement in the same FUNCTION, REPORT, or MAIN program block as the current WHENEVER statement. For example, the WHENEVER statement in this program fragment transfers control to the statement labeled missing: whenever the NOT FOUND condition occurs:
FUNCTION query_data() ... FETCH FIRST a_curs INTO p_customer.* WHENEVER NOT FOUND GO TO :missing ... LABEL missing: MESSAGE "No customers found." SLEEP 3 MESSAGE "" END FUNCTION
If your source module contains more than one program block, you might need to redene the error condition. For example, suppose that the module contains three functions, and the rst function includes a WHENEVER ... GOTO statement and a corresponding LABEL statement. When compilation moves from the rst FUNCTION denition to the next, the WHENEVER specication still species a jump to the label, but that label is no longer dened in the second FUNCTION block. If the compiler processes an SQL statement within that block before you redene the action to take for the same condition (for example, to WHENEVER ERROR CONTINUE), a compilation error results.To avoid this error, you can reset the error condition by issuing another WHENEVER statement. Alternatively, you can use the LABEL statement to dene the same statement label in each function, or you can use the CALL option of WHENEVER to invoke a separate function.
4-380
WHENEVER
If you use the BEGIN WORK statement in a function called by WHENEVER, always specify WHENEVER ERROR CONTINUE and WHENEVER WARNING CONTINUE before the ROLLBACK WORK statement. This prevents the program from looping if ROLLBACK WORK encounters an error or warning. You cannot specify the name of a stored procedure after the CALL keyword. To invoke a stored procedure, use the CALL clause to execute a function that contains an EXECUTE PROCEDURE statement for the desired procedure.
References
CALL, DEFER, FOREACH, FUNCTION, GOTO, IF, LABEL, VALIDATE
WHILE
WHILE
The WHILE statement executes a block of statements while a condition that you specify by a Boolean expression is true.
WHILE
END WHILE
Element statement
Usage
If the Boolean expression is true, 4GL executes the statements that follow it, down to the END WHILE keywords. 4GL again evaluates the Boolean expression, and if it is still true, 4GL executes the same statement block. If the expression is false, however, 4GL terminates the WHILE loop and resumes execution after the END WHILE keywords. (If the expression is already false on entry to the WHILE statement, program control passes directly to the statement immediately following END WHILE.) In the following example, if the user responds to the prompt by typing y, 4GL calls the enter_order( ) function and displays a prompt, asking whether the user wants to enter another order. 4GL continues entering orders and prompting the user, as long as the user types y in response to the prompt:
LET answer = "y" WHILE answer = "y" CALL enter_order() PROMPT "Do you want to enter another order (y/n) : " FOR answer END WHILE
The CONTINUE WHILE or EXIT WHILE keywords can interrupt the sequence of statements in a WHILE loop as described in the following sections.
4-382
WHILE
If your database has transaction logging, it is advisable that the entire WHILE loop be within a transaction. (For more information about the SQL statements that support transactions, see Informix Guide to SQL: Tutorial.)
Skips statements between EXIT WHILE and END WHILE Resumes execution at the statement following END WHILE
The following example demonstrates using the EXIT WHILE statement within a WHILE loop. If the status variable is not equal to zero, 4GL executes the statements that follow the END IF keywords. Otherwise, 4GL exits from the WHILE loop and executes the following DISPLAY statement:
WHILE TRUE ... IF status = 0 THEN EXIT WHILE END IF ... END WHILE DISPLAY p_customer.* TO customer.*
If, as in this example, statements in the WHILE loop cannot change the value of the Boolean expression to FALSE, the WHILE loop cannot terminate unless you specify EXIT WHILE, GOTO, or some other logical way out of the loop.
WHILE
References
CONTINUE, END, EXIT, FOR, FOREACH
4-384
Chapter
Functions in 4GL Programs . . . . . . . . . . . Built-In 4GL Functions . . . . . . . . . . . Built-In and External SQL Functions and Procedures . C Functions . . . . . . . . . . . . . . . ESQL/C Functions . . . . . . . . . . . . Programmer-Dened 4GL Functions . . . . . . Invoking Functions . . . . . . . . . . . . Operators of 4GL . . . . . . . . . . . . . . . . . .
Syntax of Built-In Functions and Operators . . . . . Aggregate Report Functions . . . . . . . . . The GROUP Keyword . . . . . . . . . . The WHERE Clause . . . . . . . . . . . The MIN( ) and MAX( ) Functions . . . . . . The AVG( ) and SUM( ) Functions . . . . . . The COUNT ( * ) and PERCENT ( * ) Functions . Differences Between the 4GL and SQL Aggregates ARG_VAL( ) . . . . . . . . . . . . . . Arithmetic Operators. . . . . . . . . . . . Unary Arithmetic Operators . . . . . . . . Binary Arithmetic Operators . . . . . . . . Exponentiation ( ** ) Operator . . . . . . . Modulus (MOD) Operator . . . . . . . . Multiplication ( * ) and Division ( / ) Operators . Addition ( + ) and Subtraction ( - ) Operators . . ARR_COUNT( ) . . . . . . . . . . . . . ARR_CURR( ) . . . . . . . . . . . . . .
ASCII . . . . . . . . . . . . Boolean Operators . . . . . . . . Logical Operators. . . . . . . Boolean Comparisons . . . . . Relational Operators . . . . . . The NULL Test. . . . . . . . The LIKE and MATCHES Operators Set Membership and Range Tests . CLIPPED . . . . . . . . . . . COLUMN . . . . . . . . . . Concatenation ( || ) Operator . . . . CURRENT . . . . . . . . . . CURSOR_NAME( ) . . . . . . . DATE . . . . . . . . . . . . DAY( ) . . . . . . . . . . . . DOWNSHIFT( ) . . . . . . . . ERR_GET( ) . . . . . . . . . . ERR_PRINT( ) . . . . . . . . . ERR_QUIT( ). . . . . . . . . . ERRORLOG( ) . . . . . . . . . EXTEND( ) . . . . . . . . . . FGL_DRAWBOX( ) . . . . . . . FGL_GETENV( ) . . . . . . . . FGL_GETKEY( ) . . . . . . . . FGL_KEYVAL( ) . . . . . . . . FGL_LASTKEY( ) . . . . . . . . FGL_SCR_SIZE( ) . . . . . . . . FGL_SETCURRLINE ( ) . . . . . . FIELD_TOUCHED( ) . . . . . . . GET_FLDBUF( ) . . . . . . . . INFIELD( ) . . . . . . . . . . LENGTH( ) . . . . . . . . . . LINENO . . . . . . . . . . . MDY( ) . . . . . . . . . . . Membership ( . ) Operator . . . . . MONTH( ) . . . . . . . . . . NUM_ARGS( ) . . . . . . . . .
5-2 IBM Informix 4GL Reference Manual
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5-31 5-33 5-33 5-34 5-35 5-37 5-38 5-40 5-45 5-47 5-50 5-51 5-53 5-56 5-58 5-59 5-61 5-63 5-64 5-65 5-67 5-70 5-73 5-75 5-76 5-78 5-81 5-83 5-84 5-87 5-90 5-92 5-94 5-95 5-97 5-98 5-99
ORD( ) . . . . . . . . . . . . . . . . . . PAGENO . . . . . . . . . . . . . . . . . SCR_LINE( ) . . . . . . . . . . . . . . . . SET_COUNT( ) . . . . . . . . . . . . . . . SHOWHELP( ) . . . . . . . . . . . . . . . SPACE . . . . . . . . . . . . . . . . . . STARTLOG( ) . . . . . . . . . . . . . . . . Substring ( [ ] ) Operator . . . . . . . . . . . . TIME . . . . . . . . . . . . . . . . . . TODAY . . . . . . . . . . . . . . . . . . UNITS . . . . . . . . . . . . . . . . . . UPSHIFT( ) . . . . . . . . . . . . . . . . . USING . . . . . . . . . . . . . . . . . . WEEKDAY( ) . . . . . . . . . . . . . . . . WORDWRAP . . . . . . . . . . . . . . . . Tabs, Line Breaks, and Page Breaks with WORDWRAP Kinsoku Processing . . . . . . . . . . . . YEAR( ) . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . .
. 5-100 . 5-101 . 5-102 . 5-104 . 5-106 . 5-108 . 5-110 . 5-113 . 5-116 . 5-117 . 5-119 . 5-121 . 5-123 . 5-133 . 5-135 . 5-136 . 5-137 . 5-138
5-4
In This Chapter
This chapter describes the kinds of built-in functions you can use in INFORMIX-4GL applications. It also describes 4GL operators. Information about the syntax and usage of these built-in functions and operators appears in the sections that follow, arranged in alphabetical order according to the name of the function or operator. (Aggregate functions, arithmetic operators, and most Boolean operators are described under those headings, rather than under their individual names.)
C functions
ESQL/C functions (if you have INFORMIX-ESQL/C)
The FUNCTION statement denes a function. Variables that are declared within a function are local to it, but functions that are dened in the same module can reference any module-scope variables that are declared in that module. See the descriptions in Programmer-Dened 4GL Functions on page 5-8, and FUNCTION on page 4-140. The other types of functions that you can call from a 4GL program are briey discussed on the next two pages.
You can invoke them with the CALL statement. (If they return a single value, they can appear without CALL in 4GL expressions.) They require parentheses, even if the argument list is empty. You cannot invoke them from SQL statements. You can invoke them from a C program.
s s s
If you use the FUNCTION statement to dene a function with the same name as a built-in function, your program cannot invoke the built-in function. Each of the following 4GL built-in functions is described in this chapter.
ARG_VAL(int-expr) ARR_COUNT( ) ARR_CURR(char-expr) CURSOR_NAME ("identier") DOWNSHIFT(char-expr) ERR_GET(int-expr) ERR_PRINT(int-expr) ERR_QUIT(int-expr) ERRORLOG(int-expr) FGL_DRAWBOX(nlines, ncols, begy, begx, color) FGL_GETENV(char-expr) FGL_GETKEY( ) FGL_KEYVAL(char-expr) FGL_LASTKEY( ) FGL_SCR_SIZE( ) LENGTH(char-expr) NUM_ARGS( ) ORD(char-expr) SCR_LINE( ) SET_COUNT(int-expr) SHOWHELP(int-expr) STARTLOG("lename.letype") UPSHIFT(char-expr)
5-6
FGL_DRAWBOX( ) arguments are integer expressions, except for color, which can also be a keyword. The aggregates AVG( ), COUNT(*), MAX( ), MIN( ), PERCENT(*), and SUM( ) are valid only in reports. For more information, see
These SQL statements register and execute external functions and stored procedures, which resemble 4GL functions but are executed by the database server.) Calls to SQL, SPL, and external functions can appear in SQL statements but not in other 4GL statements. (See the Informix Guide to SQL: Syntax.)
C Functions
You can use the CALL statement or an expression to invoke properly written C language functions within a 4GL program. Such functions are often helpful for specialized tasks that are not easily written in 4GL, such as processing binary I/O. For information on the application program interface (API) between 4GL and the C programming language, see Appendix C, Using C with INFORMIX-4GL. Unlike 4GL identiers, names of C functions and their arguments are casesensitive. They must typically appear in lowercase letters in the function call.
ESQL/C Functions
If you have INFORMIX-ESQL/C, your 4GL program can also call compiled ESQL/C functions that you write, as well as ESQL/C library functions. See Running Programs That Call C Functions on page 1-90.
Built-In Functions and Operators 5-7
END FUNCTION
,
argument
Description is the name of a formal argument to the function. is the identier that you declare here for the function. is an SQL statement or other 4GL statement.
The left-hand portion of this diagram, including the identier of the function and the list of formal arguments, is sometimes called the function prototype (described in detail in The Prototype of the Function on page 4-141). This portion resembles the prototype of a report. Names of functions must be unique among the names of functions, reports, and global variables within the program and cannot be the same as any of the formal arguments of the same function. See FUNCTION on page 4-140 for details of how to dene 4GL functions. The right-hand portion of this diagram, including the declarations of formal arguments and of local variables, and the statement block, is sometimes called the FUNCTION program block. This portion can include any executable statement of SQL or 4GL except the report execution statements (described in 4GL Report Execution Statements on page 4-14). The entire FUNCTION program block must be dened within a single source module.
5-8
Invoking Functions
No other FUNCTION, REPORT, or MAIN program block can be included in a FUNCTION denition, but it can include statements that produce a report, call a function, or execute a RUN statement that invokes another program.
Invoking Functions
Except for SQL functions and stored procedures, which are called in SQL expressions, 4GL programs can use the CALL statement to invoke functions. In some contexts, however, you can also call functions implicitly:
s
If a function returns a single value, you can invoke the function simply by specifying its name (and any required arguments) within an expression where a value of the returned data type is valid. Exception-handling features of 4GL can automatically invoke the function that you specify in the WHENEVERCALL statement.
Invoking Functions
Important: Some built-in 4GL functions and operators have the same names as SQL functions or operators. For example, CURRENT, DATE( ), DAY( ), EXTEND( ), LENGTH( ), MDY( ), MONTH( ), WEEKDAY( ), YEAR( ), and the relational operators are features of both 4GL and SQL. (For more information, see Relational Operators on page 5-35.) You will generally encounter a compile-time or link-time error, however, if a statement that is not an SQL statement references an SQL function or operator that is not also a 4GL function or operator. Built-in SQL functions and operators like USER cannot appear in other 4GL statements, however, that are not SQL statements. If a program requires the functionality of USER in a non-SQL statement like PROMPT, for example, you must rst use FUNCTION to dene an equivalent 4GL function:
FUNCTION get_user() DEFINE uid LIKE informix.sysusers.username SELECT USER INTO uid FROM informix.systables WHERE tabname = "systables" -- row is sure to exist and to be singular RETURN uid END FUNCTION
To require no cursor, the SELECT statement in this example must be written so that it returns only one row. Here the get_user( ) function selects the row of systables that names itself because this row it is sure to exist and to be unique. (The owner name informix is required to reference tables of the system catalog only in an ANSI-compliant database, but it is valid in any SQL database where it is an owner name.)
5-10
Operators of 4GL
Operators of 4GL
The operators of INFORMIX-4GL differ in several ways from 4GL functions:
s
Except for GET_FLDBUF( ), the CALL statement cannot invoke operators. Some operators can take special non-alphanumeric symbols as operands. You cannot reference operators from a C program.
Despite these differences, 4GL operators are described in this chapter because they resemble the built-in 4GL functions in their syntax and behavior. Operators that return a single value can be operands in expressions. The FUNCTION statement can dene (and CALL can invoke) a 4GL function that has the same name as an operator. In this case, only the operator, not the function, is visible as an operand within a 4GL expression. For example:
let dt = mdy(1,2,3) call mdy(1,2,3) --built-in MDY() operator --programmer-defined MDY() function
These operators (and additional arithmetic and relational operators) are included in this chapter as a convenience, so that you can nd syntax articles without needing to classify a given feature as a function or as an operator.
Operators that are represented by non-alphabetic symbols are grouped in this chapter under the following headings:
s s s s s
Arithmetic Operators on page 5-20 Relational Operators on page 5-35 Concatenation ( || ) Operator on page 5-50 Membership ( . ) Operator on page 5-97 Substring ( [ ] ) Operator on page 5-113
The following table lists the arithmetic and relational operators of 4GL.
Arithmetic Operators Symbol + / ** MOD * + Description Addition Division Exponentiation Modulus Multiplication Subtraction Unary negative Unary positive Page 5-26 5-25 5-25 5-25 5-25 5-26 5-22 5-22 Symbol Relational Operators Description Page 5-34 5-35 5-34 5-34 5-35 5-34
< Less than <= Less than or equal to = or == Equal to != or <> Not equal to >= Greater than or equal to > Greater than
For a general discussion of 4GL operators, see Operators in 4GL Expressions on page 3-53.
5-12
Valid only in the FORMAT section of a REPORT program block. Valid only in the COLOR attribute of a form specication, and in SQL statements.
(*) ( (
Number Expression ) p. 3-66 INTERVAL Expression p. 3-72 4GL Expression p. 3-49 WHERE Boolean Expression p. 3-60
Usage
Aggregate report functions return statistical aggregates (or for MAX and MIN, extrema) based on input records of a 4GL report. The GROUP keyword restricts the data set to the current AFTER GROUP OF control block; the WHERE keyword can apply a Boolean lter. Otherwise, returned values are based on the entire data set. The 4GL report aggregates resemble the SQL aggregates that can appear in SELECT or DELETE statements, but their syntax is not identical. For details, see Differences Between the 4GL and SQL Aggregates on page 5-17. Aggregate report functions cannot appear as operands or as arguments in 4GL expressions, and cannot be nested. That is, no expression within a report aggregate can include a report aggregate. An error typically occurs if you attempt to use the name of an aggregate as an identier. Programmer-dened functions to calculate the same statistics can be invoked from within or outside of REPORT denitions, but you must declare other names for such functions.
5-14
Variables of large or structured data types cannot be arguments to these functions. You can, however, specify the name of a simple variable that is a member of a record, or that is an element of an array. For more information, see Variables of Large Data Types on page 4-86 and Simple Data Types on page 3-9.
AVG( ), SUM( ), MIN( ), and MAX( ) ignore records with null values for their argument, but each returns NULL if all records have a null value.
If an aggregate value that depends on all records of the report appears anywhere except in the ON LAST ROW control block, each variable in that aggregate or WHERE clause must also appear in the list of formal arguments of the report. (Examples of aggregates that depend on all records include using GROUP COUNT(*) anywhere in a report, or using any aggregate without the GROUP keyword anywhere outside the ON LAST ROW control block.)
4GL stores intermediate results for aggregates in temporary tables. An error
results if no database is open (because the temporary table cannot be created), or if you change or close the current database while evaluating an aggregate.
In nondefault locales, 4GL sorts character operands of MIN( ) or MAX( ) in code-set order, unless the locale les dene a localized collation sequence in its COLLATION category, and DBNLS is set to 1. This order also applies to character variables whose values were retrieved from the database. Unlike the database, 4GL makes no distinction between character strings whose values were retrieved from CHAR or VARCHAR columns and values from NCHAR or NVARCHAR columns of the database. To sort strings by the rules of the database, rather than by these 4GL rules, write your code so that the database performs the sorting.
5-16
The following fragment of a REPORT routine uses the AFTER GROUP OF control block and GROUP keyword to form sets of records according to how many items are in each order. The last PRINT statement calculates the total price of each order, adds a shipping charge, and prints the result.
AFTER GROUP OF number SKIP 1 LINE PRINT 4 SPACES, "Shipping charges for the order: ", ship_charge USING "$$$$.&&" PRINT 4 SPACES, "Count of small orders: ", COUNT(*) WHERE total_price < 200.00 USING "##,###" SKIP 1 LINE PRINT 5 SPACES, "Total amount for the order: ", ship_charge + GROUP SUM(total_price) USING "$$,$$$,$$$.&&"
With no WHERE clause, GROUP SUM here combines every item in the group.
Only 4GL report aggregates can use the PERCENT( * ) and GROUP keywords. Only SQL aggregates can use ALL, DISTINCT, and UNIQUE as keywords. In 4GL reports, COUNT can only take an asterisk ( * ) as its argument, but in SELECT or DELETE statements of SQL, the COUNT aggregate can also use a column name or an SQL expression as its argument.
Only SQL aggregate functions can use database column names as arguments, but this syntax difference is not of much practical importance. (Operands in the expressions that you specify as arguments for 4GL report aggregates can be program variables that contain values from database columns.)
References
LINENO, PAGENO, WORDWRAP
ARG_VAL( )
ARG_VAL( )
The ARG_VAL( ) function returns a specied argument from the command line that invoked the current 4GL application program. It can also return the name of the current 4GL program.
ARG_VAL ( ordinal )
Element ordinal
Description is an integer expression that evaluates to a non-negative whole number no larger than the number of arguments of the program. (See the syntax of Integer Expressions on page 3-63.)
Usage
This function provides a mechanism for passing values to the 4GL program through the command line that invokes the program. You can design a 4GL program to expect or allow arguments after the name of the program in the command line. Like all 4GL functions, ARG_VAL( ) can be invoked from any program block. You can use it to pass values to MAIN, which cannot have formal arguments, but you are not restricted to calling ARG_VAL( ) from the MAIN statement. You can use the ARG_VAL( ) function to retrieve individual arguments during program execution. (You can also use the NUM_ARGS( ) function to determine how many arguments follow the program name on the command line.) If 1 ordinal = n, ARG_VAL(n) returns the nth command-line argument (as a character string). The value of ordinal must be between 0 and the value returned by NUM_ARGS ( ), the number of command-line arguments. The expression ARG_VAL(0) returns the name of the 4GL application program.
5-18
ARG_VAL( )
In either case, statements in the following program fragment use the ARG_VAL( ) function to store in an array of CHAR variables all the names that the user who invoked myprog entered as command-line arguments:
DEFINE args ARRAY[8] OF CHAR(10), i SMALLINT . . . FOR i = 1 TO NUM_ARGS() LET args[i] = ARG_VAL(i) END FOR
After myprog is invoked by these command-line arguments, the NUM_ARGS( ) function returns the value 4. Executing the LET statements in the FOR loop assigns the following values to elements of the args array.
Variable args[1] args[2] args[3] args[4] Value
joe bob sue les
Reference
NUM_ARGS( )
Arithmetic Operators
Arithmetic Operators
The 4GL arithmetic operators perform arithmetic operations on operands of number data types (and in some cases, on operands of time data types). Arithmetic expressions that return a number value have this syntax.
Number Expression
+ -
+ * /
MOD
** )
(
Case II: Differences between DATE values
In the next three syntax diagrams, the DATETIME and INTERVAL expression segments are only a subset of time expressions, as described in Time Expressions on page 3-72. A DATETIME expression or an INTERVAL expression used as an arithmetic operand can be any of the following items:
s s s
A program variable of the DATETIME or INTERVAL data type. A DATETIME or INTERVAL value that a function or operator returns. A DATETIME literal (page 3-78) or an INTERVAL literal (page 3-82).
A DATETIME or INTERVAL expression cannot be a quoted string, or numeric DATETIME value (page 3-78), or numeric INTERVAL value (page 3-82), that omits the DATETIME or INTERVAL keyword and the DATETIME qualier or INTERVAL qualier.
5-20 IBM Informix 4GL Reference Manual
Arithmetic Operators
This is the syntax for arithmetic expressions that return an INTERVAL value.
Time Expression
+ -
+ * / -
INTERVAL Expression p. 3-74 Number Expression p. 3-66 DATE Expression p. 3-74 DATETIME Expression p. 3-74
This is the syntax for arithmetic expressions that return a DATE value.
Time Expression
+ +
This is the syntax for arithmetic expressions that return a DATETIME value.
Time Expression
Arithmetic Operators
Usage
The arithmetic operators of 4GL resemble the arithmetic functions of Informix database servers, but they are evaluated by the client system. Arithmetic operands can only be of simple data types. Structured (ARRAY or RECORD) or large (BYTE or TEXT) data types are not valid as operands. An operand, however, can be a simple variable that is a member of a record or that is an element of an array. The range of returned values is that of the returned data type. In most contexts, CHAR or VARCHAR character-string representations of number values are valid as arithmetic operands, but this imposes additional overhead for data type conversion. The direct use of number data types tends to support better performance in 4GL applications that make intensive use of arithmetic operators. If a Boolean expression is an arithmetic operand, 4GL evaluates it and converts it to an integer by these rules: TRUE = 1 and FALSE = 0. If any component of an expression that includes an arithmetic operator is a null value, the entire expression returns NULL, unless the null component is an operand of the IS NULL or IS NOT NULL operators.
5-22
Arithmetic Operators
4GL performs calculations with binary arithmetic operators of number data types after automatically converting both operands to DECIMAL values.
Time operands in arithmetic expressions cannot be quoted strings representing numeric date and time values (page 3-78) nor numeric time intervals (page 3-82). Use instead DATETIME literals or INTERVAL literals that include an appropriate DATETIME qualier or INTERVAL qualier. For example, the following LET statement that attempts to use an arithmetic time expression as its right-hand term in fact assigns a null value to the INTERVAL variable totalsec, rather than an interval of 9 years.
LET totalsec = "2002-01-01 00:00:00.000" - "1993-01-01 00:00:00.000"
If the rst operand of an arithmetic expression includes the UNITS operator (UNITS on page 5-119), you must enclose that operand in parentheses.
Arithmetic Operators
The following table shows the precedence ( P ) and data types of operands and of returned values for both unary and binary arithmetic operators. Time operands not listed here produce either errors or meaningless results.
P 13 12 11 10 Expression Left (= x)
+ y - y x * * y x MOD y x x x x x x x x x x x x x x x x * y / y + + + + + + y y y y y y y y y y y y y y
Returned Value Same as y Same as y Same as y Same as y Same as y Same as x Number DATE DATE DATETIME DATETIME INTERVAL Number DATE DATE DATETIME INTERVAL INTERVAL INTERVAL INT
Number INT or SMALLINT Number or INTERVAL Number or INTERVAL Number INT or SMALLINT DATE DATE or DATETIME INTERVAL INTERVAL Number INT or SMALLINT DATE DATE or DATETIME DATE or DATETIME DATETIME INTERVAL DATE
INT or SMALLINT INT or SMALLINT Number Number Number DATE INT or SMALLINT INTERVAL DATE or DATETIME INTERVAL Number DATE INT or SMALLINT INTERVAL DATETIME DATE INTERVAL DATE
The precedence of all 4GL operators is listed in Operators in 4GL Expressions on page 3-53; the operators that are not listed on that page have a precedence of 1. These precedence ( P ) values are ordinal numbers to show relative ranks. Important: DATE and DATETIME values have no true zero point. Such values can support addition, subtraction, and the relational operators, but division, multiplication, and exponentiation are logically undened for these data types.
5-24
Arithmetic Operators
Exponentiation ( ** ) Operator
The exponentiation ( ** ) operator returns a value calculated by raising the left-hand operand to a power corresponding to the integer part of the righthand operand. This right-hand operand cannot have a negative value. An expression specifying the right-hand MOD operand cannot include the exponentiation operator. Before conversion to DECIMAL for evaluation, 4GL converts the right-hand operand of the exponentiation operator to an INTEGER value. Any fractional part is discarded.
In 4GL programs, MOD is a reserved word. Do not use it as a 4GL identier. An expression specifying the right-hand MOD operand cannot include the exponentiation or modulus operator, and it cannot be zero. Before conversion to DECIMAL for evaluation, 4GL converts any operand of MOD that is not of the INTEGER or SMALLINT data type to an INTEGER value by truncation. Any fractional part is discarded.
Arithmetic Operators
When the results of division are assigned to a xed-point DECIMAL variable, results are rounded, rather than truncated, if the fractional part contains more decimal places than the declared scale of the receiving DECIMAL data type.
References
Aggregate Report Functions, Boolean Operators, EXTEND, UNITS
5-26 IBM Informix 4GL Reference Manual
ARR_COUNT( )
ARR_COUNT( )
The ARR_COUNT( ) function returns a positive whole number, typically representing the number of records entered in a program array during or after execution of the INPUT ARRAY statement.
ARR_COUNT( )
Usage
You can use ARR_COUNT( ) to determine the number of program records that are currently stored in a program array. In typical 4GL applications, these records correspond to values from the active set of retrieved database rows from the most recent query. By rst calling the SET_COUNT( ) function, you can set an upper limit on the value that ARR_COUNT( ) returns.
ARR_COUNT( ) returns a positive integer, corresponding to the index of the
furthest record within the program array that the screen cursor accessed. Not all the rows counted by ARR_COUNT( ) necessarily contain data (for example, if the user presses the DOWN ARROW key more times than there are rows of data). If SET_COUNT( ) was explicitly called, ARR_COUNT( ) returns the greater of these two values: the argument of SET_COUNT( ) or the highest value attained by the array index. The insert_items( ) function in the following example uses the value returned by ARR_COUNT( ) to set the upper limit in a FOR statement:
FUNCTION insert_items() DEFINE counter SMALLINT FOR counter = 1 TO ARR_COUNT() INSERT INTO items VALUES (p_items[counter].item_num, p_orders.order_num, p_items[counter].stock_num, p_items[counter].manu_code, p_items[counter].quantity, p_items[counter].total_price) END FOR END FUNCTION
ARR_COUNT( )
The following example makes use of ARR_COUNT( ) and the related built-in functions ARR_ CURR( ) and SCR_LINE( ) to assign values to variables within the BEFORE ROW clause of an INPUT ARRAY WITHOUT DEFAULTS statement. By calling these functions in BEFORE ROW, the respective variables are evaluated each time the cursor moves to a new line and are available within other clauses of the INPUT ARRAY statement.
INPUT ARRAY ga_manuf WITHOUT DEFAULTS FROM sa_manuf.* BEFORE ROW LET curr_pa = ARR_CURR() LET curr_sa SCR_LINE() LET total_pa = ARR_COUNT()
You can have a statement, in a later statement within INPUT ARRAY, such as the following example, which tests whether the cursor is at the last position in the screen array:
IF curr_pa <> total_pa THEN ...
References
ARR_CURR( ), FGL_SETCURRLINE( ), SCR_LINE( ), SET_COUNT( )
5-28
ARR_CURR( )
ARR_CURR( )
During or immediately after the INPUT ARRAY or DISPLAY ARRAY statement the ARR_CURR( ) function returns the number of the program record within the program array that is displayed in the current line of a screen array.
ARR_CURR( )
Usage
The current line of a screen array is the line that displays the screen cursor at the beginning of a BEFORE ROW or AFTER ROW clause. The ARR_CURR( ) function returns an integer value. The rst row of the program array and the rst line (that is, top-most) of the screen array are both numbered 1. The built-in functions ARR_CURR( ) and SCR_LINE( ) can return different values if the program array is larger than the screen array. You can pass ARR_CURR( ) as an argument when you call a function. In this way the function receives as its argument the current record of whatever array is referenced in the INPUT ARRAY or DISPLAY ARRAY statement. The ARR_CURR( ) function can be used to force a FOR loop to begin beyond the rst line of an array by setting a variable to ARR_CURR( ) and using that variable as the starting value for the FOR loop. The following program segment tests the user input for duplication of what should be a unique column. If the eld duplicates an existing item, the program instructs the user to try again.
INPUT ARRAY ga_manufact FROM sa_manufact.* AFTER FIELD manu_code IF pk_check(ARR_CURR()) THEN ERROR "This code already exists. Re-enter", " or press F2 to delete this entry." NEXT FIELD manu_code END IF END INPUT
ARR_CURR( )
In this example, the value returned by ARR_CURR( ) is then passed to function pk_check( ), where it is stored in the local variable el_pa, serving as an index to the global array ga_manufact:
FUNCTION pk_check(el_pa) --verifies primary key DEFINE el_pa, manu_count INT SELECT COUNT(*) INTO manu_count FROM manufact WHERE manufact.manu_code = ga_manufact[el_pa].manucode IF manu_count >= 1 THEN RETURN TRUE ELSE RETURN FALSE END IF END FUNCTION
The ARR_CURR( ) function is frequently used with a DISPLAY ARRAY statement in popup windows to return the users selection. The following example allows users to choose supplier codes for shoes in an order form. The user chooses among eight possibilities. The choice is returned and displayed on a form. The variables pa_supplier and elem_pa are locally dened. The variable gr_shoes is a global record associated with an INPUT statement.
OPEN WINDOW w_supplier AT 3,50 WITH FORM "f_popscode" ATTRIBUTE (BORDER, REVERSE) DISPLAY "Press ESC to select." AT 1,1 DISPLAY "Use arrow keys to move." at 2,1 CALL SET_COUNT(8) DISPLAY ARRAY pa_supplier TO sa_supplier.* LET elem_pa = ARR_CURR() LET gr_shoes.supply_code = pa_supplier[elem_pa].s_code CLOSE WINDOW w_supplier DISPLAY BY NAME gr_shoes.supply_code
References
ARR_COUNT( ), FGL_SETCURRLINE( ), SCR_LINE( )
5-30
ASCII
ASCII
The ASCII operator converts an integer operand into its corresponding ASCII character.
ASCII number
Element number
Description is an integer expression (as described in Integer Expressions on page 3-63) that returns a positive whole number within the range of ASCII values.
Usage
You can use the ASCII operator to evaluate an integer to a single character. This operator is especially useful if you need to display CONTROL characters. The following DISPLAY statement rings the terminal bell (ASCII value of 7):
DEFINE bell CHAR(1) LET bell = ASCII 7 DISPLAY bell
The next REPORT program block fragments show how to implement special printer or terminal functions. They assume that, when the printer receives the sequence of ASCII characters 9, 11, and 1, it will start printing in red, and when it receives 9, 11, and 0, it will revert to black printing. The values used in the example are hypothetical; refer to the documentation for your printer or terminal for information about which values to use.
FORMAT FIRST PAGE HEADER LET red_on = ASCII 9, ASCII 11, ASCII 1 LET red_off = ASCII 9, ASCII 11, ASCII 0 ON EVERY ROW ... PRINT red_on, "Your bill is overdue.", red_off
ASCII
Warning: 4GL cannot distinguish between printable and nonprintable ASCII characters. Be sure to account for nonprinting characters when using the COLUMN operator to format the screen or a page of report output. Because devices differ in outputting spaces with control characters, you might need to use trial and error to align columns properly when you include control characters in output.
ASCII 0 only displays the null character within the PRINT statement. If you specify ASCII 0 in other contexts, it returns a blank space.
References
FGL_KEYVAL( ), FGL_LASTKEY( )
5-32
Boolean Operators
Boolean Operators
A 4GL Boolean operator returns TRUE (= 1), FALSE (= 0) or NULL. These 4GL operators resemble the SQL Boolean operators, but some are not identical.
Boolean Expression
NOT
FALSE
Relational Comparison p. 5-35 NULL Test p. 5-37 Membership and Range Tests p. 5-40
The Boolean operators include the logical operators AND, OR, and NOT, and operators for Boolean comparisons, as described in the sections that follow.
Logical Operators
The logical operators AND, OR, and NOT combine Boolean values into a single 4GL Boolean expression. AND, OR, and NOT produce the following results (where T means TRUE, F means FALSE, and ? means NULL).
AND T F ? T T F ? F F F F ? ? F ? OR T F ? T T T T F T F ? ? T ? ? NOT T F ?
F T ?
Values of right-hand operands appear in boldface below each operator; the top row also lists the possible values of left-hand operands of AND and OR.
Built-In Functions and Operators 5-33
Boolean Operators
Returned values appear in the cells where the row and column intersect. Any nonzero operand that is not null is treated as TRUE by the logical operators. For more information, see Evaluating Boolean Expressions on page 5-42. When one or both arguments of a logical operator are null, the result can in some cases also be null. For example, if var1 = 0 and var2 = NULL, the following expression assigns a null value to variable x:
LET x = var1 OR var2
even if the value of the rst operand has already determined the returned value. The NOT operator is recursive.
Boolean Comparisons
Boolean comparisons can test any type of expression for equality or inequality, null values, or set membership, using the following Boolean operators:
s s s s s
The IN and BETWEENAND operators are valid only in SQL statements. They cause a compilation error if you include them in other 4GL statements. They are listed here, however, because they are valid in the WHERE clause of a form specication le that includes the COLOR attribute. For more information, see Boolean Expressions in 4GL Form Specication Files on page 6-38. Boolean expressions in the CASE, IF, or WHILE statements (or in the WHERE clause of a COLOR attribute specication) return FALSE if any element of the comparison is null, unless it is the operand of the IS NULL or IS NOT NULL operator. Use a NULL test to detect and exclude null values in Boolean comparisons. In this CASE statement fragment, the value of the comparison is null if the value of salary or of last_raise is null:
WHEN salary * last_raise < 25000
5-34
Boolean Operators
You can use any value that is not false ( = 0) or null as a Boolean expression that returns TRUE. The constant TRUE, however, has the specic value of 1. Thus, the value FALSE is returned by a comparison like:
(10 = TRUE)
Relational Operators
These operators perform relational comparisons in Boolean expressions.
Relational Comparison Expression p. 3-49
Boolean expressions in 4GL statements can use these relational operators ( =, ==, <, >, <=, >=, <>, or !=, as dened in Evaluating Boolean Expressions on page 5-42) to compare operands. For example, each of the following comparisons returns TRUE or FALSE.
Expression (2+5)* 3 = 18 14 <= 16 "James" = "Jones" Value FALSE TRUE FALSE
For character expressions, the result depends on the position of the initial character of each operand within the collation sequence. The collation sequence is the code-set order unless the locale les dene a localized collation sequence in the COLLATION category, and DBNLS is set to 1. If the initial characters are identical in both strings, 4GL compares successive characters, until a non-identical character is found, or until the end of a string is encountered.
Built-In Functions and Operators 5-35
Boolean Operators
For number expressions, the result of a relational comparison reects the relative positions of the calculated values of the two operands on the real line. Relational comparisons of time expression operands follow these rules:
s
Comparison x < y is true when x is a briefer interval span than y, or when x is an earlier DATE or DATETIME value than y. Comparison x > y is true when x is a longer interval span than y, or when x is a later DATE or DATETIME value than y. You cannot compare an interval with a DATE or DATETIME value, but you can compare DATE and DATETIME values with each other.
The value of the built-in constant TRUE is 1. A Boolean expression such as the following example returns FALSE unless x is exactly equal to 1:
IF (x
To determine whether some value is not zero or null, avoid using TRUE in Boolean comparisons, and instead use expressions like:
IF (x) THEN ... IF (x != FALSE) THEN ...
Your code might be easier to read and might produce better results if you avoid using TRUE as an operand of the ==, =, !=, or <> operators.
5-36
Boolean Operators
Element large
Description is the name of a program variable of the BYTE or TEXT data type.
Without the NOT keyword, the comparison returns TRUE if the operand has a null value. (If you include the NOT keyword, the comparison returns TRUE if the value of the operand is not null.) Otherwise, it returns FALSE. The NULL test (like the WORDWRAP string operator with TEXT variables) is an exception to the general rule that variables of the BYTE or TEXT data type cannot appear in 4GL expressions.
Boolean Operators
Description is a single character, enclosed between a pair of single ( ' ) or double ( " ) quotation marks, to specify an escape symbol. is a character expression. The string that it returns can include literal characters, wildcards, and other symbols.
MATCHES and LIKE support different wildcards. If you use MATCHES, you
5-38
Boolean Operators
It is not valid to use backslash (nor any non-default escape character) within the brackets that specify a range for the MATCHES operator..
GLS
If an SQL statement uses the bracket notation of MATCHES to test for a range of values, and if the locale species a localized collation order, the database server sorts according to that localized order, rather than in code-set order. This sort is true even for data values from CHAR and VARCHAR columns. However, DBNLS must be set to 1 for 4GL to be able to manipulate data values from NCHAR and NVARCHAR database columns (by using CHAR and VARCHAR program variables), and for nondefault collation to be supported. The following WHERE clause tests the contents of character eld eld007 for the string ten. Here the * wildcards specify that the comparison is true if ten is found alone or in a longer string, such as often or tennis shoe:
COLOR = RED WHERE field007 MATCHES "*ten*"
If you use the keyword LIKE to compare strings, the wildcard symbols of MATCHES have no special signicance, but you can use the following wildcard characters of LIKE within the right-hand quoted string.
Symbol % _ \ Effect in LIKE Expression A percent sign matches zero or more characters. An underscore matches any single character. A backslash causes 4GL to treat the next character as a literal (so you can match % or _ by \% or \_ ).
The next example tests for the string ten in the character variable string, either alone or in a longer string:
IF string LIKE "%ten%"
The next example tests whether a substring of a character variable (or else an element of a two-dimensional array) contains an underscore symbol. The backslash is necessary because underscore is a wildcard symbol with LIKE.
IF horray[3,8] LIKE "%\_%" WHERE >> out.a
Boolean Operators
You can replace the backslash as the literal symbol. If you include an ESCAPE char clause in a LIKE or MATCHES specication, 4GL interprets the next character that follows char as a literal in the preceding character expression, even if that character corresponds to a special symbol of the LIKE or MATCHES keyword. The double quote ( " ) symbol cannot be char. For example, if you specify ESCAPE z, the characters z_ and z? in a string stand for the literal character _ and ?, rather than wildcards. Similarly, characters z% and z* stand for the characters % and *. Finally, the characters zz in the string stand for the single character z. The following expression is true if the variable company does not include the underscore character:
NOT company LIKE "%z_%" ESCAPE "z" GLS
The evaluation of logical comparisons and MATCHES, LIKE, and BETWEEN expressions containing character operands is based on the code-set order of the client locale when 4GL performs the comparison, unless a localized collation is specied. When the database server performs the comparison, sorting is based on the code-set order of the database locale, or (for data values from NVARCHAR or NCHAR columns only) on a localized collation order, if one is specied in the COLLATION category of the locale les and if the DBNLS environment variable is set to 1.
In SQL statements In the WHERE clause of the COLOR attribute in 4GL form specications In the condition column of the syscolatt table
They are not valid in 4GL statements that are not also SQL statements.
5-40
Boolean Operators
The following diagram shows the syntax for using the IN( ) operator to test for set membership.
Set Membership Test 4GL Expression p. 3-49 NOT IN (
,
4GL Expression p. 3-49
If you omit the NOT keyword, this test returns TRUE if any expression in the list (within parentheses) at the right matches the expression on the left. If you include the NOT keyword, the test evaluates as FALSE if no expression in the list matches the expression on the left. The following diagram shows the syntax for the BETWEENAND operators to test whether a value is included within a specied range (or an inclusive interval on the real line).
Range Test 4GL Expression p. 3-49 NOT BETWEEN 4GL Expression p. 3-49 AND 4GL Expression p. 3-49
Operands must return compatible data types. Values returned by the second (O2) and third (O3) operands that dene the range must follow these rules:
s s s
For number or INTERVAL values, O2 must be less than or equal to O3. For DATE and DATETIME values, O2 must be no later than O3. For character strings, O2 must be earlier than O3 in the ASCII collation sequence. (The ASCII character set is listed in Appendix A.)
GLS
In nondefault locales, the code-set order (or whatever order of sorting the COLLATION category species in the locale les) replaces the ASCII collation order. The DBNLS environment variable must also be set to 1 for 4GL to support non-code-set sorting of string values.
Boolean Operators
If you omit the NOT keyword, this test evaluates as TRUE if the rst operand has a value not less than the second operand or greater than the third. If you include the NOT keyword, the test evaluates as FALSE if the rst operand has a value outside the specied range.
The Boolean expression returns the value TRUE if the expression returns a nonzero real number or any of the following values:
A character string representing a nonzero number A nonzero INTERVAL value Any DATETIME or DATE value (except 31 December 1899) A true value returned by any Boolean function or operator The integer constant TRUE
The Boolean expression returns the value TRUE if the value is null and the expression is the operand of the IS NULL operator.
5-42
Boolean Operators
The Boolean expression returns null if the value of the expression is null and the expression appears in none of the following contexts:
An operand of the IS NULL or IS NOT NULL operator An element in a Boolean comparison (as described in Boolean Comparisons on page 5-34) An element in a conditional statement of 4GL (IF, CASE, WHILE)
Left (= x) Character Character Any simple data type Any simple data type Any simple data type Any simple data type Any simple data type Any simple data type Any Any Any Any
Right (= y) Character Character Same as x Same as x Same as x Same as x Same as x Same as x Any Same as x
Returns Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean Boolean (1 of 2)
Boolean Operators
P 4 3 2 1
Description Logical inverse Logical intersection Logical union Test whether eld edited Test for current eld
Expression NOT y
x AND y x OR y
Left (= x)
Right (= y) Boolean
Boolean Boolean
FIELD_TOUCHED( y ) INFIELD( y )
Besides the Boolean operators listed in this table, the built-in 4GL operators FIELD_TOUCHED( ) and INFIELD( ) also return Boolean values. Their precedence is lower ( P = 1) than that of the OR operator. They can use the name of a eld in the current form as their operand. Both the INFIELD( ) and FIELD_TOUCHED( ) operators are described later in this chapter.
References
FIELD_TOUCHED( ), INFIELD( )
5-44
CLIPPED
CLIPPED
The CLIPPED operator takes a character operand and returns the same character value, but without any trailing white space (such as ASCII 32).
Character Expression p. 3-69 CLIPPED
Usage
Character expressions often have a data length less than their total size. The following DISPLAY statement, for example, would produce output that included 200 trailing blanks if CLIPPED were omitted but displays only 22 characters when CLIPPED is included:
DEFINE string CHAR(222) LET string = "Two hundred characters" DISPLAY string CLIPPED
After a variable in a DISPLAY, ERROR, LET, MESSAGE, or PROMPT statement, or in a PRINT statement of a REPORT program block When concatenating several character expression into a single string When comparing two or more character expressions and one or more of them is already clipped
s s
The CLIPPED operator can affect the value of a character variable within an expression. CLIPPED does not affect the value when it is stored in a variable (unless you are concatenating CLIPPED values together). For example, if CHAR variable b contains a string that is shorter than the declared length of CHAR variable a, the following LET statement pads a with trailing blanks, despite the CLIPPED operator:
LET a = b CLIPPED
However, if CHAR variable b contains a string value no longer than the declared maximum size of VARCHAR variable v, the following statement discards any trailing blanks from what it stored in v:
LET v = b
CLIPPED
The following program fragment is from a REPORT that prints mailing labels:
FORMAT ON EVERY ROW IF (city IS NOT NULL) AND (state IS NOT NULL) THEN PRINT fname CLIPPED, 1 SPACE, lname PRINT company PRINT address1 IF (address2 IS NOT NULL) THEN PRINT address2 END IF PRINT city CLIPPED, ", " , state, 2 SPACES, zipcode SKIP TO TOP OF PAGE END IF
The following program fragment is from a report driver. Here CLIPPED is used to format the text of a MESSAGE statement that includes a lename stored in a character variable:
DEFINE file_name CHAR(60) PROMPT " Enter drive, pathname, ", "and file name for Book Report:" FOR file_name IF (file_name IS NULL) THEN LET file_name = "book.out" END IF MESSAGE "Printing Book Report to ", file_name CLIPPED, " --Please wait."
Relative to other 4GL operators, CLIPPED has a very low precedence. This can lead to confusion in some contexts, such as specifying compound Boolean conditions. For example, i4glc1 and fglpc both parse the condition:
IF LENGTH(f2) > 0 AND f2 CLIPPED != "customer" THEN
To achieve the required result, you can write the expression as:
IF LENGTH(f2) > 0 AND (f2 CLIPPED) != "customer" THEN GLS
In East Asian locales, CLIPPED can delete trailing multibyte white-space characters without creating partial characters.
Reference
USING 5-46 IBM Informix 4GL Reference Manual
COLUMN
COLUMN
COLUMN species the position in the current line of a report where output of the next value in a PRINT statement begins, or the position on the 4GL screen for the next value in a DISPLAY statement.
COLUMN left-offset
Element left-offset
Description is an integer expression (as described in Integer Expressions on page 3-63) in a report, or else a literal integer (as described in Literal Integers on page 3-65) in a DISPLAY statement, specifying where the next character of output will appear, in character positions from the left margin (of the screen, or page of report output).
Usage
Unless you use the keyword CLIPPED or USING, the PRINT statement and the DISPLAY statement (when no form is open) display 4GL variables with widths (including any sign) that depend on their declared data types.
Data Type CHAR DATE DATETIME DECIMAL FLOAT INTEGER INTERVAL MONEY SMALLFLOAT SMALLINT VARCHAR Default Display Width (in Character Positions) The length from the data type declaration 10 From 2 to 25, as implied in the data type declaration (2 + m), where m is the precision from the data type declaration 14 11 From 3 to 25, as implied in the data type declaration (3 + m), where m is the precision from the data type declaration 14 6 The maximum length from the data type declaration
COLUMN
In a REPORT program block or in A DISPLAY statement that outputs data to the 4GL screen, you can use the COLUMN operator to control precisely the location of items within a line. The COLUMN operator is often a requirement for the output of tabular information, and it is convenient for many other uses. The left-offset value species a character position offset from the left margin of the 4GL screen or the currently executing 4GL report. In a report, this value cannot be greater than the arithmetic difference (right margin - left margin) for explicit or default values in the OUTPUT section of the REPORT denition (for more information, see OUTPUT Section on page 7-12). For the syntax of 4GL expressions that return whole numbers, see Integer Expressions on page 3-63. If the printing position in the current line is already beyond the specied leftoffset, the COLUMN operator has no effect.
Output from each DISPLAY statement begins on a new line. Important: You cannot use COLUMN to send output to a screen form. Any DISPLAY statement that includes the COLUMN operator cannot also include the AT, TO, BY NAME, or ATTRIBUTE clause. When you include the COLUMN operator in a DISPLAY statement, you must specify a literal integer as the left-offset, rather than an integer expression.
5-48
COLUMN
References
ASCII, CLIPPED, SPACE, USING
Concatenation ( || ) Operator
Concatenation ( || ) Operator
The double bar ( || ) concatenation operator joins two operands of any simple data type, returning a single string.
Expression p. 3-49
||
Expression p. 3-49
Usage
The concatenation ( || ) operator joins two strings, with left-to-right associativity. For example, (a || b ||c) and ((a || b) ||c) are equivalent expressions. The precedence of || is greater than LIKE or MATCHES, but less than the arithmetic operators. Like arithmetic operators, || returns a null value (as a zero-length string) if either operand has a null value. The LET statement can use a comma ( , ) to concatenate strings, but with a different rule for null values: if one string operand is NULL, the result is the other string. For example, the comma separator in the right-hand expression list of the LET statement (LET on page 4-226) has concatenation semantics, ignoring any null values. (If all of the operands of a comma-separated list are NULL, however, LET returns a null value but represents it as a single blank space). The following left-hand and right-hand expressions are equivalent:
a || b + c "abcd " || NULL "abcd " CLIPPED || "ZZ" (a || (b + c)) NULL "abcdZZ"
Concatenation with || discards trailing white space from operands of integer and xed-point number data types, but not from character or oatingpoint data types. The CLIPPED operator can remove trailing blanks from values before concatenation in 4GL statements, but TRIM must replace CLIPPED in preparable SQL statements (for Version 7.x and later Informix databases).
References
CLIPPED, COLUMN, Substring ( [ ] ) operator 5-50 IBM Informix 4GL Reference Manual
CURRENT
CURRENT
The CURRENT operator returns the current date and time of day from the system clock as a DATETIME value of a specied or default precision.
CURRENT YEAR TO FRACTION (3) DATETIME Qualier p. 3-76
Usage
The CURRENT operator reads the date and time from the system clock. You can optionally specify the precision of the returned value by including a qualier of the form rst TO last, where rst and last are keywords from this list.
YEAR HOUR MONTH MINUTE DAY SECOND FRACTION ( n )
The rst keyword must specify a time unit that is the same as or larger than what the last keyword species. For example, the following qualier is valid:
CURRENT YEAR TO DAY
But the next qualier is not valid, because the last keyword species a time unit greater than what the rst species:
CURRENT MINUTE TO HOUR
If FRACTION is the last keyword, you can include a digit n in parentheses to specify the scale (which can range from 1 to 5 digits) of the seconds value. If no qualier is specied, the default qualier is YEAR TO FRACTION(3). If CURRENT is executed more than once in a statement, identical values might be returned at each call. Similarly, the order in which the CURRENT operator is executed in a statement cannot be predicted. For this reason, do not attempt to use this operator to mark the start or end of a 4GL statement or any specic point in the execution of a statement.
Built-In Functions and Operators 5-51
CURRENT
You can use the CURRENT operator both in SQL statements and in other 4GL statements. The following example is from an SQL statement:
SELECT prog_title FROM tv_programs WHERE air_date > CURRENT YEAR TO DAY
The last example would not produce the correct results if its execution spanned midnight.
References
DATE, EXTEND( ), TIME, TODAY
5-52
CURSOR_NAME( )
CURSOR_NAME( )
The CURSOR_NAME( ) function takes as its argument the SQL identier of an UPDATE or DELETE cursor, or the identier of a prepared statement, and returns the mangled name.
CURSOR_NAME
Usage
In versions of 4GL and ESQL/C earlier than 4.13 and 5.0, the scope of reference of the names of cursors (and of prepared statements) was restricted to the source module in which they were declared. Different .4gl source les could reference different cursors that had the same identier without conict. INFORMIX-ESQL/C 5.0 made the scope of cursor names global by default; the cursor c_query in lea.ec is the same as the cursor c_query in leb.ec. To emulate this behavior of older 4GL applications, INFORMIX-4GL p-code and C code preprocessors mangle (by default) all cursor identiers and prepared statement identiers, using the following algorithm:
sprintf(mangled_name, "I%08X_%08X", inode_number, hash_cursorname(cursor_name)); ... static unsigned long hash_cursorname(name) char *name; { unsigned long uhash = 0x14C1BC85; unsigned long g; unsigned char *s; unsigned char c; for (s = (unsigned char *)name; (c = *s) != '\0'; s++) { uhash = (uhash << 4) + (c); if ((g = uhash & 0xF0000000L) != 0) { uhash = uhash ^ (g >> 24); uhash = uhash ^ g; } } return(uhash); }
CURSOR_NAME( )
The mangled name is always 18 characters long. The rst half is derived from the inode number of the 4GL source le, and the second half, from the usersupplied name. This strategy supports backward compatibility with release version 4.12 (and earlier) 4GL applications. In most contexts, this solution is useful with the 4GL preprocessor silently substituting the mangled name wherever the identier of the cursor or the prepared statement appears. These mangled names can cause an error, however, when a prepared UPDATE or DELETE statement references a mangled name as a literal string, because the preprocessor does not perform name-mangling within a quoted string. (Similarly, name-mangling is not performed within delimited SQL statement blocks, nor within the text of prepared statements.) The CURSOR_NAME( ) function is helpful in situations where name-mangling of cursors causes failure of prepared UPDATE or DELETE statements that have the WHERE CURRENT OF clause. The problem occurs in contexts like this:
DECLARE c_name CURSOR FOR SELECT ... FOR UPDATE PREPARE p_update FROM "UPDATE SomeTable SET SomeColumn = ? WHERE CURRENT OF c_name"
Here the cursor name, c_name, is mangled into I01234567_87654321 (or something similar), but the name embedded in the UPDATE statement is not mangled. This code example leads to a -507 error when the p_update statement is executed. CURSOR_NAME( ) provides a solution to this problem by mangling the name before it is embedded in the quoted string. For example:
DECLARE c_name CURSOR FOR SELECT ... FOR UPDATE LET s = "UPDATE SomeTable SET SomeColumn = ? WHERE CURRENT OF ", CURSOR_NAME("c_name") PREPARE p_update FROM s
The name-mangling code uses, and therefore needs to know, the inode number of the source le at the time it is compiled. The fglpc and i4glc1 compilers arrange for the inode number to be pushed onto the 4GL stack before the C function is called. This is invisible to the 4GL programmer.
5-54
CURSOR_NAME( )
The -globcurs compilation option makes the scope of reference of cursors global and disables name-mangling. The compilers require you to declare the cursor before using it for any other purpose in the module, however, so this option is seldom useful. It might help in debugging, however, because the cursor names are not modied. You can also use -globcurs with fglpc. Although the CURSOR_NAME( ) function is of no use to the C programmer, it must be called with two arguments on the 4GL stack; in C programs, the two arguments are the inode number and the identier that is to be mangled.
DATE
DATE
The DATE operator converts its CHAR, VARCHAR, DATETIME, or integer operand to a DATE value. If you supply no operand, it returns a character representation of the current date.
DATE
Usage
The DATE operator can convert values of other data types to DATE values and can return the current date as a character string. When used with no operand, the DATE operator reads the system clockcalendar and returns the current date as a string in the following format:
weekday month day year
Description is a three-character abbreviation of the name of the day of the week. is a three-character abbreviation of the name of the month. is a two-digit representation of the day of the month. is a four-digit representation of the year.
The following example uses the DATE operator to display the current date:
DEFINE p_date CHAR(15) LET p_date = DATE . . . DISPLAY "Today is ", p_date AT 5,14
5-56
DATE
The effect of the DATE operator is sensitive to the time of execution and to the accuracy of the system clock. An alternative way to format a DATE value as a character string is to use the FORMAT eld attribute in a screen form (as described in FORMAT on page 6-50), or to use the USING operator (as described in Formatting DATE Values on page 5-127).
GLS
4GL can display language-specic month-name and day-name abbreviations, if the DBLANG environment variable references appropriate les in the $INFORMIXDIR/msg le system. For information, see Appendix E, Devel-
The DATE operator can also perform data type conversion of a character, integer, or DATETIME operand to a DATE value, equivalent to a count of days since the beginning of the last year of the 19th century:
s
Converting a properly formatted character string representation of a numeric date to a DATE value. For details, see Numeric Date on page 3-75. (The default format is mm/dd/yy, but the DBDATE or GL_DATE environment variable can change this default.) Converting a DATETIME value to a negative or positive integer. The returned integer corresponds to the number of days between the specied date and December 31, 1899. Obtaining a DATE value from a negative or positive integer that species the number of days between the specied date and December 31, 1899.
References
CURRENT, DATE, DAY, MDY( ), MONTH, TIME, UNITS, WEEKDAY, YEAR Built-In Functions and Operators 5-57
DAY( )
DAY( )
The DAY( ) operator returns a positive integer, corresponding to the day portion of the value of its DATE or DATETIME operand.
DAY
Usage
The DAY( ) operator can extract an integer value for the day of the month from a DATETIME or DATE operand. This feature is helpful in some applications because INTEGER values are easier than DATETIME or DATE values to manipulate with arithmetic operators. The following program fragment extracts the day of the month from a DATETIME literal:
DEFINE d_var INTEGER, date_var DATETIME YEAR TO SECOND LET date_var = DATETIME (89-12-09 18:47:32) YEAR TO SECOND LET d_var = DAY(date_var) DISPLAY "The day of the month is: ", d_var USING "##"
References
CURRENT, DATE, MONTH( ), TIME, TODAY, WEEKDAY( ), YEAR( )
5-58
DOWNSHIFT( )
DOWNSHIFT( )
The DOWNSHIFT( ) function returns a string value in which all uppercase characters in its argument are converted to lowercase.
DOWNSHIFT
Usage
The DOWNSHIFT( ) function is typically called to regularize character data. You might use it, for example, to prevent the state abbreviation entered as TX, Tx, or tx from resulting in different values, if these were logically equivalent in the context of your application. Non-alphabetic or lowercase characters are not altered by DOWNSHIFT( ). The maximum data length of the argument (and of the returned character string value) is 32,766 bytes. You can use the DOWNSHIFT( ) function in an expression (where such usage is allowed), or you can assign the value returned by the function to a variable. In the following example, suppose that the CHAR value GEAR_4 is stored in the program variable p_string. The following statement takes the value of the expression DOWNSHIFT(p_string), namely gear_4, and assigns it to another CHAR variable called d_str:
LET d_str = DOWNSHIFT(p_string)
For more information, see the DOWNSHIFT eld attribute in Chapter 6, Screen Forms.
GLS
The results of conversion between uppercase and lowercase letters are based on the locale les, which identify the relationship between corresponding pairs of uppercase and lowercase letters. If the locale les do not provide this information, no case conversion occurs. DOWNSHIFT( ) has no effect on nonEnglish characters in most multibyte locales.
DOWNSHIFT( )
Reference
UPSHIFT( )
5-60
ERR_GET( )
ERR_GET( )
The ERR_GET( ) function returns a character string containing the text of the 4GL or SQL error message whose numeric code you specify as its argument.
ERR_GET
Usage
This is a possible sequence of steps for logging system error messages:
1. 2. 3. 4.
Call STARTLOG( ) to open or create an error log le (as described in STARTLOG( ) on page 5-110). Test the value of the global status variable to see if it is less than zero. If status is negative, call ERR_GET( ) to retrieve the error text. Call ERRORLOG( ) to make an entry into the error log le (as described in ERRORLOG( ) on page 5-65).
The STARTLOG( ) function (step 1) automatically records the error text in the default error record, so the last three steps are not needed. ERR_GET( ) is most useful when you are developing a program. The message that it returns is probably not helpful to the user of your 4GL application. The argument of ERR_GET( ) is typically the value of the status variable, which is affected by both SQL and 4GL errors, or else a member of the global SQLCA.SQLCODE record. See Exception Handling on page 2-40. The LET statement in the following program fragment assigns the text of a 4GL error message to errtext, a CHAR variable:
LET op_status = STATUS IF op_status < 0 THEN LET errtext = ERR_GET(op_status) END IF
Here the value of status is rst assigned to a variable, op_status, rather than testing ERR_GET(status) directly. Otherwise, the value of status normally would be zero, reecting the success of the ERR_GET(status) function call.
ERR_GET( )
References
ERR_PRINT( ), ERR_QUIT( ), ERRORLOG( ), STARTLOG( )
5-62
ERR_PRINT( )
ERR_PRINT( )
The ERR_PRINT( ) function displays on the Error line the text of an SQL or 4GL error message, corresponding to a negative integer argument.
CALL ERR_PRINT
Usage
The argument of ERR_PRINT( ) species an error message number, which must be less than zero. It is typically the value of the global status variable, which is affected by both SQL and 4GL errors. For SQL errors only, you can examine the global SQLCA.SQLCODE record. For information on both SQLCA.SQLCODE and status, see Error Handling with SQLCA on page 2-45.
ERR_PRINT( ) is most useful when you are developing a 4GL program. The message that it returns is probably not helpful to the user of your application.
The following program segment sends any error message to the Error line:
LET op_status = STATUS IF op_status < 0 THEN CALL ERR_PRINT(op_status) END IF
Here the value of status is rst assigned to a variable, op_status, rather than calling ERR_PRINT(status) directly. Otherwise, the value of status normally would be zero, reecting the success of the ERR_PRINT(status) function call. If you specify the WHENEVER ANY ERROR CONTINUE compiler directive (or the equivalent, the anyerr command-line ag), status is reset after certain additional 4GL statements, as described in The ANY ERROR Condition on page 4-378. For information about trapping errors, see Exception Handling on page 2-40.
References
ERR_GET( ), ERR_QUIT( ), ERRORLOG( ), STARTLOG( ) Built-In Functions and Operators 5-63
ERR_QUIT( )
ERR_QUIT( )
The ERR_QUIT( ) function displays on the Error line the text of an SQL or 4GL error message, corresponding to the error code specied by its negative integer argument, and terminates the program.
CALL ERR_QUIT
Usage
The argument of ERR_QUIT( ) species an error message number, which must be less than zero. It is typically the value of the global status variable, which is reset by both SQL and 4GL errors. For SQL errors only, you can examine the global SQLCA.SQLCODE record. Both SQLCA.SQLCODE and status are described in Error Handling with SQLCA on page 2-45. The ERR_QUIT( ) function is identical to the ERR_PRINT( ) function, except that ERR_QUIT( ) terminates execution once the message is printed. ERR_QUIT( ) is primarily useful when you are developing a 4GL program. The message that it returns is probably not helpful to the user of your application. If an error occurs, the following statements display the error message on the Error line, and terminate program execution:
IF STATUS < 0 THEN CALL ERR_QUIT(STATUS) END IF
If you specify the WHENEVER ANY ERROR CONTINUE compiler directive (or the equivalent, the anyerr command-line ag), status is reset after certain additional 4GL statements, as described in The ANY ERROR Condition on page 4-378. For information about trapping errors, see Exception Handling on page 2-40.
References
ERR_GET( ), ERR_PRINT( ), ERRORLOG( ), STARTLOG( )
5-64
ERRORLOG( )
ERRORLOG( )
The ERRORLOG( ) function copies its argument into the current error log le.
CALL ERRORLOG
Usage
If you simply invoke the STARTLOG( ) function, error records that 4GL appends to the error log after each subsequent error have this format:
Date: 07/06/99 Time: 12:20:20 Program error at "stock_one.4gl", line number 89. SQL statement error number -239. Could not insert new row - duplicate value in a UNIQUE INDEX column. SYSTEM error number -100 ISAM error: duplicate value for a record with unique key.
The actual record might be incomplete if after an error the operating system fails to preserve the buffer that contains the module name or the line number. You can use the ERRORLOG( ) function to supplement default error records with additional information. Entries that ERRORLOG( ) makes in the error log le automatically include the date and time when the error was recorded. This is a typical sequence of steps for logging system error messages:
1. 2. 3. 4.
Call STARTLOG( ) to open or create an error log le (as described in STARTLOG( ) on page 5-110). Test the value of the global status variable to see if it is negative. If status < 0, call ERR_GET( ) to retrieve the error text (as described in ERRORLOG( ) on page 5-65). Call ERRORLOG( ) to make an entry into the error log le.
Unless you specify some other action for error conditions, WHENEVER ERROR CONTINUE is in effect by default. This default prevents the rst SQL error from terminating program execution.
ERRORLOG( )
You can use the ERRORLOG( ) function to identify errors in programs that you are developing and to customize error handling. Even after implementation, some errors, such as those relating to permissions and locking, are sometimes unavoidable. These errors can be trapped and recorded by these logging functions. You can use error-logging functions with other 4GL features for instrumenting a program, by tracking the way the program is used. This functionality is not only valuable for improving the program but also for recording work habits and detecting attempts to breach security. See INFORMIX-4GL by Example for a detailed example of a program with this functionality. The following program fragment calls STARTLOG( ) in the MAIN program block. Here the ERRORLOG( ) function has a quoted string argument:
CALL STARTLOG("\\usr\\catherine\\error.log") ... FUNCTION start_menu() CALL ERRORLOG("Entering start_menu function")
The following example illustrates the use of ERR_GET( ) and ERRORLOG( ). It assumes that an error log le has already been created or initialized by calling the built-in STARTLOG( ) function:
FUNCTION add_cust() DEFINE errvar CHAR(80) WHENEVER ERROR CONTINUE INPUT BY NAME gr_customer.* INSERT INTO customer VALUES (gr_customer.*) IF STATUS < 0 THEN LET errvar = ERR_GET(STATUS) CALL ERRORLOG(errvar CLIPPED) END IF END FUNCTION
If its argument is not of a character data type (for example, a DECIMAL variable), invoking ERRORLOG( ) can itself produce an error. Automatic error logging increases the size of the generated executable.
References
ERR_GET( ), ERR_PRINT( ), ERR_QUIT( ), STARTLOG( )
5-66
EXTEND( )
EXTEND( )
The EXTEND( ) operator converts its DATETIME or DATE operand to a DATETIME value of a specied (or default) precision and scale.
EXTEND
) ,
DATETIME Qualier p. 3-76 YEAR TO DAY
Usage
The EXTEND( ) operator returns the value of its DATE or DATETIME operand, but with an adjusted precision that you can specify by a DATETIME qualier. The operand can be a DATE or DATETIME expression of any valid precision. If it is a character string, it must consist of valid and unambiguous time-unit values and separators, but with these restrictions:
s s
It cannot be a character string in DATE format, such as "12/12/99". It cannot be an ambiguous numeric DATETIME value, such as "05:06" or "05" whose time units are ambiguous. It cannot be a time expression that returns an INTERVAL value.
DATETIME Qualiers
A qualier can specify the precision of the result (and the scale, if FRACTION is the last keyword in the qualier). The qualier follows a comma and is of the form rst TO last, where rst and last are keywords to specify (respectively) the largest and smallest time unit in the result. Both can be the same. If no qualier is specied, the following defaults are in effect, based on the explicit or default precision of the DATE or DATETIME operand:
s
The default qualier that EXTEND( ) applies to a DATETIME operand is YEAR TO FRACTION(3). The default qualier for a DATE operand is YEAR TO DAY.
Built-In Functions and Operators 5-67
EXTEND( )
See also DATETIME Qualier on page 3-76. The following rules are in effect for DATETIME qualiers that you specify as EXTEND( ) operands:
s
If a rst TO last qualier is specied, the rst keyword must specify a time unit that is larger than (or the same as) the time unit that the last keyword species. If rst species a time unit larger than any in the operand, omitted time units are lled with values from the system clock-calendar. In the following fragment, the rst keyword species a time unit larger than any in t_stamp, so the value of the current year would be used:
DEFINE t_stamp DATETIME MONTH TO DAY DEFINE annual DATETIME YEAR TO MINUTE ... LET t_stamp = "1993-12-04 17" LET annual = EXTEND(t_stamp, YEAR TO MINUTE)
If last species a smaller time unit than any in the operand, the missing time units are assigned values according to these rules:
A missing MONTH or DAY is lled in with the value one ( 01 ). Any missing HOUR, MINUTE, SECOND, or FRACTION is lled in with the value zero ( 00 ).
If the operand contains time units outside the precision specied by the qualier, the unspecied time units are discarded. For example, if you specify rst TO last as DAY TO HOUR, any information about MONTH in the DATETIME operand is not used in the result.
5-68
EXTEND( )
Here the EXTEND( ) operator returns a DATETIME value whose precision is expanded from YEAR TO DAY to YEAR TO MINUTE. This adjustment allows 4GL to evaluate the arithmetic expression. The result of the subtraction has the extended precision of YEAR TO MINUTE from the rst operand. In the next example, fragments of a report denition use DATE values as operands in expressions that return DATETIME values. Output from these PRINT statements would in fact be the numeric date and time (as described in DATETIME Literal on page 3-78) without the DATETIME keywords and qualiers that are included here to show the precision of the values that the arithmetic expressions return.
DEFINE calendar DATE LET calendar = "05/18/1999" PRINT (calendar - INTERVAL (5-5) YEAR TO MONTH) --result: DATETIME (1993-12-18) YEAR TO DAY PRINT (EXTEND(calendar, YEAR TO HOUR) - INTERVAL (4 8) DAY TO HOUR) --result: DATETIME (1999-05-13 16) YEAR TO HOUR
You cannot directly combine a DATE with an INTERVAL value whose last qualier is smaller than DAY. But as the previous example shows, you can use the EXTEND( ) operator to convert the value in a DATE column or variable to a DATETIME value that includes all the elds of the INTERVAL operand. In the next example, the INTERVAL variable how_old includes elds that are not present in the DATETIME variable t_stamp, so the EXTEND( ) operator is required in the expression that calculates the sum of their values.
DEFINE t_stamp DATETIME YEAR TO HOUR DEFINE age DATETIME DAY TO MINUTE DEFINE how_old INTERVAL DAY TO MINUTE LET t_stamp = "1989-12-04 17" LET how_old = INTERVAL (28 9:25) DAY TO MINUTE LET age = EXTEND(t_stamp, DAY TO MINUTE) + how_old
SQL statements can include a similar EXTEND( ) operator of SQL, whose rst argument can be the name of a DATETIME or DATE database column.
Reference
UNITS
FGL_DRAWBOX( )
FGL_DRAWBOX( )
The FGL_DRAWBOX( ) function displays a rectangle of a specied size.
FGL_DRAWBOX
height
Element color
Description is an integer expression (as described in Integer Expressions on page 3-63) that returns a positive whole number, specifying a foreground color code. is an integer expression, specifying the number of screen lines occupied by the rectangle. is an integer expression, specifying the horizontal coordinate (in characters) of the upper-left corner of the rectangle, where 1 is the rst (or left-most) character in a line of the current 4GL window. is an integer expression, specifying the vertical coordinate of the upperleft corner, where 1 means the rst (or top-most) line. is an integer expression, specifying the number of character positions occupied by each line of the rectangle.
height left-offset
line width
5-70
FGL_DRAWBOX( )
Usage
The FGL_DRAWBOX( ) function draws a rectangle with the upper-left corner at (line, left-offset) and the specied height and width. These dimensions must have positive integer values, in units of lines and character positions, where (0,0) is the upper-left corner of the current 4GL window. The optional color number must correspond to one of the following foreground colors.
Color Number 0 1 2 3 Foreground Color WHITE YELLOW MAGENTA RED Color Number 4 5 6 7 Foreground Color CYAN GREEN BLUE BLACK
The upscol utility can specify these same color options in the syscolatt table. The default color is used when the color number is omitted. The color argument is optional. As is the case with borders, the width of the line that draws the rectangle is xed. This xed width cannot be specied or modied when you invoke FGL_DRAWBOX( ). Also as with borders, 4GL draws the box with the characters dened in the termcap or terminfo les. You can specify alternative characters in these les. Otherwise, 4GL uses hyphens to create horizontal lines, pipe symbols (|) for vertical lines, and plus signs at the corners. To assign the box a color, you must use termcap because terminfo does not support color. For complete information on termcap and terminfo, see Appendix F, Modifying termcap and terminfo. Rectangles drawn by FGL_DRAWBOX( ) are part of a displayed form. Each time that you execute the corresponding DISPLAY FORM or OPEN WINDOW ... WITH FORM statement, you must also redraw the rectangle. If you invoke FGL_DRAWBOX( ) several times to create a display in which rectangles intersect, output from the most recent function call overlies any previously drawn rectangles. Screen elds and reserved lines, however, have a higher display priority than FGL_DRAWBOX( ) rectangles, regardless of the order in which the elds, lines, and rectangles are drawn.
Built-In Functions and Operators 5-71
FGL_DRAWBOX( )
Important: In most applications, avoid drawing rectangles that intersect or overlap any eld or reserved line. Reserved lines might be redrawn frequently during user interaction statements, partially erasing any rectangles at the intersections where they overlap the reserved lines. To avoid this problem, position the rectangles so they do not overlap any reserved lines or screen elds. For more information, see Reserved Lines on page 4-114.
5-72
FGL_GETENV( )
FGL_GETENV( )
The FGL_GETENV( ) function returns a character string, corresponding to the value of an environment variable whose name you specify as the argument.
FGL_GETENV
Usage
The argument of FGL_GETENV( ) must be a character expression that returns the name of an environment variable. To evaluate a call to FGL_GETENV( ), 4GL takes the following actions at runtime:
1. 2.
Evaluates the character expression argument of FGL_GETENV( ) Searches among environment variables for the returned value
If the requested value exists, the function returns it as a character string and then returns control of execution to the calling context. The identier of an environment variable is not a 4GL expression, so you typically specify the argument as a quoted string or character variable. For example, this call evaluates the DBFORMAT environment variable:
fgl_getenv("DBFORMAT")
You can assign the name of the environment variable to a character variable and use that variable as the function argument. If you declare a CHAR or VARCHAR variable called env_var and assign to it the name of an environment variable, a FGL_GETENV( ) function call could look like this:
fgl_getenv(env_var)
If the argument is a character variable, be sure to declare it with sufcient size to store the character value returned by the FGL_GETENV( ) function. Otherwise, 4GL truncates the returned value. If the specied environment variable is not dened, FGL_GETENV( ) returns a NULL value. If the environment variable is dened but does not have a value assigned to it, FGL_GETENV( ) returns blank spaces.
Built-In Functions and Operators 5-73
FGL_GETENV( )
You can use the FGL_GETENV( ) function anywhere within a 4GL program to examine the value of an environment variable. The following program segment displays the value of the INFORMIXDIR environment variable. The environment variable is identied in the FGL_GETENV( ) call by enclosing the name INFORMIXDIR between quotation marks:
DEFINE path CHAR(64) ... LET path = fgl_getenv("INFORMIXDIR") DISPLAY "Informix installed in ", path CLIPPED
The next example also displays the value of the INFORMIXDIR environment variable. In this case, the environment variable is identied by the env_var character variable, and its contents are stored in a variable called path:
DEFINE env_var CHAR(25), path CHAR(64) ... LET env_var = "INFORMIXDIR" LET path = fgl_getenv(env_var) DISPLAY "Informix installed in ", path CLIPPED
The following example examines the environment to see if the DBANSIWARN environment variable is currently set:
DEFINE dbansi_flag SMALLINT ... IF (fgl_getenv("DBANSIWARN") IS NOT NULL) THEN LET dbansi_flag = 1 END IF GLS
In nondefault locales, FGL_GETENV( ) can return values that include nonASCII characters that the code set of the locale supports. In multibyte locales, the returned value can include multibyte characters.
References
For environment variables that control features of the database, see the Informix Guide to SQL: Reference. For descriptions of environment variables that can affect the visual displays of 4GL programs, see Appendix D, Environment Variables.
5-74
FGL_GETKEY( )
FGL_GETKEY( )
The function FGL_GETKEY( ) waits for a key to be pressed and returns the integer code of the physical key that the user pressed.
FGL_GETKEY
( )
Usage
Unlike FGL_LASTKEY( ), which can return a value indicating the logical effect of whatever key the user pressed, FGL_GETKEY( ) returns an integer representing the raw value of the physical key that the user pressed. The FGL_GETKEY( ) function recognizes the same codes for keys that the FGL_KEYVAL( ) function returns. Unlike FGL_KEYVAL( ) , which can only return keystrokes that are entered in 4GL forms, FGL_GETKEY( ) can be invoked in any context where the user is providing keyboard entry.
GLS
Single-byte non-ASCII characters from the code set of the locale can also be returned. Here is an example of a program fragment that calls both functions, so that FGL_KEYVAL( ) evaluates what FGL_GETKEY( ) returns.
DEFINE key INT PROMPT "Press the RETURN key to continue. " || "Press any other key to quit." LET key = FGL_GETKEY( ) IF key = FGL_KEYVAL("return") THEN CALL continue() ELSE CALL quit() END IF
Important: Here the term key refers to a physical element of the keyboard or to its logical effect rather than to the SQL construct of the same name.
References
ASCII, FGL_KEYVAL( ), FGL_LASTKEY( ), ORD( )
FGL_KEYVAL( )
FGL_KEYVAL( )
Function FGL_KEYVAL( ) returns the integer code of a logical or physical key.
FGL_KEYVAL
Usage
The FGL_KEYVAL( ) function returns NULL unless its argument species one of the following physical or logical keys:
s s s
A single letter or a digit Non-alphanumeric symbols (such as !, @, and #) Any of the keywords in the following table (in uppercase or lowercase letters)
RETURN RIGHT TAB UP
ACCEPT HELP NEXT or DELETE INSERT NEXTPAGE DOWN INTERRUPT PREVIOUS or ESC or ESCAPE LEFT PREVPAGE F1 through F64 CONTROL-character (except A, D, H, I, J, L, M, R, or X
GLS
Single-byte non-ASCII characters from the code set of the locale can also be returned. Enclose the argument in quotation marks. If you specify a single letter, FGL_KEYVAL( ) considers the case. In all other instances, FGL_KEYVAL( ) ignores the case of its argument, which can be uppercase or lowercase letters. If the argument is invalid, FGL_KEYVAL( ) returns NULL. Important: Here the term key refers to a physical element of the keyboard or to its logical effect rather than to the SQL construct of the same name.
5-76
FGL_KEYVAL( )
returned by the FGL_GETKEY( ) or FGL_LASTKEY( ) function. By comparing the values returned by FGL_KEYVAL( ) with what FGL_GETKEY( ) or FGL_LASTKEY( ) returns, you can determine whether the last key that the user pressed was a specied logical or physical key. Typically, you use the FGL_KEYVAL( ) function in conditional statements and Boolean comparisons:
DEFINE key_var INTEGER ... INPUT BY NAME p_customer.fname THRU p_customer.phone ... AFTER FIELD phone IF FGL_LASTKEY() = FGL_KEYVAL("f1") THEN ... END IF END INPUT
This example displays a message and moves the cursor to the manu_code eld if the user presses the UP ARROW key to leave the stock_num eld:
CONSTRUCT query_1 ON stock.* FROM s_stock.* ... AFTER FIELD stock_num IF FGL_LASTKEY() = FGL_KEYVAL("up") THEN DISPLAY "You cannot move up from here." NEXT FIELD manu_code END IF ... END CONSTRUCT
To determine whether the user performed some action, such as inserting a row, specify the logical name of the action (such as INSERT) rather than the name of the physical key (such as F1). For example, the logical name of the default Accept key is ESCAPE. To test if the key most recently pressed by the user was the Accept key, specify FGL_KEYVAL("ACCEPT") rather than FGL_KEYVAL("escape") or FGL_KEYVAL("ESC"). Otherwise, if a key other than ESCAPE is set as the Accept key and the user presses that key, FGL_LASTKEY( ) does not return a code equal to FGL_KEYVAL("ESCAPE"). The value returned by FGL_LASTKEY( ) is undened in a MENU statement.
References
ASCII, FGL_GETKEY( ), FGL_LASTKEY( ), ORD( )
FGL_LASTKEY( )
FGL_LASTKEY( )
The FGL_LASTKEY( ) function returns an INTEGER code, corresponding to the logical key that the user most recently typed in a eld of a screen form.
FGL_LASTKEY
( )
Usage
The FGL_LASTKEY( ) function returns a numeric code for the users last keystroke before FGL_LASTKEY( ) was called. For example, if the last key that the user entered was the lowercase s, the FGL_LASTKEY( ) function returns 115. Appendix A lists the numeric codes for all the ASCII characters. The value returned by FGL_LASTKEY( ) is undened in a MENU statement. Important: Here the term key refers to a physical element of the keyboard of a terminal or to its logical effect rather than to the SQL construct of the same name.
5-78
FGL_LASTKEY( )
The following CONSTRUCT statement checks the value of the last key that the user entered in each eld. If the user last pressed RETURN, the program displays a message in the Error line:
CONSTRUCT query_1 ON stock.* FROM s_stock.* BEFORE CONSTRUCT DISPLAY "Use the TAB key to move ", "between the fields." AT 1,1 AFTER FIELD stock_num, manu_code, description, unit_price, unit, unit_descr IF FGL_LASTKEY() = FGL_KEYVAL("return") THEN ERROR "Use the TAB key to move the cursor ", "between the fields." END IF END CONSTRUCT
Here (as in ON KEY clauses), RETURN is a synonym for ENTER. The following example demonstrates using the FGL_LASTKEY( ) function after a PROMPT statement that expects the user to respond to the prompt with a single keystroke. The FGL_LASTKEY( ) function returns the code of the key the user pressed to the program. The FGL_LASTKEY( ) function compares the code with the code for the RETURN key. If an exact match occurs, 4GL calls the continue( ) function. If a match does not occur because the user pressed a key other than RETURN, 4GL calls the quit( ) function:
DEFINE value CHAR, key INTEGER PROMPT "Press the RETURN key to continue. ", "Press any other key to quit." FOR CHAR value LET key = FGL_LASTKEY() IF key = FGL_LASTKEY("return") THEN CALL continue() ELSE CALL quit() END IF
AUTONEXT Fields
If FGL_LASTKEY( ) is invoked after the user enters a value in a eld with the AUTONEXT attribute, 4GL returns the code of the last key that the user entered, regardless of any processing done in the AFTER FIELD or BEFORE FIELD clause. For more information, see AUTONEXT on page 6-34.
FGL_LASTKEY( )
References
ASCII, FGL_GETKEY( ), FGL_KEYVAL( ), ORD( )
5-80
FGL_SCR_SIZE( )
FGL_SCR_SIZE( )
The function FGL_SCR_SIZE( ) accepts as its argument the name of a screen array in the currently opened form and returns an integer that corresponds to the number of screen records in that screen array.
FGL_SCR_SIZE
"array "
variable
Description is the identier (between quotation marks) of a screen array from the INSTRUCTIONS section of the specication of the current form. is a CHAR or VARCHAR variable containing the array identier.
Usage
The built-in FGL_SCR_SIZE( ) function returns the declared size of a specied screen array at runtime. In the following example, a form specication le (called le.per) declares two screen arrays, called s_rec1 and s_rec2:
DATABASE FORMONLY SCREEN { [f1 [f1 [f1 [f3 [f3 [f5 }
] ] ] ] ] ]
] ] ] ] ]
; ; ; ; ;
FGL_SCR_SIZE( )
INSTRUCTIONS DELIMITERS "" SCREEN RECORD s_rec1[3] (a,b) SCREEN RECORD s_rec2 (c,d)
The proper value is returned even though the array dimension is not specied in the form le. An error is returned if no form is open or if the specied array is not in the current open form.
References
ARR_CURR( ), ARR_COUNT( )
5-82
FGL_SETCURRLINE ( )
FGL_SETCURRLINE ( )
During the INPUT ARRAY or DISPLAY ARRAY statement the FGL_SETCURRLINE( ) function positions the cursor at a specied program record within the program array that is displayed in the current screen array, and displays that record.
FGL_SETCURRLINE( num )
Element num
Description is a literal integer, specifying the ordinal number of a program record within the program array that was specied in the current INPUT ARRAY or DISPLAY ARRAY statement.
Usage
The current line of a screen array is the line that displays the screen cursor at the beginning of a BEFORE ROW or AFTER ROW clause. The integer argument of the FGL_SETCURRLINE( ) function species which program record to display in the current screen array, and moves the cursor to that line. . The rst row of the program array is numbered 1. Error -4669 is issued if you attempt to call the FGL_SETCURRLINE( ) function outside a statement block of the DISPLAY ARRAY or INPUT ARRAY statement.
References
ARR_CURR( ), SCR_LINE( ), SET_COUNT( )
FIELD_TOUCHED( )
FIELD_TOUCHED( )
The FIELD_TOUCHED( ) operator tests whether the user has entered or edited a value in a specied eld or list of elds of the current 4GL form. (This operator can only appear within CONSTRUCT, INPUT, and INPUT ARRAY statements.) ,
FIELD_TOUCHED Field Clause (subset) eld table reference screen array screen record
Description is the name of a screen eld (from the ATTRIBUTES section). is the name of a screen array (from the INSTRUCTIONS section). is the name of a screen record (from the INSTRUCTIONS section of the form specication). is a table name, alias, synonym, or FORMONLY keyword (from the TABLES section of the form specication).
Usage
FIELD_TOUCHED( ) returns the Boolean value TRUE (meaning that the user changed the contents of a eld) after a DISPLAY statement displays data in
any of the specied elds or after the user presses any of the following keys:
s s s
5-84
FIELD_TOUCHED( )
After any of these keystrokes, the FIELD_TOUCHED( ) operator returns TRUE, regardless of whether the keystroke actually changed the value in the eld. (The locale les classify each character as printable or unprintable.) Otherwise, the FIELD_TOUCHED( ) operator returns FALSE, indicating that none of the specied elds have been edited. Moving through a eld (by pressing RETURN, TAB, or the arrow keys) does not mark a eld as touched. Important: FIELD_TOUCHED( ) is valid only in CONSTRUCT, INPUT, and INPUT ARRAY statements. When you use it, 4GL assumes that you are referring to the current screen record rather than to a different row of the screen array. This operator does not register the effect of 4GL statements that appear in a BEFORE CONSTRUCT or BEFORE INPUT clause. You can assign values to elds in these clauses without marking the elds as touched. In the following program fragment, an IF statement tests whether the user has entered a value into any eld. If no eld has been touched, the program prompts the user to indicate whether to retrieve all customer records. If the user types N or n, the CONTINUE CONSTRUCT statement is executed, and the screen cursor is positioned in the form, giving the user another opportunity to enter selection criteria. If the user types any other key, the program terminates the IF statement and reaches the END CONSTRUCT keywords.
CONSTRUCT BY NAME query1 ON customer.* ... AFTER CONSTRUCT IF NOT FIELD_TOUCHED(customer.*) THEN PROMPT "Do you really want to see ", "all customer rows? (y/n)" FOR CHAR answer IF answer MATCHES "[Nn]" THEN CONTINUE CONSTRUCT END IF END IF END CONSTRUCT
This strategy is not as dependable as testing whether query1 = " 1=1" after the END CONSTRUCT keywords because the user might have left all the elds blank after rst entering and then deleting query criteria in some eld. In that case, the resulting Boolean expression (" 1=1") can retrieve all rows, but FIELD_TOUCHED( ) returns TRUE, and the PROMPT statement is not executed. For additional information, see Searching for All Rows on page 4-60.
FIELD_TOUCHED( )
References
Boolean Operators, FGL_GETKEY, FGL_KEYVAL( ), FGL_LASTKEY( ),
GET_FLDBUF( ), INFIELD( )
5-86
GET_FLDBUF( )
GET_FLDBUF( )
The GET_FLDBUF( ) operator returns the character values of the contents of one or more elds in the currently active screen form. (This operator can only appear within the CONSTRUCT, INPUT, and INPUT ARRAY statements of 4GL.)
Case I: (single eld)
GET_FLDBUF
(
table-reference screen-record screen-array
eld )
,
Field Clause (subset) p. 5-84
, ) RETURNING
variable program record . *
Description is the name of a eld in the current screen form. is the name of a program record of CHAR or VARCHAR variables in which to store values from the specied elds. is the name of a screen array that was dened in the INSTRUCTIONS section of the form specication le. is the name of a screen record that is explicitly or implicitly dened in the form specication le. is the unqualied name, alias, or synonym of a database table or view, or else the keyword FORMONLY. is a name within a list of one or more character variables, separated by commas. Variables must correspond in number and position with the list of elds in the eld clause.
GET_FLDBUF( )
Usage
GET_FLDBUF( ) operates on a list of one or more elds. For example, this LET
statement assigns the value in the lname eld to the lbuff variable:
LET lbuff = GET_FLDBUF(lname)
To specify a list of several eld names as operands of GET_FLDBUF( ), you must use the CALL statement with the RETURNING clause. Insert commas to separate successive eld names and successive variables:
CALL GET_FLDBUF(c_num, company, lname) RETURNING p_cnum, p_company, p_lname
The following statement returns a set of character values corresponding to the contents of the s_customer screen record and assigns these values to the p_customer program record:
CALL GET_FLDBUF(s_customer.*) RETURNING p_customer.*
(The rst asterisk ( * ) species all the elds in the s_customer screen-record; the second species all the members of the p_customer program record.) You can use the GET_FLDBUF( ) operator to assist a user when entering a value in a eld. For example, if you have an input eld for last names, you can include an ON KEY clause that lets a user enter the rst few characters of the desired last name. If the user calls the ON KEY clause, 4GL displays a list of last names that begin with the characters entered. The user can then choose a last name from the list. The following program fragment demonstrates this use of the GET_FLDBUF( ) operator:
DEFINE lname, myquery, partial_name CHAR(20), tw ARRAY[10] OF CHAR(20), a INTEGER ... INPUT BY NAME lname ON KEY (CONTROL-P) LET partial_name = GET_FLDBUF(lname) LET myquery = "SELECT lname FROM teltab ", "WHERE lname MATCHES \"", partial_name CLIPPED, "*\"" OPEN WINDOW w1 AT 5,5 WITH FORM "tel_form" ATTRIBUTE (BORDER) DISPLAY partial_name AT 1,1 PREPARE mysubquery FROM myquery DECLARE q1 CURSOR FOR mysubquery LET a = 0 FOREACH q1 INTO lname LET a = a + 1 ... END FOREACH DISPLAY a TO ncount
5-88
GET_FLDBUF( )
IF (a = 0) THEN PROMPT "Nothing beginning with these letters" FOR CHAR partial_name ELSE IF (a > 10) THEN LET a = 10 END IF CALL SET_COUNT(a) DISPLAY ARRAY tw TO srec.* END IF ... END INPUT
If you assign the character string returned by the GET_FLDBUF( ) operator to a variable that is not dened as a character data type, 4GL tries to convert the string to the appropriate data type. Conversion is not possible in these cases:
s
The eld contains special characters (for example, date or currency characters) that 4GL cannot convert.
GET_FLDBUF( ) is called from a CONSTRUCT statement, and the eld contains comparison or range operators that 4GL cannot convert.
GET_FLDBUF( ) is valid only in CONSTRUCT, INPUT, and INPUT ARRAY statements. When it encounters this operator in an INPUT ARRAY statement, 4GL
assumes that you are referring to the current row. You cannot use a subscript within brackets to reference a different row of the screen array. The following example uses the GET_FLDBUF( ) and FIELD_TOUCHED( ) operators in an AFTER FIELD clause in a CONSTRUCT statement. The FIELD_TOUCHED( ) operator checks whether the user has entered a value in the zipcode eld. If FIELD_TOUCHED( ) returns TRUE, GET_FLDBUF( ) retrieves the value entered in the eld and assigns it to the p_zip program variable. If the rst character in the p_zip variable is not a 9, the program displays an error, clears the eld, and returns the cursor to the eld.
CONSTRUCT BY NAME query1 ON customer.* ... AFTER FIELD city IF FIELD_TOUCHED(zipcode) THEN LET p_zip = GET_FLDBUF(zipcode) IF p_zip[1,1] <> "9" THEN ERROR "You can only search in section 9." CLEAR zipcode NEXT FIELD zipcode END IF END IF
References
FIELD_TOUCHED( ), INFIELD( ) Built-In Functions and Operators 5-89
INFIELD( )
INFIELD( )
The INFIELD( ) operator in CONSTRUCT, INPUT, and INPUT ARRAY statements tests whether its operand is the identier of the current screen eld.
INFIELD
(
table-reference screen-record screen-array
eld
Description is the name of a eld in the current screen form. is the name of a screen array that was dened in the INSTRUCTIONS section of the form specication le. is the name of a screen record that is explicitly or implicitly dened in the form specication le. is the unqualied name, alias, or synonym of a database table or view, or else the keyword FORMONLY.
Usage
INFIELD( ) is a Boolean operator that returns the value TRUE if eld is the name of the current screen eld. Otherwise, INFIELD( ) returns the value FALSE.
(For information on assigning a name to a display eld of a screen form, see ATTRIBUTES Section on page 6-25.) Important: You must specify a eld name rather than a eld tag as the operand. You can use INFIELD( ) during a CONSTRUCT, INPUT, or INPUT ARRAY statement to take eld-dependent actions.
5-90
INFIELD( )
The INFIELD( ) operator is typically part of an ON KEY clause, often with the built-in function SHOWHELP( ) to display help messages to the user. The next code example is from a program that uses INFIELD( ) to determine whether to call a function:
ON KEY (CONTROL-F, F5) IF INFIELD(customer_num) THEN CALL cust_popup()
When a user presses either of two keys during the INPUT, the cust_popup( ) function is invoked if the screen cursor is in the customer_num eld. In the following fragment, call_ag and res_ag are the names of elds:
ON KEY (F2, CONTROL-E) IF INFIELD(call_flag) OR INFIELD(res_flag) THEN IF INFIELD (call_flag) THEN LET fld_flag = "C" ELSE --* user pressed F2 (CTRL-E) from res_flag LET fld_flag = "R" END IF ... END IF
Subsequent code could use these eld names to determine which column of a row to edit. In the following example, the INPUT statement uses the INFIELD( ) operator with the SHOWHELP( ) function to display eld-dependent help messages.
INPUT gr_equip.* FROM sr_equip.* ON KEY(CONTROL-B) CASE WHEN INFIELD(part_num) CALL SHOWHELP(301) WHEN INFIELD(part_name) CALL SHOWHELP(302) WHEN INFIELD(supplier) CALL SHOWHELP(303) ... END CASE END INPUT
References
SCR_LINE( ), SHOWHELP( ), FIELD_TOUCHED( ), GET_FLDBUF( )
LENGTH( )
LENGTH( )
The LENGTH( ) function accepts a character string argument and returns an integer, representing the number of bytes in its argument (but disregarding any trailing blank spaces).
LENGTH
Usage
The LENGTH( ) function returns an integer value, based on the length (in bytes) of its character-expression argument. Statements in the next example center a report title on an 80-column page:
LET title = "Invoice for ", fname CLIPPED, " ", lname CLIPPED LET offset = (80 - length(title))/2 PRINT COLUMN offset, title
The following are among the possible uses for the LENGTH( ) function:
s
You can check whether a user has entered a database name and, if not, set a default name. Check whether the user has supplied the name of a le to receive the output from a report and, if not, set a default output. Use LENGTH(string) as the upper limit in a FOR loop, and check each character in string for a specic character. For example, you can check for a period ( . ) to determine whether a table name has a qualier.
LENGTH( ) is also useful as a check on user input. In the following example, an IF statement is used to determine whether the user has responded to a
displayed message:
IF LENGTH (ans1) = 0 THEN PROMPT "Press RETURN to continue: " FOR input_val ELSE ...
5-92
LENGTH( )
GLS
The rst invalid character (or partial character) All subsequent characters Any immediately preceding single-byte or multibyte white spaces
For example, suppose that w is an invalid character. The following expression evaluates to 7 because ABCD EF corresponds to seven bytes:
LENGTH(ABCD EF wXYZ)
The invalid character, the blank spaces preceding it, and all subsequent characters in the argument are ignored because w is an invalid character.
References
CLIPPED, USING
LINENO
LINENO
The LINENO operator returns the number of the line within the page that is currently printing. (This operator can appear only in the FORMAT section of a REPORT program block.)
LINENO
Usage
This operator returns the value of the line number of the report line that is currently printing. 4GL computes the line number by calculating the number of lines from the top of the current page, including the TOP MARGIN. For example, the following program fragment examines the value of LINENO. If this value is less than 9, a PRINT statement formats and displays it, beginning in the 10th character position after the left margin.
IF (LINENO > 9) THEN PRINT COLUMN 10, LINENO USING "Line <<<" END IF
You can specify LINENO in the PAGE HEADER, PAGE TRAILER, and other report control blocks to nd the print position on the current page of a report.
4GL cannot evaluate the LINENO operator outside the FORMAT section of a REPORT program block. The value that LINENO returns must be assigned to
a variable that is not local to the report if you need to reference this value within some other program block of your 4GL application.
Reference
PAGENO
5-94
MDY( )
MDY( )
The MDY( ) operator returns a value of the DATE data type from three integer operands that represent the month, the day of the month, and the year.
MDY
Usage
The MDY( ) operator converts to a single DATE format a list of exactly three valid integer expressions. The three expressions correspond with the month, day, and year elements of a calendar date:
s
The rst expression must return an integer, representing the number of the month (1 through 12). The second must return an integer, representing the number of the day of the month (1 through 28, 29, 30, or 31, depending on the month). The third must return a four-digit integer, representing the year.
An error results if you specify values outside the range of days and months in the calendar or if the number of operands is not three. You must enclose the three integer expression operands between parentheses, separated by commas, just as you would if MDY( ) were a function. The third expression cannot be the abbreviation for the year. For example, 99 species a year in the rst century, approximately 1,900 years ago. The following program uses MDY( ) to return a DATE value, which is then assigned to a variable and displayed on the screen:
MAIN DEFINE a_date DATE LET a_date = MDY(12/2,3+2,1988) DISPLAY a_date END MAIN
MDY( )
Reference
DATE( )
5-96
Membership ( . ) Operator
Membership ( . ) Operator
The membership operator, a period ( . ), species that its right-hand operand is a member of the set whose name is its left-hand operand.
structure . member
Description is the name of a component of structure. is the name of a RECORD variable, screen record, screen array of records, or database table, view, or synonym that has member as a component.
Usage
The structure value can specify a screen record, screen array, RECORD variable, or database table, view, or synonym. If member is the name of a database column, structure can be qualied by a table qualier. (For details, see Table Qualiers on page 3-89.) The structure value, member value, or both can be expressions that include the membership operator. For example:
myRec.data --member of a program or screen record alias.array[3].field5 --field within a screen array
The LET statement syntax diagram (shown in Data Types and Expressions on page 3-5) illustrates the syntax of members that are RECORD variables. For a description of the members of a RECORD variable, see also THRU or THROUGH Keywords and .* Notation on page 3-92. In contexts where more than one member is valid, you can substitute an asterisk ( * ) for member to specify every member of structure.
MONTH( )
MONTH( )
The MONTH( ) operator returns a positive whole number between 1 and 12, corresponding to the month portion of a DATE or DATETIME operand.
MONTH
Usage
The MONTH( ) operator extracts an integer value for the month in a DATE or DATETIME value. You cannot specify an INTERVAL operand. The following program extracts the month time unit from a DATETIME literal expression. It evaluates MONTH(date_var) as an operand of a Boolean expression to test whether the month is earlier in the year than March.
MAIN DEFINE date_var DATETIME YEAR TO SECOND DEFINE current_month CHAR(10) DEFINE month_var INT LET current_month = CURRENT MONTH TO MONTH LET date_var = DATETIME(89-01-12 18:47:32) YEAR TO SECOND LET month_var = MONTH(date_var) DISPLAY "The current month is: ", current_month DISPLAY "The month of interest is month number : ", month_var USING "##" IF MONTH(date_var) < 3 THEN DISPLAY "Month of interest is Feb. or Jan. END IF END MAIN
References
DATE( ), DAY( ), TIME( ), WEEKDAY( ), YEAR( )
5-98
NUM_ARGS( )
NUM_ARGS( )
The NUM_ARGS( ) function takes no arguments. It returns an integer that corresponds to the number of command-line arguments that followed the name of your 4GL program when the user invoked it.
NUM_ARGS
( )
Usage
You can use the ARG_VAL( ) built-in function to retrieve individual arguments. By using NUM_ARGS( ) with the ARG_VAL( ) function, the program can pass command-line arguments to the MAIN statement or to whatever program block invokes the NUM_ARGS( ) and ARG_VAL( ) functions. In the following examples, both of the command lines include three arguments:
myprog.4gi kim sue joe (executable compiled C version) fglgo myprog kim sue joe (command for p-code runner in RDS)
After either of these command lines, NUM_ARGS( ) sets 3 as the upper limit of variable i in the FOR loop of the program fragment that follows:
DEFINE pa_args ARRAY[8] OF CHAR(10), i SMALLINT FOR i = 1 TO NUM_ARGS() LET pa_args[i] = ARG_VAL(i) END FOR
Reference
ARG_VAL( )
ORD( )
ORD( )
The ORD( ) function accepts as its argument a character expression and returns the integer value of the rst byte of that argument. (
Character Expression p. 3-69
ORD
For the default (U.S. English) locale, the ORD( ) function is the logical inverse of the ASCII operator. Only the rst byte of the argument is evaluated. The following line assigns the value 66 to the integer ord1:
LET ord1 = ORD ("Belladonna")
This built-in function is case sensitive; if the rst character in its argument is an uppercase letter, ORD( ) returns a value different from what it would return if its argument had begun with a lowercase letter.
References
ASCII, FGL_KEYVAL( )
5-100
PAGENO
PAGENO
The PAGENO operator returns a positive whole number, corresponding to the number of the page of report output that 4GL is currently printing. (PAGENO is valid only in the FORMAT section of a REPORT program block.)
PAGENO
Usage
This operator returns a positive integer whose value is the number of the page of output that includes the current print position in the currently executing report. For example, the following program fragment conditionally prints the value returned by PAGENO, using the USING operator to format it, if this value is less than 10,000:
IF (PAGENO < 10000) THEN PRINT COLUMN 28, PAGENO USING "page <<<<" END IF
You can include the PAGENO operator in PAGE HEADER and PAGE TRAILER control blocks and in other control blocks of a report denition to identify the page numbers of output from a report.
4GL cannot evaluate the PAGENO operator outside the FORMAT section of a REPORT program block. If some other program block of your 4GL application needs to reference the value that PAGENO returns, the report must assign that
value to a program variable whose scope of reference is not local to the report.
Reference
LINENO
SCR_LINE( )
SCR_LINE( )
The SCR_LINE( ) function returns a positive integer that corresponds to the number of the current screen record in its screen array during a DISPLAY ARRAY or INPUT ARRAY statement.
SCR_LINE
( )
Usage
The current screen record is the line of a screen array that contains the screen cursor at the beginning of a BEFORE ROW or AFTER ROW clause. The rst record of the program array and of the screen array are both numbered 1. The built-in 4GL functions SCR_LINE( ) and ARR_CURR( ) can return different values if the program array is larger than the screen array. The following program fragment tests what the user enters and rejects it if the state eld value indicates that the customer is not from California:
DEFINE pa_clients ARRAY[90] OF RECORD fname CHAR(15), lname CHAR(15), state CHAR(2) END RECORD, curr_pa, curr_sc SMALLINT INPUT ARRAY pa_clients FROM sa_clients.* AFTER FIELD state LET curr_pa = ARR_CURR() LET curr_sc = SCR_LINE() IF UPSHIFT(pa_clients[curr_pa].state) != "CA" THEN ERROR "Policy for California clients only" INITIALIZE pa_clients[curr_pa].* TO NULL CLEAR scr_array[curr_sc].* NEXT FIELD fname END IF END INPUT
5-102
SCR_LINE( )
The following example makes use of SCR_LINE( ) and of the related ARR_CURR( ) built-in function to assign values to variables within the BEFORE ROW clause of an INPUT ARRAY statement. Because these functions are invoked in the BEFORE ROW control block, the respective curr_pa and curr_sa variables are evaluated each time that the cursor moves to a new line and are available within other clauses of the INPUT ARRAY statement.
INPUT ARRAY ga_items FROM sa_items.* HELP 62 BEFORE ROW LET curr_pa = ARR_CURR() LET curr_sa = SCR_LINE()
In a later statement within INPUT ARRAY, you can have a statement such as the following example, which lls in the description and unit_price elds on the screen:
DISPLAY ga_items[curr_pa].description, ga_items[curr_pa].unit_price TO sa_items[curr_sa].description, sa_items[curr_sa].unit_price
References
ARR_COUNT( ), ARR_CURR( )
SET_COUNT( )
SET_COUNT( )
The SET_COUNT( ) function species the number of records that contain data in a program array.
CALL SET_COUNT
Usage
Before you use an INPUT ARRAY WITHOUT DEFAULTS statement or a DISPLAY ARRAY statement, you must call the SET_COUNT( ) function with an integer argument to specify the total number of records in the program array. In typical applications, these records contain the values in the retrieved rows that a SELECT statement returned from a database and are associated with a database cursor. The SET_COUNT( ) built-in function sets an initial value from which the ARR_COUNT( ) function determines the total number of members in an array. If you do not explicitly call ARR_COUNT( ), a default value of zero is assigned. In the following program fragment, the variable n_rows is an array index that received its value in an earlier FOREACH loop. The index was initialized with a value of 1, so the expression (n_rows -1) represents the number of rows that were fetched from a database table in the FOREACH loop. The expression SET_COUNT (n_rows - 1) tells INPUT ARRAY WITHOUT DEFAULTS how many program records containing row values from the database are in the program array, so it can determine how to control the screen array.
CALL SET_COUNT(n_rows - 1) INPUT ARRAY pa_items WITHOUT DEFAULTS FROM sa_items.*
If no INPUT ARRAY statement has been executed, and you do not call the SET_COUNT ( ) function, the DISPLAY ARRAY or INPUT ARRAY WITHOUT DEFAULTS statement displays no records.
5-104
SET_COUNT( )
References
ARR_COUNT( ), ARR_CURR( )
SHOWHELP( )
SHOWHELP( )
The SHOWHELP( ) function displays a runtime help message, corresponding to its specied SMALLINT argument, from the current help le.
CALL SHOWHELP
Usage
The argument of SHOWHELP( ) identies the number of a message in the current help le that was specied in the most recently executed HELP FILE clause of the OPTIONS statement. For details of how to specify the current help le, see The HELP FILE Option on page 4-299.
If the help message is too long to t on one page, the Screen option of the Help menu can display the next page of the message. The Resume option closes the Help window and returns focus to the 4GL screen.
In nondefault locales, the help le can also contain printable non-ASCII characters from the code set of the locale.
IBM Informix 4GL Reference Manual
5-106
SHOWHELP( )
The help message follows the message number on the next line. It can include any printable ASCII characters, except that a line cannot begin with a period. The text of the help message should contain information useful to the user in the context where SHOWHELP( ) is called. The message is terminated by the next message number or by the end of the le. You must then use the mkmessage utility to create a runtime version of the help le that users can view. See the description of the mkmessage utility in Appendix B for details of how to compile help les. Here is a simple example of an ASCII help le for use with SHOWHELP( ):
.100 You have pressed the Help key of the Megacrunch Application. Unfortunately, all of our operators are busy at this time. Perhaps your supervisor can tell you what to do next..200 Press CONTROL-ALT-DEL to exit from this program. GLS
Help messages should be in the language of the intended user of the application. For applications that will be run in different locales, this might require translating the help messages into several languages. At runtime, the compiled help message les must exist in an appropriate subdirectory of $INFORMIXDIR/msg and be referenced by the DBLANG variable. (See also Appendix E, Developing Applications with Global Language Support.) In interactive statements like CONSTRUCT, INPUT, INPUT ARRAY, PROMPT, and the COMMAND clause of a MENU statement, the effect of SHOWHELP( ) resembles that of the Help key. The Help key, however, displays only the message specied in the current HELP clause. The following example uses INFIELD( ) with SHOWHELP( ) to display eld-dependent help messages:
INPUT ARRAY gr_equip.* FROM sa_equip.* ON KEY(CONTROL-B) CASE WHEN INFIELD(part_num) CALL SHOWHELP(301) WHEN INFIELD(part_name) CALL SHOWHELP(302) WHEN INFIELD(supplier) CALL SHOWHELP(303) ... END CASE END INPUT
Reference
INFIELD( ) Built-In Functions and Operators 5-107
SPACE
SPACE
The SPACE operator returns a string of a specied length, containing only blank (ASCII 32) characters. The keyword SPACES is a synonym for SPACE.
Integer Expression p. 3-63 SPACE SPACES
Usage
This operator returns a blank string of a length corresponding to its positive integer argument, specifying a relative offset. The returned value is identical to a quoted string that contains the same number of blank spaces. In a PRINT statement in the FORMAT section of a report denition, SPACE advances the character position by the specied number of characters. The following statements from a fragment of a report denition use the SPACE operator to accomplish several tasks:
s s s
To separate variables within two PRINT statements To concatenate six blank spaces to the string "=ZIP" To print the resulting string after the value of the variable zipcode:
FORMAT ON EVERY ROW LET mystring = (6 SPACES), "=ZIP" PRINT fname, 2 SPACES, lname PRINT company PRINT address1 PRINT city, ", " , state, 2 SPACES, zipcode, mystring
In a DISPLAY statement, the SPACE operator inserts the specied number of blank characters into the output. Outside PRINT statements, the SPACE (or SPACES) keyword and its operand must appear within parentheses, as in the LET statement of the previous example.
5-108
SPACE
References
LINENO, PAGENO
STARTLOG( )
STARTLOG( )
The STARTLOG( ) function opens an error log le.
CALL STARTLOG
"lename "
variable
Description is a quoted string to specify a lename (and optional pathname and le extension) of the error log le. is a variable of type CHAR or VARCHAR that contains a lename (and optional pathname and le extension) of the error log le.
Usage
The following is a typical sequence to implement error logging:
1. 2. 3.
Call STARTLOG( ) in the MAIN program block to open or create an error log le. Use a LET statement with ERR_GET(status) to retrieve the error text and to assign this value to a program variable. Use ERRORLOG( ) to make an entry into the error log le.
The last two steps are not needed if you are satised with the error records that are automatically produced after STARTLOG( ) has been invoked. After STARTLOG( ) has been invoked, a record of every subsequent error that occurs during the execution of your program is written to the error log le.
5-110
STARTLOG( )
The default format of an error record consists of the date, time, sourcemodule name and line number, error number, and error message. If you invoke the STARTLOG( ) function, the format of the error records that 4GL appends to the error log le after each subsequent error are as follows:
Date: 03/06/99 Time: 12:20:20 Program error at "stock_one.4gl", line number 89. SQL statement error number -239. Could not insert new row - duplicate value in a UNIQUE INDEX column. SYSTEM error number -100 ISAM error: duplicate value for a record with unique key.
You can also write your own messages in the error log le by using the ERRORLOG( ) function. For details, see ERRORLOG( ) on page 5-65. With other 4GL features, the STARTLOG( ), ERR_GET( ), and ERRORLOG( ) functions can be used for instrumenting a program, to track how the program is used. This use is not only valuable for improving the program but also for recording work habits and detecting attempts to breach security. Example 25 in INFORMIX-4GL by Example contains an example of this type of functionality. Unless you specify another option, WHENEVER ERROR CONTINUE is the default error-handling action when a runtime error condition is detected. The WHENEVER ERROR CONTINUE compiler directive can prevent the rst SQL error from terminating program execution.
STARTLOG( )
In this example, text written to the error log le merely shows that control of program execution has passed to the start_menu( ) function rather than indicating that any error has been issued. For portable programs, the lename should be a variable rather than a literal string. As in other lename specications, any literal backslash ( \ ) that is required as a pathname separator must be entered as two backslashes.
References
ERRORLOG( ), ERR_GET( ), ERR_PRINT( ), ERR_QUIT( )
5-112
Substring ( [ ] ) Operator
Substring ( [ ] ) Operator
The substring operator ( [ ] ) species a substring of the value returned by a character expression.
Character Expression p. 3-69
rst
] ,
last
Description are 1-based positions of the rst and last bytes (respectively) of a substring within the string returned by the left-hand operand.
Usage
The brackets ( [ ] ) are required. If last is not specied, the single byte in the rst position is returned. If last is specied, a comma must separate it from rst, and a substring is returned whose rst byte is rst and whose last byte is last, including any intervening bytes. The integer expressions rst and last must return values greater than zero but in the range 1 rst length, where length is the length of the string returned by the character expression, and rst last length. For example:
DEFINE diamond, spade CHAR[5], club ARRAY [3,4,5] OF CHAR[5] LET spade = "heart" LET club[2,2,2] = "heart" LET diamond = spade[3,5]
Here the last statement assigns the value "art" to the variable diamond, using a three-character substring of the string value in spade. If the substring consists of a single character, the last term is not required. For example, if you modied the previous program fragment to include the following statement, the LET statement assigns the value a to variable diamond, from the third character of the "heart" string value in spade:
LET diamond = spade[3]
Substring ( [ ] ) Operator
Expressions with character arrays as operands can specify substrings of an individual array element:
LET diamond = club[2,2,2] [2,4]
In the context of the previous program fragments, this assigns to diamond the substring "ear" from the value ("heart") of array element club[2,2,2].
When rst has a zero or negative value When rst is larger than last When rst or last cannot be converted to an integer value When last has a value greater than the number of bytes returned by the left-hand character expression When the left-hand expression is a CHAR or VARCHAR variable (or ARRAY element, or RECORD member) of a declared size less than last When the left-hand character expression returns an empty string
Invalid operands can produce runtime error -1332. If you are using the RDS version of 4GL, the resulting error message also reports the lename of the .4gl source-code module in which the error was detected and the line number within that module of the substring expression that caused the error. If you have compiled your source code to C, however, rather than to p-code, no module name or line number is provided in the error message. This situation can make it more difcult for developers who do not have RDS to locate an invalid substring specication.
GLS
The substring operator is byte based. In East Asian locales that support multibyte characters, 4GL automatically replaces any partial characters that this operator attempts to create with single-byte white-space characters so that no partial character is returned. Informix database servers that support GLS provide functions that are based on a count of logical characters rather than on the number of bytes.
5-114
Substring ( [ ] ) Operator
Reference
CLIPPED
TIME
TIME
The TIME operator converts the time-of-day portion of its DATETIME operand to a character string. If you supply no operand, TIME reads the system clock and returns a character string value representing the current time of day.
TIME
Usage
TIME returns a character string that represents the time-of-day portion of its DATETIME operand in the format hh:mi:ss, based on a 24-hour clock. (Here hh
represents the hour, mi the minute, and ss the second as 2-digit strings, with colons as separators.) If you do not supply an operand, TIME returns a character string that represents the current time in the format hh:mi:ss, based on a 24-hour clock. In the following program fragment, the value returned by TIME is assigned to the p_time variable and displayed:
DEFINE p_time char(15) LET p_time = TIME DISPLAY "The time is ", p_time
If this code were executed half an hour before midnight, the previous DISPLAY statement would produce output in the following format:
The time is 23:30:00
Like the values returned by the CURRENT, DATE, DAY, MONTH, TODAY, WEEKDAY, and YEAR operators, the value that TIME returns is sensitive to the time of execution and to the accuracy of the system clock-calendar.
References
CURRENT, DATE, DAY, MONTH, TODAY, WEEKDAY, YEAR
5-116
TODAY
TODAY
The TODAY operator reads the system clock and returns a DATE value that represents the current calendar date.
TODAY
Usage
TODAY can return the current date in situations where the time of day (which CURRENT or TIME supplies) is not necessary. Like the CURRENT, DATE, DAY, MONTH, TIME, WEEKDAY, and YEAR operators, TODAY is sensitive to the
time of execution and to the accuracy of the system clock-calendar. The following example uses TODAY in a REPORT denition:
SKIP 1 LINE PRINT COLUMN 15, "FROM: ", begin_date USING "mm/dd/yy", COLUMN 35, "TO: ", end_date USING "mm/dd/yy" PRINT COLUMN 15, "Report run date: ", TODAY USING "mmm dd, yyyy" SKIP 2 LINES PRINT COLUMN 2, "ORDER DATE", COLUMN 15, "COMPANY", COLUMN 35, "NAME", COLUMN 57, "NUMBER", COLUMN 65, "AMOUNT"
TODAY is useful in setting defaults and initial values in form elds. The next
code fragment initializes a eld with the current date if the eld is empty. This initialization takes place before the user enters data into the eld:
INPUT gr_payord.paid_date FROM a_date BEFORE FIELD a_date IF gr_payord.paid_date IS NULL THEN LET gr_payord.paid_date = TODAY END IF GLS
4GL can display language-specic month-name and day-name abbreviations if appropriate les exist in a subdirectory of $INFORMIXDIR/msg and they are referenced by the DBLANG variable. For example, the weekday portion of a date in a Spanish locale can translate Saturday to the abbreviation Sab,
TODAY
References
CURRENT, DATE, DAY, MONTH, TIME, WEEKDAY, YEAR
5-118
UNITS
UNITS
The UNITS operator converts an integer expression to an INTERVAL value, expressed in a single unit of time that you specify after the UNITS keyword.
Integer Expression p. 2-3
UNITS
Element scale
Usage
The UNITS operator returns an INTERVAL value for a single unit of time, such as DAY TO DAY, YEAR TO YEAR, or HOUR TO HOUR. If you substitute a number expression for the integer operand, any fractional part of the returned value is discarded before the UNITS operator is applied.
UNITS has a higher precedence than any arithmetic or Boolean operator of 4GL. Any left-hand arithmetic operand that includes the UNITS operator must
be enclosed within parentheses. The next example species a starting time for a meeting (DATETIME value) and a value for the duration of the meeting, which the program has already converted to a whole number of minutes (SMALLINT). The program calculates when the meeting will end (DATETIME value). UNITS in this case allows you to add the SMALLINT value to the DATETIME value and get a new DATETIME value.
LET end_time = (meeting_length UNITS MINUTE) + start_time
Because the difference between two DATE values is an integer count of days rather than an INTERVAL data type, you might want to use the UNITS operator to convert such differences explicitly to INTERVAL values:
LET lateness = (date_due - TODAY) UNITS DAYS
UNITS
Arithmetic operations with UNITS can return an invalid date. For example, the expression (1 UNITS MONTH) + DATETIME (2001-1 31) YEAR TO DAY returns February 31, 2001, and also a runtime error:
-1267: The result of a datetime computation is out of range.
5-120
UPSHIFT( )
UPSHIFT( )
The UPSHIFT( ) function takes a character-string argument and returns a string in which any lowercase letters are converted to uppercase letters.
UPSHIFT
Usage
The UPSHIFT( ) function is most often used to regularize data; for example, to prevent the state abbreviation VA, Va, or va from resulting in different values if these abbreviations were logically equivalent in the context of your application. You can use the UPSHIFT( ) function in an expression where a character string is valid, in DISPLAY and PRINT statements, and in assignment statements. (See also UPSHIFT on page 6-64.) Non-alphabetic and uppercase characters are not altered by UPSHIFT( ). The maximum data length of the argument (and of the returned character string value) is 32,766 bytes. The following example demonstrates a function that was written to merge two privilege strings. Its output preserves letters in preference to hyphens (privileges over lack of privilege) and uppercase letters in preference to lowercase (privileges WITH GRANT OPTION over those without).
FUNCTION merge_auth(oldauth, newauth) DEFINE oldauth, newauth LIKE systabauth.tabauth, k SMALLINT FOR k = 1 TO LENGTH(oldauth) IF (oldauth[k] = "-") -- no privilege in this position OR (UPSHIFT(oldauth[k]) = newauth[k]) -- new is "with grant option" THEN LET oldauth[k] = newauth[k]) END IF END FOR RETURN oldauth END FUNCTION
UPSHIFT( )
In the next example, the CHAR variables u_str and str are equivalent, except that u_str substitutes uppercase letters for any lowercase letters in str:
LET u_str = UPSHIFT(str) GLS
The results of conversion between uppercase and lowercase letters are based on the locale les, which specify the relationship between corresponding pairs of uppercase and lowercase letters. If the locale les do not provide this information, no case conversion occurs.
UPSHIFT( ) has no effect on non-English characters in most multibyte locales.
In multibyte locales, UPSHIFT( ) and DOWNSHIFT( ) treat the rst partial (or otherwise invalid) character in the argument as if it terminated the string. For example, suppose that b is an invalid character. The following expression would return the character string "ABCD EF " with any single-byte or multibyte white-space characters that immediately precede the rst invalid character being included in the returned value, rather than being discarded:
UPSHIFT(ABCD ef
bXYZ)
Reference
DOWNSHIFT( )
5-122
USING
USING
The USING operator species a character-string format for a number, MONEY, or DATE operand and returns the formatted value.
Number Expression p. 3-72 Time Expression p. 3-72 USING "format-string"
Element format-string
Description is a quoted string that species how to format the returned character string from the number or time expression.
Usage
With a number or MONEY operand, you can use the USING operator to align decimal points or currency symbols, to right- or left-align numbers, to put negative numbers in parentheses, and to perform other formatting tasks. USING can also convert a DATE operand to a variety of formats.
USING is typically used in DISPLAY and PRINT statements, but you can also use it with LET to assign the formatted value to a character variable. If a value is too large for the eld, 4GL lls it with asterisks ( * ) to indicate an overow.
For information on symbols that the USING operator recognizes in formatstring, see The USING Formatting Symbols for Number Values on page 5-124 (for number values) and Formatting DATE Values on page 5-127 (for DATE values).
USING
4GL displays the leading currency symbol (as set by DBFORMAT or DBMONEY) for MONEY values. (But if the FORMAT attribute also species a leading currency symbol, 4GL displays that symbol for
4GL omits the thousands separators, unless they are specied by a FORMAT attribute or by the USING operator. 4GL displays the decimal separator, except for INT or SMALLINT
values.
s
4GL displays the trailing currency symbol (as set by DBFORMAT or DBMONEY) for MONEY values unless you specify a FORMAT attribute or the USING operator. In this case, the user cannot enter a trailing currency symbol, and 4GL does not display it.
5-124
USING
Character Description This character is a literal. USING displays it as a minus sign when the expression is less than zero and otherwise as a blank. When you group several minus signs in a row, a single minus sign oats immediately to the left of the number being printed. This character is a literal. USING displays it as a plus sign when the expression is greater than or equal to zero and as a minus sign when it is less than zero. When you group several plus signs in a row, a single plus sign oats immediately to the left of the displayed number. The dollar ( $ ) sign is a placeholder for the front specication of DBMONEY or DBFORMAT. (The back specication of DBMONEY or DBFORMAT has no effect if USING is applied to the data value. ) When you group several consecutive dollar signs, a single front currency symbol oats immediately to the left of the number being printed. This literal character is displayed as a left parenthesis before a negative number. It is the accounting parenthesis that is used in place of a minus sign to indicate a negative number. Consecutive left parentheses display a single left parenthesis to the left of the number being printed. For the accounting parenthesis that is used in place of a minus sign to indicate a negative number, one of these characters generally closes a format string that begins with a left parenthesis. (2 of 2)
The minus sign ( - ), plus sign ( + ), parentheses, and dollar sign ( $ ) oat, meaning that when you specify multiple leading occurrences of one of these characters, 4GL displays only a single character immediately to the left of the number that is being displayed. Any other character in format-string is interpreted as a literal. Important: These characters are not identical to the formatting characters that you can specify in the format-strings of the FORMAT or PICTURE eld attributes, described in Chapter 6, Screen Forms. For examples of using format strings for number expressions, see Examples of the USING Operator on page 5-129. Because format strings interact with data to produce visual effects, you might nd that the examples are easier to follow than the descriptions on the previous page of USING format string characters.
USING
The following example prints a MONEY value using a format string that allows values up to $9,999,999.99 to be formatted correctly:
DEFINE mon_val MONEY(8,2) LET mon_val = 23485.23 DISPLAY "The current balance is ", mon_val USING "$#,###,##&.&&"
Executing this DISPLAY statement (with the value of mon_val set to 23485.23) produces the following output:
The current balance is $ 23,485.23
The format string in this example species the currency symbol. The previous example also uses the # and & ll characters. The # character provides blank ll for unused character positions, while the & character provides zero lling. This format ensures that even if the number is zero, any positions marked with & appear as zero, not blank. Dollar signs can be used instead of # characters, as in the following statement:
DISPLAY "The current balance is ",mon_val USING "$$,$$$,$$&.&&"
In this example, the currency symbol oats with the size of the number so that it appears immediately to the left of the most signicant digit in the display. This example would produce the following formatted output, if the value of the mon_val variable were 23485.23:
The current balance is $23,485.23
By default, 4GL displays numbers right aligned. You can use the < symbol in a USING format string to override this default. For example, specifying
DISPLAY "The current balance is ",mon_val USING "$<<,<<<,<<&.&&"
5-126
USING
Resulting Time Unit in Formatted DATE Display Day of the month as a 2-digit number (01 through 31 or less) Day of the week as a 3-letter abbreviation (Sun through Sat) Month as a 2-digit number (01 through 12) Month as a 3-letter abbreviation (Jan through Dec) Year as a 2-digit number (the trailing digits, 00 through 99) Year as a 4-digit number (0001 through 9999)
Here lowercase is required; uppercase D, M, or Y cannot be substituted. Any other characters within a USING formatting mask for DATE values are interpreted as literals. The following examples show valid format-string masks for December 25, 1999, and the resulting display for the default U.S. English locale.
Format String
"mmddyy" "ddmmyy" "yymmdd" "yy/mm/dd" "yy mm dd" "yy-mm-dd" "mmm. dd, yyyy" "mmm dd yyyy"
Formatted Result
122599 251299 991225 99/12/25 99 12 25 99-12-25 Dec. 25, 1999 Dec 25 1999
(1 of 2)
USING
Format String
"yyyy dd mm" "mmm dd yyyy" "ddd, mmm. dd, yyyy" "(ddd) mmm. dd, yyyy"
Formatted Result
1999 25 12 Dec 25 1999 Sat, Dec. 25, 1999 (Sat) Dec. 25, 1999
(2 of 2)
5-128
USING
GLS
In nondefault locales, the NUMERIC and MONETARY categories in the locale les affect how the format string of the USING operator is interpreted for formatting number and currency data values. In format string, the period ( . ) is not a literal character but a placeholder for the decimal separator specied by environment variables. Likewise, the comma is a placeholder for the thousands separator specied by environment variables. The dollar sign ( $ ) is a placeholder for the leading currency symbol. The @ symbol is a placeholder for the trailing currency symbol. Thus, the format string $#,###.## formats the value 1234.56 as 1,234.56 in a U.K. English locale, but as f1.234,56 in a French locale. Setting either DBFORMAT or DBMONEY overrides these locale setting. The mmm and ddd speciers in a format string can display language-specic month-name and day-name abbreviations. This operation requires the installation of appropriate les in a subdirectory of $INFORMIXDIR/msg and reference to that subdirectory in the setting of the environment variable DBLANG. For example, in a Spanish locale, the ddd specier translates the day Saturday into the day-name abbreviation Sab, which stands for Sabado (the Spanish word for Saturday). For more information on GLS, see Appendix E, Developing Applications with Global Language Support.
The rst column shows a format string (the left-hand operand). The second column shows a data value (the right-hand operand). The third column shows the resulting formatted display. The fourth column provides a comment (for some rows).
USING
Here the character b in the Formatted Result column represents a blank space.
Format String
"#####" "&&&&&" "$$$$$" "*****" "<<<<<" "<<<,<<<" "<<<,<<<" "<<<,<<<" "<<<,<<<" "##,###" "##,###" "##,###" "##,###" "##,###" "##,###" "##,###" "&&,&&&" "&&,&&&" "&&,&&&" "&&,&&&" "&&,&&&" "&&,&&&" "&&,&&&" "&&,&&&.&&" "&&,&&&.&&" "&&,&&&.&&" "&&,&&&.&&" "$$,$$$" "$$,$$$" "$$,$$$" "$$,$$$" "$$,$$$" "$$,$$$" "**,***" "**,***" "**,***" "**,***" "**,***" "**,***"
Data Value
0 0 0 0 0 12345 1234 123 12 12345 1234 123 12 1 -1 0 12345 1234 123 12 1 -1 0 12345.67 1234.56 123.45 0.01 12345 1234 123 12 1 0 12345 1234 123 12 1 0
Formatted Result
bbbbb 00000 bbbb$ ***** 12,345 1,234 123 12 12,345 b1,234 bbb123 bbbb12 bbbbb1 bbbbb1 bbbbbb 12,345 01,234 000123 000012 000001 000001 000000 12,345.67 01,234.56 000123.45 000000.01 ****** $1,234 bb$123 bbb$12 bbbb$1 bbbbb$ 12,345 *1,234 ***123 ****12 *****1
Comment on Result No zero symbol No zero symbol No zero symbol (NULL string)
No negative sign
(Overow)
No zero symbol
******
No zero symbol
5-130
USING
Here the character b in the Formatted Result column represents a blank space.
Format String
"##,###.##" "##,###.##" "##,###.##" "##,###.##" "##,###.##" "##,###.##" "##,###.##" "##,###.##" "##,###.##" "$$,$$$.$$" "$$,$$$.$$" "$$,$$$.##" "$$,$$$.##" "$$,$$$.&&" "$$,$$$.&&" "-$$$,$$$.&&" "-$$$,$$$.&&" "-$$$,$$$.&&" "--$$,$$$.&&" "--$$,$$$.&&" "--$$,$$$.&&" "--$$,$$$.&&" "--$$,$$$.&&" "-##,###.##" "-##,###.##" "-##,###.##" "--#,###.##" "---,###.##" "---,-##.##" "---,--#.##" "-##,###.##" "-##,###.##" "-##,###.##" "-##,###.##" "--#,###.##" "---,###.##" "---,-##.##" "---,---.##" "---,---.--" "---,---.&&"
Data Value
12345.67 1234.56 123.45 12.34 1.23 0.12 0.01 -0.01 -1 12345.67 1234.56 0.00 1234.00 0.00 1234.00 -12345.67 -1234.56 -123.45 -12345.67 -1234.56 -123.45 -12.34 -1.23 -12345.67 -123.45 -12.34 -12.34 -12.34 -12.34 -1.00 12345.67 1234.56 123.45 12.34 12.34 12.34 12.34 1.00 -.01 -.01
Formatted Result
12,345.67 b1,234.56 bbb123.45 bbbb12.34 bbbbb1.23 bbbbb0.12 bbbbbb.01 bbbbbb.01 bbbbb1.00
Comment on Result
*********
$1,234.56 $.00 $1,234.00 $.00 $1,234.00 -$12,345.67 -b$1,234.56 -bbb$123.45 -$12,345.67 -$1,234.56 -bb$123.45 -bbb$12.34 -bbbb$1.23 -12,345.67 -bbb123.45 -bbbb12.34 -bbb12.34 -bb12.34 -12.34 -1.00 12,345.67 1,234.56 123.45 12.34 12.34 12.34 12.34 1.00 -.01 -.01
No leading zero No negative sign No negative sign (overow) No leading zero No leading zero
USING
Here the character b in the Formatted Result column represents a blank space.
Format String
"----,--$.&&" "----,--$.&&" "----,--$.&&" "----,--$.&&" "----,--$.&&" "----,--$.&&" "$***,***.&&" "$***,***.&&" "$***,***.&&" "$***,***.&&" "$***,***.&&" "$***,***.&&" "($$$,$$$.&&)" "($$$,$$$.&&)" "($$$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "($$$,$$$.&&)" "($$$,$$$.&&)" "($$$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "(($$,$$$.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)" "((((,(($.&&)"
Data Value
-12345.67 -1234.56 -123.45 -12.34 -1.23 -.12 12345.67 1234.56 123.45 12.34 1.23 .12 -12345.67 -1234.56 -123.45 -12345.67 -1234.56 -123.45 -12.34 -1.23 -12345.67 -1234.56 -123.45 -12.34 -1.23 -.12 12345.67 1234.56 123.45 12345.67 1234.56 123.45 12.34 1.23 12345.67 1234.56 123.45 12.34 1.23 .12
Formatted Result
-$12,345.67 -$1,234.56 -$123.45 -$12.34 -$1.23 -$.12 $*12,345.67 $**1,234.56 $****123.45 $*****12.34 $******1.23 $*******.12 ($12,345.67) (b$1,234.56) (bbb$123.45) ($12,345.67) ($1,234.56) (bb$123.45) (bbb$12.34) (bbbb$1.23) ($12,345.67) ($1,234.56) ($123.45) ($12.34) ($1.23) ($.12) $12,345.67 $1,234.56 $123.45 $12,345.67 $1,234.56 $123.45 $12.34 $1.23 $12,345.67 $1,234.56 $123.45 $12.34 $1.23 $.12
Comment on Result
Accounting parentheses
5-132
WEEKDAY( )
WEEKDAY( )
The WEEKDAY( ) operator returns a positive integer, corresponding to the day of the week implied by its DATE or DATETIME operand.
WEEKDAY ( DATETIME Expression p. 3-74 DATE Expression p. 3-74
Usage
This operator takes a DATETIME or DATE operand, and returns an integer in the range 0 through 6. Here 0 represents Sunday, 1 represents Monday, and so on. The following example calls a function that uses WEEKDAY with a CASE statement to assign a three-letter day-of-the-week abbreviation to each date in an array, omitting days that fall on weekends:
FOR i = 1 TO 10 CALL seize_theday(next_day) RETURNING day_name, next_day LET pa_days[i].dayo_week = day_name LET pa_days[i].rdate = next_day LET next_day = next_day + 1 END FOR ... FUNCTION seize_theday(next_day) DEFINE week_day SMALLINT day_name CHAR(3) next_day DATE LET week_day = WEEKDAY(next_day) CASE week_day WHEN 1 LET day_name = "Mon" WHEN 2 LET day_name = "Tues" WHEN 3 LET day_name = "Wed" WHEN 4 LET day_name = "Thu" WHEN 5 LET day_name = "Fri" WHEN 6 LET day_name = "Mon" LET next_day = next_day + 2 WHEN 7 LET day_name = "Mon" LET next_day = next_day + 1 END CASE RETURN day_name, next_day END FUNCTION -- seize_theday
WEEKDAY( )
This operator is useful for determining the day of the week from dates in recent and future centuries. It should be used with caution, however, for more remote dates, because of disagreements between the old and new calendar systems in some European countries between the invention of the Gregorian calendar in 1582 and the eventual acceptance of that calendar. For dates thousands of years in the past (for example, the death of Socrates, or the establishment of the Middle Kingdom in ancient Egypt), it is difcult to verify that the sequential count of the seven days of the week has been accurately maintained from antiquity up to the present. Computers that use defective algorithms for calculating leap years might also have difculties with the weekdays in modern dates after February 28 of the year 2000. The WEEKDAY( ) operator is among a group of 4GL operators that extract a single time unit value from a DATETIME or DATE value. The following extraction operators of 4GL accept a DATETIME or DATE operand.
Operator DAY( ) MONTH( ) YEAR( ) WEEKDAY( ) Meaning of the Returned Integer The day of the month The month The year The day of the week
In addition, the DATE( ) operator can extract the date portion of a DATETIME value that has YEAR TO DAY or greater precision, and the TIME operator can extract the time-of-day from a DATETIME expression that has HOUR TO FRACTION precision (or a subset thereof). The USING operator can also return day-of-the-week information from a DATE operand (as described in Formatting DATE Values on page 5-127). For more information, see the GL_DATE environment variable in Appendix D, Environment Variables.
References
CURRENT, DATE, DAY, MONTH, TIME, TODAY, YEAR
5-134
WORDWRAP
WORDWRAP
The WORDWRAP operator divides a long text string into segments that appear in successive lines of a 4GL report. (This operator can appear only in the PRINT statement in the FORMAT section of a REPORT program block.)
string TEXT variable WORDWRAP RIGHT MARGIN temporary
Description is a character expression (as described in Character Expressions on page 3-69) to be printed in the output from the report. is an integer expression (as described in Integer Expressions on page 3-63) whose returned value species the absolute position (in characters), counting from the left edge of the page, of a temporary right margin. is the name of a 4GL variable of the TEXT data type to be printed in the output from the report.
TEXT variable
Usage
The WORDWRAP operator automatically wraps successive segments of long character strings onto successive lines of output from a 4GL report. The string value of any expression or TEXT variable that is too long to t between the current character position and the specied or default right margin is divided into segments and displayed between temporary margins:
s s
The current character position becomes the temporary left margin. Unless you specify RIGHT MARGIN temporary, the right margin defaults to 132 or to the size from the RIGHT MARGIN clause of the OUTPUT section of the report denition.
These temporary values override the specied or default left and right margins from the OUTPUT section. After the PRINT statement has executed, any explicit or default margins from the OUTPUT section are restored. For more information, see PRINT on page 7-55.
Built-In Functions and Operators 5-135
WORDWRAP
The following PRINT statement species a temporary left margin in column 10 and a temporary right margin in column 70 to display the character string that is stored in the 4GL variable called mynovel:
print column 10, mynovel WORDWRAP RIGHT MARGIN 70
Prints blank characters only to the right margin Discards any remaining blank characters from the blank string or tab Starts a new line at the temporary left margin Processes the next word
4GL starts a new line when a word plus the next blank space cannot t on the
current line. If all words are separated by a single space, an even left margin results. 4GL applies the following rules (in descending order of precedence) to the portion of the data string within the right margin:
s
Break at any newline character, RETURN, or newline character and RETURN pair. Break at the last blank (ASCII 32) or TAB character before the right margin. Break at the right margin if no character farther to the left is a blank, RETURN, TAB, or newline character.
4GL maintains page discipline with the WORDWRAP operator. If the character string or TEXT value operand is too long for the current page of report output, 4GL executes the statements in any PAGE TRAILER and PAGE HEADER control
WORDWRAP
Tip: The WORDWRAP keyword can also specify a eld attribute that supports data display and data entry in a multiple-segment eld of a 4GL form. For more information, see WORDWRAP on page 6-67.
Kinsoku Processing
GLS
In Japanese locales, a suitable break can also be made between the Japanese characters. However, certain characters must not begin a new line, and some characters must not end a line. This convention creates the need for kinsoku processing, whose purpose is to format the line properly, without any prohibited character at the beginning or ending of a line.
4GL reports use the wrap-down method for WORDWRAP and kinsoku
processing. The wrap-down method reads the last character in the line and forces that character down to the next line if that character is prohibited from ending a line. A character that precedes another that is prohibited from beginning a line can also wrap down to the next line. Characters that are prohibited from beginning or ending a line must be listed in the locale les. 4GL tests for prohibited characters at the beginning and ending of a line, testing the rst and last visible characters. The kinsoku processing only happens once for each line. That is, no further kinsoku processing occurs even if prohibited characters are still on the same line after the rst kinsoku processing takes place.
References
CLIPPED, SPACES, USING
YEAR( )
YEAR( )
The YEAR( ) operator returns an integer corresponding to the year portion of its DATE or DATETIME operand.
YEAR
Usage
The YEAR( ) operator returns all the digits of the year value (1999, not 99). (The second example that follows illustrates how to obtain a two-digit value like 99 from a four-digit year like 1999.) The following example extracts the current year and stores the value in an integer variable:
LET y_var = YEAR(TODAY)
You can produce a two-digit year abbreviation by using the MOD (modulus) operator:
LET birth_yr = (YEAR(birth_date)) MOD 100
In the right-hand expression, the MOD operator yields the year modulo 100, the remainder when the value representing the actual year is divided by 100. For example, if the value of the DATE variable birth_date is 09-16-1953, the YEAR( ) operator extracts the value 1953, and the following expression returns 53:
1953 MOD 100
References
CURRENT, DATE, DAY, MONTH, TIME, TODAY, WEEKDAY 5-138 IBM Informix 4GL Reference Manual
Chapter
Screen Forms
6
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-5 6-5 6-5 6-7 6-7 6-8 6-8 6-9 6-12 6-13 6-14 6-14 6-15 6-16 6-17 6-17 6-17 6-18 6-18 6-19 6-21 6-22 6-23 6-24
In This Chapter .
4GL Forms. . . . . . . . . . . Form Drivers . . . . . . . . Form Fields . . . . . . . . . Appearance of Fields . . . . Navigation Among Form Fields. Disabled Form Fields . . . . Structure of a Form Specication File .
DATABASE Section . . . . . . . . . . . Database References in the DATABASE Section The FORMONLY Option . . . . . . . . The WITHOUT NULL INPUT Option . . . . SCREEN Section . . . . . . . . The SIZE Option . . . . . . The Screen Layout . . . . . . Display Fields . . . . . . . Field Delimiters . . . . . Field Length . . . . . . Field Tags . . . . . . . Literal Characters in Forms . . Graphics Characters in Forms Rectangles Within Forms . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
ATTRIBUTES Section . . . . . FORMONLY Fields . . . . The Data Type Specication The NOT NULL Keywords Multiple-Segment Fields . . WORDWRAP Fields . . . Subscripted Fields . . . Field Attributes . . . . . Field Attribute Syntax . . . AUTONEXT . . . . . . . CENTURY . . . . . . . COLOR . . . . . . . . COMMENTS . . . . . . DEFAULT . . . . . . . DISPLAY LIKE . . . . . . DOWNSHIFT . . . . . . FORMAT . . . . . . . . INCLUDE . . . . . . . INVISIBLE . . . . . . . NOENTRY . . . . . . . PICTURE . . . . . . . . PROGRAM . . . . . . . REQUIRED . . . . . . . REVERSE . . . . . . . . UPSHIFT . . . . . . . . VALIDATE LIKE . . . . . VERIFY . . . . . . . . WORDWRAP . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . .
6-25 6-29 6-29 6-30 6-31 6-31 6-32 6-32 6-33 6-34 6-35 6-37 6-43 6-45 6-48 6-49 6-50 6-53 6-56 6-57 6-58 6-60 6-62 6-63 6-64 6-65 6-66 6-67 6-74 6-74 6-75 6-76 6-77 6-79 6-80 6-83 6-84
INSTRUCTIONS Section . . . . . . . . . . . . . . . . . Screen Records . . . . . . . . . . . . . . . . . . . Nondefault Screen Records . . . . . . . . . . . . . The List of Member Fields . . . . . . . . . . . . . . Screen Arrays . . . . . . . . . . . . . . . . . . . Field Delimiters . . . . . . . . . . . . . . . . . . . Default Attributes . . . . . . . . . . . . . . Precedence of Field Attribute Specications . . . . Default Attributes in an ANSI-Compliant Database .
6-2 IBM Informix 4GL Reference Manual
. . .
. . .
. . .
. . .
. . .
Creating and Compiling a Form . . . . . . . . . . . . Compiling a Form Through the Programmers Environment. Compiling a Form at the Command Line . . . . . . . Default Forms . . . . . . . . . . . . . . . . . Using PERFORM Forms in 4GL . . . . . . . . . . . .
. . . . .
. . . . .
. . . .
. 6-91
6-4
In This Chapter
A screen form is a visual display that can support input and output tasks in an INFORMIX-4GL application. Before your 4GL program can use a screen form, you must rst create a form specication le. This source le describes the logical format of the screen form and how to display data values in the form at runtime. It must be compiled separately from the rest of your source code. The same compiled form can be used by different 4GL programs. The rst part of this chapter describes the structure of a form specication le and the effect and syntax of its components. Default Attributes on page 6-80 describes the syscolval and syscolatt tables that can specify formats, validation rules, and default data values for elds. (For information on using the upscol utility to specify values in these tables, see Appendix B, INFORMIX-4GL Utility Programs.) Additional sections in this chapter describe how to compile 4GL forms and how to use forms designed for PERFORM, the screen transaction processor of INFORMIX-SQL.
4GL Forms
This section describes form drivers, which control the display of a form, and form elds, including their behavior and how to navigate among them.
Form Drivers
To work with a compiled screen form, the application requires a form driver, a logical set of 4GL statements that control the display of the form, bind form elds to 4GL variables, and respond to actions by the user in elds.
Form Drivers
The form driver can include 4GL screen interaction and data manipulation statements to enter, retrieve, modify, or delete data in the database. The emphasis of this chapter, however, is on how to create the form specication le, rather than on how to design and implement the form driver. Regardless of how you dene them, there is no implicit relationship between the values of program variables, form elds, and database columns. Even, for example, if you declare a 4GL variable lname LIKE customer.lname, the changes that you make to the variable do not imply any change in the column value. Functional relationships among these entities must be specied in the logic of your form driver, typically through screen interaction statements of 4GL, and through data manipulation statements of SQL. After the user presses the Accept key to terminate an INPUT ARRAY statement, for example, the form driver can use the INSERT statement to modify the database. Similarly, a 4GL form is only a template. FORM4GL reads the system catalog at compile time to obtain the names and data types of any columns that are referenced in the form specication le. After compilation, however, the form loses its connection to the database. It can no longer distinguish the name of a table or view from the name of a screen record. It is up to you, the programmer, to determine what data a form displays and what to do with data values that the user enters into the elds of a form. You must indicate the binding explicitly in any 4GL statement that connects 4GL variables to screen forms or to database columns. The following statements, for example, take input from a 4GL form and insert the entered value from the form into the database. (Here the @ sign in the INSERT statement tells 4GL that the rst lname is the SQL identier of a database column.)
INPUT lname FROM customer.lname INSERT INTO customer (@lname) VALUES (lname)
You can use interactive 4GL statements such as OPEN FORM, OPEN WINDOW, INPUT, DISPLAY FORM, CLEAR FORM, and CONSTRUCT in the form driver to support data entry or data display through the 4GL form. Some statements support temporary binding when a program variable and a screen eld have identical names. (See the individual 4GL statement descriptions in Chapter 4, INFORMIX-4GL Statements, for the appropriate syntax.) For example, the following statement could replace the previous INPUT statement:
INPUT BY NAME lname
For more information about form drivers, refer to INFORMIX-4GL Concepts and Use.
6-6 IBM Informix 4GL Reference Manual
Form Fields
Form Fields
In a form, a eld (sometimes called a screen eld or form eld) is an area where the user of the application can view, enter, and edit data, depending on its description in the form specication and the statements in the form driver. This section discusses the appearance and behavior of form elds in 4GL.
Appearance of Fields
The screen form contains display elds bounded by delimiters, such as the square brackets shown in Figure 6-1.
Figure 6-1 The customer Form
FORM
Last Name: ] ] ]
City: State:
Telephone: [ - - - - -
The currently active form eld contains a visual cursor. This current eld displays what the user types. For details about how to size and position elds in a form, see Display Fields on page 6-17. For information on assigning display and validation attributes to elds, see Field Attribute Syntax on page 6-33.
GLS
For nondefault locales, screen forms can include non-ASCII characters that the client locale supports.
Screen Forms 6-7
Form Fields
6-8
DATABASE section. Each form specication le must begin with a DATABASE section identifying the database (if any) on which the
form is based. This can be any database that the current database server can access, including a remote database.
s
SCREEN section. The SCREEN section must appear next, showing the
dimensions and the exact layout of the logical elements of the form. You must specify the position of one or more screen elds for data entry or display as well as any additional text or ornamental characters.
s
TABLES section. If it is present, the TABLES section must follow the SCREEN section. This section lists every table or view that is referenced in the ATTRIBUTES section. If a table requires as a qualier the name of an owner or of a database, the TABLES section must also
ATTRIBUTES section. The ATTRIBUTES section describes each eld on the form and assigns names to elds. Field descriptions can optionally include eld attributes to specify, for example, the appearance, acceptable input values, on-screen comments, and default values for each eld. INSTRUCTIONS section. The INSTRUCTIONS section is optional. It can specify screen arrays and nondefault screen records and eld delimiters.
Each section must begin with the keyword for which it is named. After you create a form specication le, you must compile it. The form driver of your 4GL application can then use 4GL variables to transfer information between the database and the elds of the screen form.
DATABASE Section DATABASE FORMONLY DATABASE Section Database Reference p. 6-13 SCREEN Section SCREEN SIZE lines TABLES Section TABLES alias = Table Qualier p. 3-89 table END BY characters WITHOUT NULL INPUT
}
END
;
END
INSTRUCTIONS Section
INSTRUCTIONS
SCREEN RECORD
)
END
closing "
6-10
The next ve sections of this chapter identify the keywords and terms that are listed in this diagram and describe their syntax in detail. The following example illustrates the overall structure of a typical form specication:
DATABASE stores7 SCREEN { --------------------------------------------------------------------CUSTOMER INFORMATION: Customer Number: [c1 ] Telephone: [c10 ] ... SHIPPING INFORMATION: Customer P.O.: [o20 Ship Date: [o21 } TABLES customer orders items manufact ATTRIBUTES c1 = customer.customer_num = orders.customer_num; c10 = customer.phone, PICTURE = "###-###-####x#####"; ... o20 = orders.po_num; o21 = orders.ship_date; o22 = orders.paid_date; INSTRUCTIONS SCREEN RECORD sc_order[5] (orders.order_date THRU orders.paid_date)
In this example, the screen form has been designed to display columns from several tables in the stores7 demonstration database and includes all ve of the required and optional sections that are described in the pages that follow. This example is incomplete because it omits portions of the SCREEN and ATTRIBUTES sections that describe some of the screen elds. The ellipsis notation ( ) in those sections is a typographic device to simplify this illustration rather than a valid specication for the form.
DATABASE Section
DATABASE Section
The DATABASE section identies the database, if any, that contains tables or views whose columns are referenced in the form specication le.
DATABASE Section DATABASE FORMONLY database DATABASE Section Database Reference DATABASE Section Database Reference database database @server IDS SE WITHOUT NULL INPUT
"/ server / database " "/ pathname / database@server " "// server / pathname / database "
Description is the SQL identier of a database. is the path to the parent directory of the .dbs directory (for INFORMIX-SE databases only). is the name of the host system where database resides.
Usage
The DATABASE section is required, even if the screen form does not reference any database columns or tables. You can specify only one database. When compiling forms, 4GL uses the schema of tables from the specied database to dene the data types of elds in the form and obtains default values and attributes from the syscolval and syscolatt tables in the default database.
6-12 IBM Informix 4GL Reference Manual
The last format requires quotation marks. The next examples specify that columns or tables referenced in the TABLES, ATTRIBUTES, or INSTRUCTIONS section are in the stores7 database; the last two DATABASE section examples specify mammoth as the database server:
DATABASE stores7 DATABASE stores7@mammoth DATABASE "//mammoth/stores7"
For databases supported by the INFORMIX-SE database server, the following are all valid database reference formats:
database "/pathname/database@server" "//server/pathname/database"
Quotation marks around the last two formats are mandatory. Here pathname is a pathname to the directory that contains database, and server is the name of the host system where database resides. For INFORMIX-SE, the following DATABASE sections illustrate these formats:
DATABASE newdb DATABASE "/usr/projects/newdb@mammoth" DATABASE "//mammoth/usr/projects/newdb"
Compilation errors can result if FORMONLY appears in the DATABASE section of a form that also species features that depend on information from the system catalog or from the syscolval and syscolatt tables of a database. You can declare elds as FORMONLY in the ATTRIBUTES section, however, even if the DATABASE section species a database. The following features of 4GL forms depend on a database:
s s
The TABLES section Any eld associated with a database column in the ATTRIBUTES section Any FORMONLY eld declared LIKE a column in the ATTRIBUTES section
DISPLAY LIKE or VALIDATE LIKE attributes in the ATTRIBUTES
section
6-14
SCREEN Section
The use of WITHOUT NULL INPUT is discouraged. This specication was useful in 1981 for Informix 1.00 databases, which did not yet support the construct of null values. Current Informix databases can prevent null input by specifying a not-null constraint on individual columns through the CREATE TABLE or ALTER TABLE statements. If your application requires nonnull values in a eld corresponding to a database column, you can specify in the ATTRIBUTES section that the eld is FORMONLY and NOT NULL, as described in Field Attribute Syntax on page 6-33.
SCREEN Section
The SCREEN section of the form specication le species the vertical and horizontal dimensions of the physical screen and the position of one or more display elds and other information that will appear on the screen form. This section is required.
SCREEN SIZE lines BY characters
}
END
Description is a literal integer that species how many lines of characters (measured vertically) the form can display. The default is 24. is a literal integer that species how many characters (measured horizontally) a line can display. The default is the maximum number of characters in any line of the screen layout.
Usage
The SCREEN keyword is required. As in other sections of a form specication, the keyword END is optional. A single pair of braces ( { } ), immediately preceded and immediately followed by NEWLINE characters, must enclose the screen layout. You cannot use comment indicators in the SCREEN section.
For complete information on the form4gl command, see Compiling a Form at the Command Line on page 6-87. The portion of the SCREEN section between the braces is called the screen layout. This portion shows the geometric arrangement of the logical screen. If the SIZE clause or command line species dimensions that are too small for the screen layout, FORM4GL issues a compile-time warning, but it produces the compiled form that your form specication le described.
6-16
[ eld-tag ]
[ eld-tag
| eld-tag
character
Description is a 4GL identier of no more than 128 bytes within each eld. The length of a eld tag cannot exceed the eld width. is a printable character of text that will appear in the form.
Display Fields
Every 4GL form must include at least one eld where data can appear. Use brackets ( [ ] ) to delimit elds in the screen layout. Between delimiters, each eld must have an identifying eld tag. For more information, see Field Tags on page 6-18.
Field Delimiters
Each eld must be indicated by left and right delimiters to show the length of the eld and its position within the screen layout. Both delimiters must appear on the same line. Usually you use left and right brackets to delimit elds. However, to make two elds appear directly next to each other, you can use the pipe symbol (|) to indicate the end of the rst eld and the beginning of the second eld. For complete information on using a pipe symbol to delimit elds, see Field Delimiters on page 6-79.
Display Fields
Field Length
If you create a nondefault form, you normally should set the width of each display eld in the SCREEN section to be equal to the width of the program variable or the database column to which it corresponds. A eld to display numeric values should be large enough to contain the largest anticipated value. When a numeric eld is too small to display a data value, 4GL lls the eld with asterisk ( * ) symbols to indicate the overow. Fields to display character data can be shorter than the data length. 4GL lls the eld from the left and truncates from the right any string that is longer than its display eld. By using multiple-segment elds, you can display portions of a long character value in successive lines of the form. For more information, see Multiple-Segment Fields on page 6-31. In a default form specication le, the widths of all elds are determined by the data type of the corresponding columns in the database tables. (For more information, see Creating and Compiling a Form on page 6-85.) The section Default Forms on page 6-89 lists default eld widths for each data type. If you edit and modify the default form specication le or create a new le, you can verify that the eld widths match the data length requirements of the corresponding character columns when you compile the form. See also Compiling a Form at the Command Line on page 6-87.
Field Tags
Field tags must follow the rules for 4GL identiers (as described in 4GL Identiers on page 2-14). The rst character of a eld tag must be a letter or underscore ( _ ). Other characters can be any combination of letters, digits, and underscores. Because FORM4GL is not case sensitive, both a1 and Al represent the same eld tag. Field tags cannot be referenced in 4GL statements. The ATTRIBUTES section declares a eld name for each eld tag. Each eld has only one tag, but elds with the same tag can appear at more than one position in the SCREEN section in two special cases:
s
6-18
Otherwise, each eld tag must be unique within a form. Because a eld tag must t within the brackets that delimit its eld, you can give single-character elds the tags a through z. This designation implies that a form can include no more than 27 single-character elds in the default locale.
GLS
Locales for natural languages other than English might have different limits on the number of single-character elds within a single 4GL form.
In U.S. English locales, literal characters in the screen layout are restricted to ASCII characters, but in other locales you can include any other printable characters that the code set of the client locale supports. Text cannot overlap display elds, but the PICTURE attribute (described in Field Attribute Syntax on page 6-33) can specify literal characters within CHAR or VARCHAR elds.
The SCREEN section shown in Figure 6-2 appears in the orderform.per form specication le in the stores7 demonstration application. This example uses default screen dimensions (24 by 80) and textual information for eld labels, a screen title, and ornamental lines. (INSTRUCTIONS Section on page 6-74 describes how repeated eld tags are used in forms that dene screen arrays.)
Figure 6-2 Example of a Screen Section
SCREEN { --------------------------------------------------------------------------ORDER FORM --------------------------------------------------------------------------Customer Number:[f000 ] Contact Name:[f001 ][f002 ] Company Name:[f003 ] Address:[f004 ][f005 ] City:[f006 ] State:[a0] Zip Code:[f007 ] Telephone:[f008 ] --------------------------------------------------------------------------Order No:[f009 ] Order Date:[f010 ] Purchase Order No:[f011 ] Shipping Instructions:[f012 ] --------------------------------------------------------------------------Item No. Stock No. Code Description Quantity Price Total [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] Running Total including Tax and Shipping Charges:[f019 ] =========================================================================== } END
Important: The backslash ( \ ) is not valid as a text character; FORM4GL attempts to interpret it as the beginning of an escape sequence and does not print it. In addition, your form might not compile correctly if you attempt to use either braces ( { and } ) or the eld delimiter ( [, ], and | ) symbols as text characters in the screen layout. FORM4GL interprets any pound sign ( # ) or double-hyphens ( -- ) in the screen layout as literals, not as comment indicators.
6-20
Purpose Use p to mark the upper-left corner. Use q to mark the upper-right corner. Use b to mark the lower-left corner. Use d to mark the lower-right corner. Use hyphens to indicate horizontal line segments. Use pipe symbols to indicate vertical line segments.
The meanings of these six special characters are derived from the gb and acsc specications in the termcap and terminfo les, respectively. 4GL substitutes the corresponding graphics characters when you display the compiled form. Once the form has the desired conguration, use \g to indicate when to begin graphics mode and when to end graphics mode. Insert \g before the rst p, q, d, b, hyphen, or pipe symbol that represents a graphics character. To leave graphics mode, insert \g after the p, q, d, b, hyphen, or pipe symbol. FORM4GL exits from graphics mode automatically at the end of each screen line, regardless of whether the \g string terminates the line. This means that every line that requires graphics mode must start with the \g string, but does not necessarily need to end with it. Do not insert \g into original white space of a screen layout. The backslash should displace the rst graphics character in the line and push the remaining characters to the right. The process of indicating graphics distorts the appearance of a screen layout in the SCREEN section, compared to the corresponding display of the screen form. You can include other graphics characters in a form specication le, but the meaning of a character other than the p, q, d, b, hyphen, and pipe symbol is terminal dependent.
Screen Forms 6-21
To use graphics characters, the system termcap or terminfo le must include entries for specic variables. The following table shows what variables need to be set in the termcap le.
termcap Variable gs ge gb Description The escape sequence for entering graphics mode The escape sequence for leaving graphics mode The concatenated, ordered list of ASCII equivalents for the six graphics characters used to draw the border
The following table shows what variables need to be set in the terminfo le.
terminfo Variable smacs rmacs acsc Description The escape sequence for entering graphics mode The escape sequence for leaving graphics mode The concatenated, ordered list of ASCII equivalents for the six graphics characters used to draw the border
See Appendix F, Modifying termcap and terminfo, and the manual that comes with your terminal for information about making changes to your termcap or terminfo le to support these graphics characters.
6-22
TABLES Section
TABLES Section
The TABLES section lists the database tables that are referenced elsewhere in the form specication le. You must list in this section any table, view, or synonym that includes a column whose name is referenced in the form.
TABLES Section
table END
Description is the alias that replaces table in the form specication le. is the identier or synonym of a table or view in its database.
Usage
If the DATABASE section species FORMONLY, no TABLES section is needed unless you give a eld the VALIDATE LIKE or DISPLAY LIKE attribute in the ATTRIBUTES section or specify a FORMONLY eld LIKE a database column. Every database column referenced in the ATTRIBUTES section must be part of some table specied in the TABLES section. The table identier is the name listed in the tabname column of the systables catalog or else a synonym.
4GL allows you to specify up to 20 tables, but the actual limit on the number of tables, views, and synonyms that you can reference in a form depends on how your system is congured. The form specication le orderform.per in the demonstration application lists four tables:
TABLES customer orders items stock
The table identier cannot be a temporary table. If the form supports entry or update of data in a view, your 4GL application should test at runtime whether the view is updatable, especially if it is based on other views. The END keyword is optional.
Screen Forms 6-23
Table Aliases
Table Aliases
The TABLES section must declare an alias value for the identier of any table, view, or synonym that requires a table qualier (as described in Table Qualiers on page 3-89). Table qualiers can specify the owner of a table or a database (or database@server value) that is different from the database in the DATABASE section. In an ANSI-compliant database, for example, you must qualify any table name with the owner prex if the form will be used by anyone other than owner. You do not need to specify alias, unless the form will be used in an ANSIcompliant database by a user who did not create table, or if the form references a table, view, or synonym whose name is the same as another in the same database, so that the owner prex is required for an unambiguous reference. The alias can be the same identier as table. For example, stock can be the alias for stores7@naval:tom.stock. Except to assign an alias in the TABLES section, a form specication le cannot qualify the name of a table. If a qualier is needed, you must use an alias from the TABLES section to reference the table in other sections of the form specication le. Table aliases cannot exceed the 128-byte limit for 4GL identiers. The same alias must also appear in screen interaction statements of 4GL that reference screen elds linked to columns of a table that has an alias. Statements in 4GL programs or in other sections of the form specication le can reference screen elds as column, as alias. column, or as table. column, but they cannot specify owner. table. column. You cannot specify table. column as a eld name if you dene a different alias for table. The following TABLES section species aliases for two tables:
TABLES tab1 tab2 = = libdpt.booktab athdpt.balltab
6-24
ATTRIBUTES Section
ATTRIBUTES Section
The ATTRIBUTES section species a eld description that associates an identier and a data type with every eld in the SCREEN section. You can also control the behavior and appearance of each eld by using eld attributes to describe how 4GL should display the eld, supply a default value, limit the values that can be entered, or set other parameters. For information on eld attributes, see Field Attribute Syntax on page 6-33. The ATTRIBUTES section has the following syntax.
eld-tag =
; Field Description
END
, ,
attribute
, ,
attribute
Description species one of the eld attribute listed on page 6-32. is the unqualied SQL identier of a database column. is any 4GL data type specication except ARRAY or RECORD. is an identier that you assign to a FORMONLY eld (a eld that is not associated here with any database column). is the eld tag, as declared in the SCREEN section. is the name or alias of a table, synonym, or view, as declared in the TABLES section.
ATTRIBUTES Section
Usage
The ATTRIBUTES section must describe every eld-tag value from the SCREEN section. The order in which you list the eld tags determines the order of elds in the default screen records that 4GL creates for each table. (INSTRUCTIONS Section on page 6-74 describes screen records.) The tables specication is not required unless several columns in different tables have the same name or the table is an external table. The END keyword is optional. It is supported to provide compatibility with form specication les for earlier versions of Informix products. You can specify two kinds of eld descriptions: those that associate a eld tag with the data type and with the default attributes of a database column and those that link eld tags to FORMONLY elds.
6-26
ATTRIBUTES Section
This is the syntax for specifying the attributes of a screen eld that is linked to a column of a database.
eld-tag = table . column
, ,
attribute
Description is a string of keywords, identiers, and symbols that specify a eld attribute, as listed in Field Attributes on page 6-32. is the unqualied SQL identier of a database column. This variable can also appear in 4GL statements that reference the eld. is the eld tag, as declared in the SCREEN section. is the name or alias of a database table, synonym, or view, as declared in the TABLES section. Qualiers are not allowed.
Usage
Although you must include an ATTRIBUTES section that assigns at least one name to every eld-tag value from the SCREEN section, you are not required to specify any eld attributes. You are not required to specify table unless the name column is not unique within the form specication, or if table is external to the database that the DATABASE section species. However, Informix recommends that you always specify table.column rather than the unqualied column name. If there is ambiguity, FORM4GL issues an error during compilation. Because you can refer to eld names collectively through a screen record built upon all the elds linked to the same table, your forms might be easier to work with if you specify table for each eld. For more information about declaring screen records, see INSTRUCTIONS Section on page 6-74. A screen eld can display a portion of a character string if you use subscripts in the column specication. Subscripts are a pair of comma-separated integers in brackets ( [ ] ) that indicate starting and ending character positions within a string value. But if you specify in the ATTRIBUTES section that two elds are linked to the same character column in the database, you cannot associate each eld with a different substring of the same column.
Screen Forms 6-27
ATTRIBUTES Section
The ATTRIBUTES section in the following le lists elds linked to columns in the customer table. The UPSHIFT and PICTURE attributes that are assigned here are described later in this chapter.
DATABASE stores7 SCREEN { Customer Name:[f000 Address:[f002 City:[f004 Telephone:[f006 } TABLES customer
ATTRIBUTES f000 = customer.fname; f001 = customer.lname; f002 = customer.address1; f003 = customer.address2; f004 = customer.city; a0 = customer.state, UPSHIFT; f005 = customer.zipcode; f006 = customer.phone, PICTURE = "###-###-#### XXXXX";
Values from a column of data type BYTE are never displayed in a form; the words <BYTE value> are shown in the corresponding display eld to indicate that the user cannot see the BYTE data. The following excerpt from a form specication le shows a TEXT eld resume and a BYTE eld photo. In this example, the BYTE eld is short because only the words <BYTE value> are displayed. Similarly, you do not need to include more than one line in a form for a TEXT eld. (The PROGRAM attribute that can display TEXT or BYTE values is described in PROGRAM on page 6-60.)
resume [f003 photo [f004 ] . . . attributes f003 = employee.resume; f004 = employee.photo; ]
6-28
FORMONLY Fields
FORMONLY Fields
FORMONLY elds are not associated with columns of any database table or
view. They can be used to enter or display the values of program variables. If the DATABASE section species FORMONLY, this is the only kind of eld description that you can specify in the ATTRIBUTES section.
eld-tag = FORMONLY . eld name Field Description p. 6-25
Description is an identier that you assign to a FORMONLY eld. This identier can also appear in 4GL statements that reference the eld. is the eld tag, as declared in the SCREEN section.
Usage
Like other 4GL identiers, eld name cannot begin with a number. It can have up to 128 bytes, including letters, numbers, and underscore ( _ ) symbols. If you specify one or more FORMONLY elds, 4GL behaves as if they formed a database table named formonly, with the eld names as column names. The following elds are examples of FORMONLY elds:
f021 = FORMONLY.manu_name; f022 = FORMONLY.unit_price TYPE MONEY, COLOR = GREEN; f023 = FORMONLY.unit_descr TYPE LIKE orders.unit_descr; f024 = FORMONLY.order_placed TYPE DATETIME YEAR TO HOUR NOT NULL, DEFAULT = CURRENT;
FORMONLY Fields
If you do not specify any data type, FORM4GL treats the eld as type CHAR by default. Do not assign a length to CHAR, DECIMAL, and MONEY elds because eld length is determined by the display width in the SCREEN section. For example, the demonstration application uses the following FORMONLY eld to store the running total price for the order as items are entered:
f019 = FORMONLY.t_price;
You are required to specify a data type only if you also specify an INCLUDE or DEFAULT attribute for this eld. 4GL performs any necessary data type conversion for the corresponding program variable during input or display. 4GL evaluates the LIKE clause at compile time, not at runtime. If the database schema changes, you might need to recompile a program that uses the LIKE clause to describe a FORMONLY eld in a form specication le. Like a eld linked to a database column, a FORMONLY eld cannot display a BYTE value directly. The form displays the string <BYTE value> to indicate that the user cannot see the BYTE value. Similarly, you need not allocate more than one line on a form for a FORMONLY eld of data type TEXT. You can assign the PROGRAM attribute to a FORMONLY eld to display TEXT or BYTE values from 4GL variables.
6-30
Multiple-Segment Fields
Multiple-Segment Fields
If you need the form to support entry or display of long character strings, you can specify multiple-segment elds that occupy several lines of the form. To create a multiple-segment eld, repeat the same eld tag in different elds of the layout in the SCREEN section, typically on successive lines.
WORDWRAP Fields
For a multiple-segment eld to enter or display long character strings in successive lines of the form, you must also specify the WORDWRAP attribute for that eld tag in the ATTRIBUTES section. During input and display, 4GL treats all segments that have that eld tag as segments of a single eld. The following example shows only the SCREEN and ATTRIBUTES sections of a form specication le that species a multiple-segment eld:
SCREEN SIZE 24 BY 80 { title: [title author: [author ] synopsis: [synopsis [synopsis [synopsis [synopsis [synopsis } . . . ATTRIBUTES title = booktab.title; author = booktab.author; synopsis = booktab.synopsis, WORDWRAP COMPRESS;
] ] ] ] ] ]
Here the screen eld whose tag is synopsis appears in ve physical segments in the screen layout and has the WORDWRAP attribute. Its value is composed of the physical segments, taken in top-to-bottom, left-to-right order. The eld should ordinarily be as long or longer than the program variable or database column that it displays, so it can display all of the text. Users of your 4GL application program might expect all segments to be the same size and to be laid out in vertical alignment, as in the example, but that is not required. Your form is likely to be easier to use, however, if multiple-segment elds are compact and symmetrical.
Field Attributes
In the description of the eld in the last line of the ATTRIBUTES section of the previous example, the keyword WORDWRAP enables a multiple-line editor when the form is open and the cursor enters the eld. If you omit it, words cannot ow from segment to segment of the eld, and users must move the cursor from eld to eld with arrow keys or RETURN to edit values in the form. (For more information about the multiple-line editor and about the COMPRESS keyword, see WORDWRAP on page 6-67.)
Subscripted Fields
FORM4GL can create a default form specication that references a database
column of a character data type whose declared length in bytes is greater than (characters - 22), where characters is the width of the form. For such columns, FORM4GL generates two or more elds in the default specication (each with a different eld tag but with the same eld name) whose total length is the declared length of the corresponding database column. In the ATTRIBUTES section of the default specication, the name of each such eld is immediately followed (in brackets) by an ordered pair of commaseparated literal integers that identify the rst and last of the bytes in the database column that the eld displays. For example:
c3 = engineer.code[1,56]; c4 = engineer.code[57,112];
These are called subscripted elds, and they are generated for backward compatibility with the PERFORM forms compiler. Statements of 4GL that enter or display data in screen forms (CONSTRUCT, INPUT, and INPUT ARRAY) are difcult to use with subscripted 4GL elds beyond the rst eld. Use a text editor to change such elds to segmented WORDWRAP elds.
Field Attributes
FORM4GL recognizes the following eld attributes. AUTONEXT CENTURY COLOR COMMENTS DEFAULT DISPLAY LIKE DOWNSHIFT FORMAT INCLUDE INVISIBLE NOENTRY PICTURE PROGRAM REQUIRED REVERSE UPSHIFT VALIDATE LIKE VERIFY WORDWRAP
6-32
The following table summarizes the effects of these eld attributes, which are individually described in the sections that follow.
Attribute AUTONEXT CENTURY COLOR COMMENTS DEFAULT DISPLAY LIKE DOWNSHIFT FORMAT INCLUDE INVISIBLE NOENTRY PICTURE PROGRAM REQUIRED REVERSE UPSHIFT VALIDATE LIKE VERIFY WORDWRAP Effect Causes the cursor to advance automatically to the next eld Species expansion of 2-digit years in DATE and DATETIME elds Species the color or intensity of values displayed in a eld Species a message to display on the Comment line Assigns a default value to a eld during data entry Assigns attributes from syscolatt table that the upscol utility creates, associating attributes with specic database columns Converts to lowercase any uppercase character data Formats DECIMAL, SMALLFLOAT, FLOAT, or DATE output Lists a set of acceptable values during data entry Does not echo characters on the screen during data entry Prevents the user from entering data in the eld Imposes a data-entry format on CHAR or VARCHAR elds Invokes an external program to display TEXT or BYTE values Requires the user to supply some value during data entry Causes values in the eld to be displayed in reverse video Converts to uppercase any lowercase character data Validates data entry with the syscolval table that the upscol utility creates, associating default values with specic database columns Requires that data be entered twice when the database is modied Invokes a multiple-line editor in multiple-segment elds
AUTONEXT
AUTONEXT
The AUTONEXT attribute causes the cursor to advance automatically during input to the next eld when the current eld is full.
AUTONEXT
Usage
You specify the order of elds in each INPUT or INPUT ARRAY statement. If the most recent OPTIONS statement species INPUT WRAP, the next eld after the last eld is the rst eld.
AUTONEXT is particularly useful with character elds in which the input
data is of a standard length, such as numeric postal codes or the abbreviations in the state table. It is also useful if a character eld has a length of 1 because only one keystroke is required to enter data and move to the next eld. If data values entered in the eld do not meet requirements of other eld attributes like INCLUDE or PICTURE, the cursor does not automatically move to the next eld but remains in the current eld, with an error message. The demonstration application uses the customer form to enter all the names and addresses of the customers. The following excerpt from the ATTRIBUTES section of the customer form uses the AUTONEXT attribute:
a0 = customer.state, DEFAULT = "CA", AUTONEXT; f007 = customer.zipcode, AUTONEXT; f008 = customer.phone;
When two characters are entered into the customer.state eld (thus lling the eld), the cursor moves automatically to the beginning of the next screen eld (the customer.zipcode eld). When ve characters are entered into the customer.zipcode eld (lling this eld), the cursor moves automatically to the beginning of the next eld (the customer.phone eld).
6-34
CENTURY
CENTURY
The CENTURY attribute species how to expand abbreviated one- and twodigit year specications in a DATE and DATETIME eld. Expansion is based on this setting (and on the year value from the system clock at runtime).
CENTURY
In most versions of 4GL earlier than 7.20, if the user enters only the two trailing digits of a year for literal DATE or DATETIME values, these digits are automatically prexed with the digits 19. For example, 12/31/02 is always expanded to 12/31/1902 regardless of when the program is executed.
CENTURY can specify any of four algorithms to expand abbreviated years
into four-digit year values that end with the same digits (or digit) that the user entered. CENTURY supports the same settings as the DBCENTURY environment variable but with a scope that is restricted to a single eld.
Symbol
C or c F or f P or p R or r
Algorithm for Expanding Abbreviated Years Use the past, future, or current year closest to the current date. Use the nearest year in the future to expand the entered value. Use the nearest year in the past to expand the entered value. Prex the entered value with the rst two digits of the current year.
Here past, closest, current, and future are all relative to the system clock. Unlike DBCENTURY, which sets a global rule for expanding abbreviated year values in DATE and DATETIME elds that do not have the CENTURY attribute, CENTURY is not case sensitive; you can substitute lowercase letters ( r, c, f, p) for these uppercase letters. If you specify anything else, an error (-2018) is issued. If the CENTURY and DBCENTURY settings are different, CENTURY takes precedence.
Screen Forms 6-35
CENTURY
Three-digit years are not expanded. A single-digit year is rst expanded to two digits by prexing it with a zero; CENTURY then expands this value to four digits, according to the setting that you specied. Years between 1 and 99 AD (or CE) require leading zeros (to avoid expansion). Just as with DBCENTURY, expansion of abbreviated years is sensitive to time of execution and to the accuracy of the system clock-calendar. For examples of the effects of the different CENTURY settings on abbreviated year values, see DBCENTURY on page D-15. (Those examples are for DBCENTURY, but except for case-sensitivity, DBCENTURY and CENTURY have the same semantics.) Important: The CENTURY attribute has no effect on DATETIME elds that do not include YEAR as the rst time unit nor on elds that are not DATE or DATETIME elds. If an abbreviated year value is entered in a character eld or a number eld, for example, neither CENTURY nor DBCENTURY has any effect. The ATTRIBUTES clause that can follow the FOR clause of the PROMPT statement can also specify CENTURY as an attribute, using this syntax.
||
,
PROMPT variable FOR ATTRIBUTE Clause p. 3-96 response
"string "
CHAR
HELP number
ATTRIBUTE ( CENTURY
)
ON KEY Clause p. 4-325 END PROMPT
Here response must be a DATE or DATETIME variable for CENTURY to be useful. This diagram is simplied, in that any FORATTRIBUTE clause of PROMPT that species CENTURY can also specify other display attributes, as listed in ATTRIBUTE Clause on page 3-96. The setting is not case sensitive but must be enclosed within quotation marks. See PROMPT on page 4-325 for descriptions of syntax terms that appear in this diagram.
6-36 IBM Informix 4GL Reference Manual
COLOR
COLOR
The COLOR attribute displays eld text in a color or with other video attributes, either unconditionally or only if a Boolean expression is TRUE.
COLOR =
Element attribute
Description is one of the keywords to specify a color or an intensity. You can specify zero or one color keyword and zero or more intensity keywords. The color keywords include BLACK, BLUE, CYAN, GREEN, MAGENTA, RED, WHITE, and YELLOW. The intensity keywords include REVERSE, LEFT, BLINK, and UNDERLINE.
Important: If you are using terminfo, the only color or intensities available are REVERSE and UNDERLINE.
Usage
If you do not use the WHERE keyword to specify a 4GL Boolean expression, the intensity or color in your display mode list applies to the eld. This example species unconditionally that eld text appears in red:
f000 = customer.customer_num, COLOR = RED LEFT;
COLOR
4GL Expression (Subset) p. 3-49 eld-tag TRUE FALSE eld-tag AND 4GL Expression (Subset) p. 3-49
,
IN ( 4GL Expression (Subset) p. 3-49 eld-tag
"
ESCAPE "char"
Description is a single character, enclosed between a pair of single ( ' ) or double ( " ) quotation marks. is one or more literal or special characters, enclosed between two single or double quotation marks. is the eld tag (as described in Field Tags on page 6-18) of the current eld.
6-38
COLOR
In this diagram, terms for other 4GL expressions are restricted subsets. Except for the constants TRUE and FALSE, you cannot reference the name of a program variable in the WHERE clause of a COLOR attribute specication. You can, however, include a eld-tag or a literal value wherever the name of a variable can appear in a 4GL expression that is a component of the 4GL Boolean expression, as described in Expressions of 4GL on page 3-49. If any component of a 4GL Boolean expression is null, the value of the entire 4GL Boolean expression is FALSE (rather than null), unless the IS NULL operator is also included in the expression. As in other Boolean expressions of 4GL, applying the NOT operator to a null value does not change its FALSE evaluation. The conditional attribute is displayed only if the overall condition is true. In the following example, the value of the expression is FALSE if a NULL value appears in the display eld whose eld tag is f004:
3.1415265 * f004 < 25000
If you include a eld-tag value in a 4GL Boolean expression when you specify a conditional COLOR attribute, 4GL replaces eld-tag at runtime with the current value in the screen eld and evaluates the expression. If eld-tag references a eld that is linked to a database column of data type TEXT or BYTE or to a FORMONLY eld of either of those two data types, only the IS NOT NULL or IS NULL keywords can include that eld tag in an expression. The specied color or intensity is applied to the <BYTE value> message, not to the BYTE data value because only the PROGRAM attribute can display a BYTE value. Values of the TEXT data type are displayed in the eld, beginning with the rst printable data character. If the TEXT value is too large to t in the eld, characters beyond what the eld can hold are not displayed.
COLOR
The WHERE clause of a COLOR eld description can also use the IN operator to specify a comma-separated list (enclosed between parentheses) of values with which to compare the eld tag or expression. Set Membership and Range Tests on page 5-40 describes the syntax of the BETWEENAND and IN Boolean operators in conditional COLOR specications for 4GL forms. See also the Informix Guide to SQL: Reference for the complete syntax of Boolean expressions in SQL statements.
If the value is a non-zero real number (or a character string representing a non-zero number) or a non-zero INTERVAL, or any DATE or DATETIME value, the 4GL Boolean value is TRUE. If the value is null, and the IS NULL keywords are also included in the expression, the value of the 4GL Boolean expression is TRUE. Otherwise, the 4GL Boolean expression is FALSE.
6-40
COLOR
The following table shows the effects of the intensity attribute keywords on a color terminal.
Attribute NORMAL BOLD DIM Display White Red Blue
The LEFT attribute produces a left-aligned display in a screen eld of any number data type. It has no effect on elds of other data types. (Without the COLOR = LEFT specication, number values are right-aligned by default.) The next lines specify display attributes if Boolean expressions are TRUE:
f001 f002 f003 f004 f005 = = = = = FORMONLY.late, COLOR = RED BLINK WHERE f001 < TODAY; manufact.manu_code, COLOR = RED WHERE f002 = "HRO"; customer.lname, COLOR = RED WHERE f003 LIKE "Quinn"; mytab.col6, COLOR = GREEN WHERE f004 < 10000; mytab.col9, COLOR = BLUE REVERSE WHERE f005 IS NULL, COLOR = YELLOW WHERE f005 BETWEEN 5000 AND 10000, COLOR = GREEN BLINK WHERE f005 > 10000;
COLOR
The following expression is TRUE if the eld f022 does not include the underscore character:
NOT f022 LIKE "%z_%" ESCAPE "z"
Related Attributes
DISPLAY LIKE, INVISIBLE, REVERSE
6-42
COMMENTS
COMMENTS
The COMMENTS attribute displays a message on the Comment line at the bottom of the window. The message is displayed when the cursor moves to the specied eld and is erased when the cursor moves to another eld.
COMMENTS
= "message "
Element message
Usage
The message string must appear between quotation marks ( " ) on a single line of the form specication le. In the following example, the eld description species a message for the Comment line to display. The message appears when the screen cursor enters the eld that is linked to the fname column of the customer table. In the stores7 database, this column contains the rst name of a customer:
c2 = customer.fname, comments = "Please enter initial if available.";
The most common application of the COMMENTS attribute is to give information or instructions to the user. This application is particularly appropriate when the eld accepts only a limited set of values. (For details of how to specify a range or a list of acceptable values for data entry, see INCLUDE on page 6-53.)
4GL programs can use the same screen form to support several distinct tasks
(for example, data input and query by example). Do not specify the COMMENTS attribute in a eld description unless message is appropriate to all of the tasks in which message can appear. If the same eld requires a different message for different tasks, specify each message using MESSAGE or DISPLAY statements rather than in the form specication le.
COMMENTS
Related Attribute
INCLUDE
6-44
DEFAULT
DEFAULT
The DEFAULT attribute assigns a default value to a eld during data entry.
DEFAULT = value
Element value
Description is a default value for the eld. This restricted expression cannot reference any variable or programmer-dened function.
Usage
Default values have no effect when you execute the INPUT statement by using the WITHOUT DEFAULTS option. In this case, 4GL displays the values in the program variables list on the screen. The situation is the same for the INPUT ARRAY statement except that 4GL displays the default values when the user inserts a new row. If the eld is FORMONLY, you must also specify a data type when you assign the DEFAULT attribute to a eld. (See FORMONLY Fields on page 6-29.) If both the DEFAULT attribute and the REQUIRED attribute are assigned to the same eld, the REQUIRED attribute is ignored. If you do not use the WITHOUT NULL INPUT option in the DATABASE section, all elds default to null values unless you use the DEFAULT attribute. If you use the WITHOUT NULL INPUT option in the DATABASE section and you do not use the DEFAULT attribute, character elds default to blanks, number and INTERVAL elds to 0, and MONEY elds to $0.00. The default DATE value is 12/31/1899. The default DATETIME value is 1899-12-31 23:59:59.99999. You cannot assign the DEFAULT attribute to elds of data type TEXT or BYTE.
DEFAULT
Literal Values
The value can be a quoted string, a literal number, a literal DATE value, a literal DATETIME value, or a literal INTERVAL value. These values are described in Chapter 3. Or the value can be a built-in function or operator that returns a single value of a data type compatible with that of the eld. For details, see Syntax of Built-In Functions and Operators on page 5-13. If you include in the value list a character string that contains a blank space, a comma, or any special characters, or a string that does not begin with a letter, you must enclose the entire string in quotation marks. (If you omit the quotation marks, any uppercase letters are down-shifted.) For a DATE eld, you must enclose any literal value in quotation marks ( " ). For a DATETIME or INTERVAL eld, you can enclose value in quotation marks, or you can enter it as an unquoted literal, as in the following examples:
DATETIME (2012-12) YEAR TO MONTH INTERVAL (10:12) HOUR TO MINUTE - INTERVAL (28735) DAY TO DAY
For more information, see DATETIME Qualier on page 3-76 and INTERVAL Literal on page 3-82.
Here integer can be a positive or negative literal integer (as described in Literal Integers on page 3-65) or an expression in parentheses that evaluates to an integer, and time-unit is a keyword from an INTERVAL qualier, such as MONTH, DAY, HOUR. (This qualier must be consistent with the explicit or implied data type declaration of the eld; do not, for example, specify YEAR or MONTH as the time-unit value for a DAY TO FRACTION eld.)
6-46
DEFAULT
Use the TODAY operator as value to assign the current date as the default value of a DATE eld. Use the CURRENT operator as value to assign the current date and time as the default for a DATETIME eld. (4GL does not assign these values automatically as defaults, so you must specify them explicitly.) These expressions are evaluated at runtime, not at compile time. The following eld descriptions specify DEFAULT values:
c8 = state, UPSHIFT, AUTONEXT, DEFAULT = "CA"; o12 = order_date, DEFAULT = TODAY; f019 = FORMONLY.timestamp TYPE DATETIME YEAR TO DAY COLOR = RED, DEFAULT = CURRENT;
Related Attributes
INCLUDE, REQUIRED, VALIDATE LIKE
DISPLAY LIKE
DISPLAY LIKE
The DISPLAY LIKE attribute takes attributes that the upscol utility assigned to a specied column in the syscolatt table and applies them to a eld.
DISPLAY LIKE table . column
Element table
Description is the unqualied name or alias of a database table, synonym, or view, as declared in the TABLES section. (This value is not required unless several columns in different tables have the same name or if the table is an external table or an external, distributed table.) is the name of a column in table or (if you omit table) the unique identier of a column in one of the tables that you declared in the TABLES section. The column cannot be of data type BYTE.
column
Usage
Specifying this attribute is equivalent to listing all the attributes that are assigned to table.column in the syscolatt table. (Default Attributes on page 6-80 describes the syscolatt table. See also the description of the upscol utility in Appendix B.) You do not need to specify the DISPLAY LIKE attribute if the eld is linked to table.column in the eld name specication. The following example instructs 4GL to apply the default display attributes of the items.total_price column to a FORMONLY eld:
s12 = FORMONLY.total, DISPLAY LIKE items.total_price;
4GL evaluates the LIKE clause at compile time, not at runtime. If the database schema changes, you might need to recompile a program that uses the LIKE clause. Even if all of the elds in the form are FORMONLY, this attribute requires FORM4GL to access the database that contains table.
Related Attribute
VALIDATE LIKE
6-48
DOWNSHIFT
DOWNSHIFT
Assign the DOWNSHIFT attribute to a character eld when you want 4GL to convert uppercase letters entered by the user to lowercase letters, both on the screen and in the corresponding program variable.
DOWN SHIFT
Usage
Because uppercase and lowercase letters have different values, storing character strings in one or the other format can simplify sorting and querying a database. By specifying the DOWNSHIFT attribute, you instruct 4GL to convert character input data to lowercase letters in the program variable. The maximum length of a character value to which you can apply the DOWNSHIFT attribute is 511 bytes.
GLS
The results of conversion between uppercase and lowercase letters are based on the locale les, which specify the relationship between corresponding pairs of uppercase and lowercase letters. If the locale les do not provide this information, no case conversion occurs.
Related Attribute
UPSHIFT
FORMAT
FORMAT
You can use the FORMAT attribute with a DECIMAL, SMALLFLOAT, FLOAT, or DATE eld to control the format of output displays.
FORMAT
"format-string "
Element format-string
Description is a string of characters that species a data display format. You must enclose format-string within quotation marks ( " ).
Usage
This attribute can format data that the application displays in the eld. (Use the PICTURE attribute to format data entered in the eld by the user.) 4GL right-aligns the data in the eld. If format-string is smaller than the eld width, FORM4GL issues a compile-time warning, but the form is usable.
The NUMERIC setting in the locale les affects how format-string is interpreted for numeric data. In the format string, the period symbol ( . ) is not a literal character but a placeholder for the decimal separator specied by environment variables or by locale le settings. Likewise, the comma ( , ) is a placeholder for the thousands separator specied by environment variables. Thus, the format string #,###.## formats the value 1234.56 as 1,234.56 in a U.S. English locale but as 1.234,56 in a German locale.
IBM Informix 4GL Reference Manual
6-50
FORMAT
Produces a three-letter English-language abbreviation of the month; for example, Jan, Feb Produces the two-digit representation of the day of the month Produces a three-letter English language abbreviation of the day of the week; for example, Mon, Tue Produces the two-digit representation of the year, discarding the leading digits; for example, the year 2003 would appear as 03 Produces a four-digit representation of the year
For DATE elds, FORM4GL interprets any other characters as literals and displays them wherever you place them within format-string. These format-string examples and their corresponding display formats for
DATE elds display the twenty-third day of September 1999. Input no FORMAT attribute
FORMAT = "mm/dd/yy" FORMAT = "mmm dd, yyyy" FORMAT = "yymmdd" FORMAT = "dd-mm-yy" FORMAT = "(ddd.) mmm. dd, yyyy"
Result 09/23/1999 09/23/99 Sep 23, 1999 990923 23-09-99 (Thu.) Sep. 23, 1999
FORMAT
GLS
The mmm and ddd speciers in a format string can display language-specic month name and day name abbreviations. This operation requires installing message les in a subdirectory of $INFORMIXDIR/msg and subsequent reference to that subdirectory by way of the environment variable DBLANG. For example, in a Spanish locale, the ddd specier translates the day Saturday into the day name abbreviation Sab, which stands for Sabado (the Spanish word for Saturday). For more information on GLS, see Appendix E, Developing Applications with Global Language Support.
Related Attribute
PICTURE
6-52
INCLUDE
INCLUDE
The INCLUDE attribute species acceptable values for a eld and causes 4GL to check at runtime before accepting an input value. ,
INCLUDE = ( value TO value NULL
Element value
Description is an element in a comma-separated list (within parentheses) of values (value1, value2, ), a range of values (value1 TO value2), or any combination of individual values and ranges.
Usage
Each value specication is a restricted expression that cannot include the name of any 4GL variable or programmer-dened function. It can include literal values (as described inExpressions of 4GL on page 3-49 ), built-in functions, operators (as described in Syntax of Built-In Functions and Operators on page 5-13), and the constants TRUE, FALSE, and NOTFOUND. The same rules for DEFAULT attribute values also apply to INCLUDE values. TEXT and BYTE elds cannot have the INCLUDE attribute. If a eld has the INCLUDE attribute, the user must enter an acceptable value (from the value list) before 4GL accepts a new row. If the value list does not include the default value, the INCLUDE attribute behaves like the REQUIRED attribute, and an acceptable entry is required. Include the NULL keyword in the value list to specify that it is acceptable for the user to press RETURN without entering any value.
f006 = survey.item06, INCLUDE = (NULL, "YES", "NO");
In this example, the NULL keyword allows the user to enter nothing. You cannot accomplish the same thing by substituting a string of blanks for the NULL keyword in the INCLUDE specication because for most data types a null value is different from ASCII 32, the blank character.
Screen Forms 6-53
INCLUDE
Including a COMMENTS attribute for the same eld to describe acceptable values makes data entry easier because you can display a message to advise the user of whatever restrictions you have imposed on data entry:
i18 = items.quantity, INCLUDE = (1 TO 50), COMMENTS = "Acceptable values are 1 through 50";
If you include in the value list a character string that contains a blank space, a comma, or any special characters or a string that does not begin with a letter, you must enclose the entire string in quotation marks ( " ). (If you omit the quotation marks, any uppercase letters are down-shifted.)
Ranges of Values
You can use the TO keyword to specify an inclusive range of acceptable values. For example, ranges in the following eld description include the postal abbreviations for the names of the contiguous states of the United States:
i20 = customer.state, INCLUDE = (NULL, "AL" TO "GA", "IA" TO "WY"), COMMENTS = "No Alaska (AK) or Hawaii (HI) addresses here.";
When you specify a range of values, the lower value must appear rst. The meaning of lower depends on the data type of the eld:
s
For number or INTERVAL elds, it is the larger (or only) negative value, or (if neither value is negative) the value closer to zero. For other time elds, it is the earlier DATE or DATETIME value. For character elds, the lower value is the string that starts with a character closer to the beginning of the collating sequence. (See Appendix A for a listing of the ASCII collating sequence, which U.S. English locales use.) For nondefault locales, the code-set order is used as the collating sequence.
s s
GLS
In a number eld, for example, the range "5 TO 10" is valid. In a character eld, however, it produces a compile-time error. (In the default locale, for example, the character string "10" is less than "5" because 1 comes before 5 in the ASCII collating sequence.)
6-54
INCLUDE
FORMONLY Fields
You must specify a data type when you assign the INCLUDE attribute to a FORMONLY eld (as described in FORMONLY Fields on page 6-29). The TYPE clause is required in the following example:
f006 = FORMONLY.item07 TYPE CHAR(*), INCLUDE = (NULL, "PERHAPS", "MAYBE");
Related Attributes
COMMENTS, DEFAULT, REQUIRED
INVISIBLE
INVISIBLE
The INVISIBLE attribute prevents user-entered data from being echoed on the screen during a CONSTRUCT, INPUT, INPUT ARRAY, or PROMPT statement.
INVISIBLE
Usage
Characters that the user enters in a eld with this attribute are not displayed during data entry, but the cursor moves through the eld as the user types. No other aspects of data entry are affected by the INVISIBLE attribute. The following example illustrates the use of the INVISIBLE attribute:
i001 = FORMONLY.secret_password TYPE LIKE state.sname, INVISIBLE, COMMENTS = "Enter your secret password.";
If you specify INVISIBLE and any other display attribute for a eld, 4GL ignores the INVISIBLE attribute. By default, the ERROR statement displays messages in REVERSE. If you specify the INVISIBLE attribute, ERROR displays its message in NORMAL. The INVISIBLE attribute has no effect on editing BYTE or TEXT elds. This attribute does not prevent a DISPLAY, DISPLAY ARRAY, DISPLAY FORM, MESSAGE, or OPEN WINDOW statement from displaying data in the eld. Specify the INVISIBLE attribute, rather than COLOR = BLACK, if you do not want the eld to display what the user types during data entry. (The BLACK color attribute displays black characters on a color terminal and displays as DIM on a monochrome terminal.)
Related Attribute
COLOR
6-56
NOENTRY
NOENTRY
The NOENTRY attribute prevents data entry in the eld during an INPUT or INPUT ARRAY statement.
NOENTRY
Usage
The following example illustrates the use of the NOENTRY attribute:
i13 = stock.stock_num, NOENTRY;
When the user enters data in the stock table, the stock_num column is not available because this SERIAL column gets its value from the database server during the INSERT statement. The NOENTRY attribute does not prevent data entry into a eld during a CONSTRUCT statement (for a query by example).
Related Attribute
INVISIBLE
PICTURE
PICTURE
The PICTURE attribute species a character pattern for data entry in a text eld and prevents entry of values that conict with the specied pattern.
PICTURE = "format-string "
Element format-string
Description is a string of characters to specify a character pattern for data entry. This string must be enclosed within quotation marks ( " ).
Usage
A format-string value can include literals and these three special symbols.
Symbol
A # X
4GL treats any other character in format-string as a literal. The cursor skips over any literals during data entry. 4GL displays the literal characters in the
display eld and leaves blanks elsewhere. For example, note the following eld specication:
c10 = customer.phone, picture = "###-###-####x#####";
If the user attempts to enter a character that conicts with format-string, the terminal beeps, and 4GL does not echo the character on the screen.
6-58
PICTURE
The format-string value must ll the entire width of the display eld. The PICTURE attribute, however, does not require data entry into the entire eld. It only requires that whatever characters are entered conform to format-string. When PICTURE species input formats for DATETIME or INTERVAL elds, FORM4GL does not check the syntax of format-string, but your form will work if the syntax is correct. Any error in format-string, however, such as an incorrect eld separator, produces a runtime error. As another example, suppose you specify a eld for part numbers like this:
f1 = part_no, picture = "AA#####-AA(X)";
The user does not enter the hyphen or the parentheses, but 4GL includes them in the string that it passes to the program variable.
GLS
The PICTURE attribute is not affected by GLS environment variables because it only formats character information.
Related Attribute
FORMAT
PROGRAM
PROGRAM
The PROGRAM attribute can specify an external application program to work with screen elds of data type TEXT or BYTE.
PROGRAM = "command "
Element command
Description is a command string (or the name of a shell script) that invokes an editing program, enclosed within quotation marks.
Usage
You can assign the PROGRAM attribute to a BYTE or TEXT eld to call an external program to work with the BYTE or TEXT values. Users can invoke the external program by pressing the exclamation point ( ! ) key while the screen cursor is in a BYTE or TEXT eld. The external program then takes over control of the screen. When the user exits from the external program, the form is redisplayed with any display attributes besides PROGRAM in effect. For example, this eld description designates vi as the external editor of a multiple-segment TEXT eld that also has the WORDWRAP attribute:
f010 = personnel.resume, WORDWRAP, PROGRAM = "vi";
Here the WORDWRAP attribute (described in WORDWRAP on page 6-67) species that as much of the TEXT value as possible be displayed in successive segments of the multiple-segment eld when the form displays a value in the eld, but the WORDWRAP editor cannot edit a TEXT value. If the cursor enters the eld whose tag is f010 in the same example and presses the ! key, the form is cleared from the screen. Now the user can run the vi utility to view or edit the TEXT value. When the editing session ends, the form is restored on the screen, and control returns to the 4GL application. When a display eld is of data type TEXT, but the screen cursor is not in that eld, the 4GL application can display as many of the leading characters of a TEXT data value as can t in the eld. (For BYTE elds, 4GL displays <BYTE value> in the eld.) This behavior is independent of the PROGRAM attribute.
6-60
PROGRAM
Default Editors
If a user moves the cursor to a TEXT eld and presses the exclamation point key in the rst character position of the eld, 4GL attempts to invoke an external program. The program invoked for a TEXT eld is chosen from among the following programs, in descending order of priority:
s
The program (if any) identied by the PROGRAM ="command" attribute specication for the eld The program (if any) named in the DBEDIT environment variable The default editor, which depends on the host operating system
s s
Specify the editor to use with the DBEDIT environment variable; this variable should contain the name of a UNIX application such as vi or emacs. When the user exits from the editor, control returns to the 4GL screen.
4GL applications that display or modify a value in a BYTE eld must use the PROGRAM attribute explicitly to assign an editor. For BYTE elds, the default editor is not called, and the DBEDIT variable is not examined.
REQUIRED
REQUIRED
The REQUIRED attribute forces the user to enter data in the eld during an INPUT or INPUT ARRAY statement.
REQUIRED
Usage
The REQUIRED keyword is effective only when the eld name appears in the list of screen elds of an INPUT or INPUT ARRAY statement. For example, suppose the ATTRIBUTES section includes the following eld description:
o20 = orders.po_num, REQUIRED;
Because of the REQUIRED specication, 4GL requires the entry of a purchase order value when the form is used to collect information for a new order. You cannot specify a default value for a REQUIRED eld. If both the REQUIRED and DEFAULT attributes are assigned to the same eld, 4GL assumes that the DEFAULT value satises the REQUIRED attribute. This attribute requires only that the user enter a printable character in the eld. If the user subsequently erases the entry during the same input, 4GL considers the REQUIRED attribute satised. To insist on a non-null entry, specify that the eld is FORMONLY and NOT NULL.
Related Attribute
NOENTRY
6-62
REVERSE
REVERSE
The REVERSE attribute displays any value in the eld in reverse video (dark characters in a bright eld).
REVERSE
Usage
The following example species that a eld linked to the customer_num column displays data in reverse (sometimes called inverse) video:
f000 = customer.customer_num, REVERSE;
On terminals that do not support reverse video, elds that have the REVERSE attribute are enclosed between angle brackets ( < > ). The REVERSE attribute disables any other COLOR attribute for the same eld.
Related Attribute
COLOR
UPSHIFT
UPSHIFT
During data entry in a character eld, the UPSHIFT attribute converts lowercase letters to uppercase letters, both on the screen display and in the 4GL program variable that stores the contents of that eld.
UPSHIFT
Usage
Because uppercase and lowercase letters have different code-set values, storing all character strings in one or the other format can simplify sorting and querying a database. The following example includes UPSHIFT in the attribute list of a eld:
c8 = state, UPSHIFT, AUTONEXT, INCLUDE = ("CA", "OR", "NV", "WA"), DEFAULT = "CA" ;
Because of the UPSHIFT attribute, 4GL enters uppercase characters in the state eld regardless of the case used to enter them. The AUTONEXT attribute tells 4GL to move automatically to the next eld once you type the total number of characters allowed for the eld (in this instance, two characters). The INCLUDE attribute restricts entry in this eld to the characters CA, OR, NV, or WA only. The DEFAULT value for the eld is CA.
GLS
The results of conversion between uppercase and lowercase letters are based on the locale les, which specify the relationship between corresponding pairs of uppercase and lowercase letters. If the locale les do not provide this information, no case conversion occurs.
Related Attribute
DOWNSHIFT
6-64
VALIDATE LIKE
VALIDATE LIKE
The VALIDATE LIKE attribute instructs 4GL to validate the data entered in the eld by using the validation rules that the upscol utility assigned to the specied database column in the syscolval table.
VALIDATE LIKE table . column
Description is the name of a column in table, or (if you omit table) the unique identier of a column in one of the tables that you declared in the TABLES section. is the unqualied name or alias of a database table, synonym, or view, as declared in the TABLES section. (This value is not required unless several columns in different tables have the same name or if the table is an external table or an external, distributed table.)
Usage
This attribute is equivalent to listing all the attributes that you have assigned to table.column in the syscolval table. Default Attributes on page 6-80 describes the syscolval table and the effects of this table in an ANSI-compliant database. The following example assigns the default attributes of the customer.state column to a FORMONLY eld:
s13 = FORMONLY.state, VALIDATE LIKE customer.state;
The restrictions on the DISPLAY LIKE attribute also apply to this attribute. You do not need the VALIDATE LIKE attribute if table.column is the same as eld name. You cannot specify a column of data type BYTE as table.column. Even if all of the elds in the form are FORMONLY, this attribute requires FORM4GL to access the database that contains table.
Related Attribute
DISPLAY LIKE
VERIFY
VERIFY
The VERIFY attribute requires users to enter data in the eld twice to reduce the probability of erroneous data entry.
VERIFY
Usage
Because some data is critical, this attribute supplies an additional step in data entry to ensure the integrity of your data. After the user enters a value into a VERIFY eld and presses RETURN, 4GL erases the eld and requests reentry of the value. The user must enter exactly the same data each time, character for character: 15000 is not exactly the same as 15000.00. For example, if you specify a eld for salary information in the following way, 4GL requires entry of exactly the same data twice:
s10 = quantity, VERIFY;
An error message appears if the user does not enter the same keystrokes. The VERIFY attribute takes effect while INPUT, INPUT ARRAY, or UPDATE statements of 4GL are executing. It has no effect on CONSTRUCT statements.
Related Attributes
INCLUDE, REQUIRED, VALIDATE LIKE
6-66
WORDWRAP
WORDWRAP
In a multiple-segment eld, the WORDWRAP attribute enables a multiple-line editor. This editor can wrap long character strings to the next line of a multiple-segment eld for data entry, data editing, and data display.
WORDWRAP COMPRESS NONCOMPRESS
Usage
If the same eld tag is repeated in two or more locations in the screen layout, this attribute instructs 4GL to treat all the instances of that eld tag as successive segments of a multiple-segment eld (described in MultipleSegment Fields on page 6-31). These elds can display data strings that are too long to t on a single line of the screen form. For example, the following excerpt from a form specication le shows a VARCHAR eld linked to the history column in the employee table.
history [f002 [f002 [f002 ] ] ]
4GL replaces each set of multiple-segment elds with a single WORDWRAP eld of a rectangular shape. The COMPRESS keyword option is applied to this
eld, and the delimiters are replaced with blank spaces. When a variable is bound to the WORDWRAP eld during INPUT, only the number of characters allowed by the bound variable can be entered. If necessary, text in the eld scrolls to allow the full number of characters to be entered. Data compression takes place before storage in the bound variable. If the lines of the multiple-segment eld are not contiguous or if the eld has an irregular shape, the WORDWRAP eld that results is based on the maximum height and width of the multiple-segment eld as a unit.
WORDWRAP
The resulting WORDWRAP eld can overlap or be overlapped by labels or individual form elds. To prevent such unpredictable effects, consolidate the segments of multiple-segment elds into rectangular shapes.
In nondefault locales, WORDWRAP elds can process non-ASCII characters that the locale supports. For the special case of Japanese locales, WORDWRAP elds support Kinsoku processing, with the same features that are described in Kinsoku Processing with WORDWRAP on page 7-66.
6-68
WORDWRAP
WORDWRAP
The editor distinguishes between intentional blanks (from the database or typed by the user) and editor blanks (inserted at the ends of lines for wordwrap or to align after a newline character). Intentional blanks are retained as part of the data. Editor blanks are inserted and deleted automatically as required. When designing a multiple-segment eld, allow room for editor blanks, over and above the data length. The expected number of editor blanks is half the length of an average word per segment. Text that requires more space than you expect might be truncated after the nal eld segment.
of intentional characters exceeds the eld or column size. Because of editing blanks in the WORDWRAP eld, the stored value might not correspond exactly to its multiple-line display, so a 4GL report generally cannot display the data in identical form. To suppress COMPRESS, specify UNCOMPRESS after the WORDWRAP keyword. This option causes any editor blanks to be saved when the WORDWRAP string is saved in a database column, in a variable, or in a le. In the following fragment of a form specication le, a CHAR value in the column charcolm is displayed in the multiple-segment eld whose tag is mlf:
SCREEN SIZE 24 by 80 { Enter text: [mlf [mlf . . . [mlf [mlf } TABLES tablet . . .
] ] ] ]
If the data string is too long to t in the rst line, successive segments are displayed in successive lines, until all of the lines are lled or until the last text character is displayed (whichever happens rst).
6-70 IBM Informix 4GL Reference Manual
WORDWRAP
If the form is used to insert data into tablet.charcolm, the keyword COMPRESS species that 4GL will not store editor blanks.
RETURN leaves the entire multiple-segment eld and goes to the rst
BACKSPACE or LEFT ARROW moves the cursor left one character, unless
at the left edge of a eld segment. From the left edge of the rst segment, these keys either move the cursor to the rst character of the preceding eld or only beep, depending on whether INPUT WRAP is in effect. (Input wrap mode is controlled by the OPTIONS statement.) From the left edge of a lower eld segment, these keys move the cursor to the right-most intentional character of the previous eld segment.
s
RIGHT ARROW moves the cursor right one character, unless at the right-most intentional character in a segment. From the right-most intentional character of the last segment, this key either moves the cursor to the rst character of the next eld or only beeps, depending on INPUT WRAP mode. From the right-most intentional character of a higher segment, this key moves the cursor to the rst intentional character in a lower segment.
WORDWRAP
UP ARROW moves
the cursor from the top-most segment to the rst character of the preceding eld. From a lower segment, this key moves the cursor to the character in the same column of the next higher segment, jogging left, if required, to avoid editor blanks, or if it encounters a tab.
DOWN ARROW moves the cursor from the lowest segment to the rst character of the next eld. From a higher segment, this key moves the cursor to the character in the same column in the next lower segment, jogging left if required to avoid editor blanks, or if it encounters a tab. TAB enters a TAB character in insert mode and moves the cursor to the
next tab stop. This action can cause following text to jump right to align at a tab stop. In typeover mode, this key moves the cursor to the next tab stop that falls on an intentional character, going to the next eld segment if required. The character keys enter data. Any following data shifts right, and words can move down to subsequent segments. This action can result in characters being discarded from the nal eld segment. These keystrokes can also alter data:
s s
the character under the cursor, possibly causing words to be pulled up from subsequent segments.
CONTROL-D deletes all text from the cursor to the end of the multiple-
line eld (not merely to the end of the current eld segment).
s
CONTROL-N inserts
a newline character, causing subsequent text to align at the rst column of the next segment of the eld and possibly moving words down to subsequent segments. This action can result in characters being discarded from the nal segment of the eld.
6-72
WORDWRAP
Non-WORDWRAP Displays
The appearance of a character value on the screen can vary, depending on whether or not it is displayed in a multiple-segment WORDWRAP eld. For instance, if a value that was entered by using WORDWRAP is displayed without this attribute, words will generally be broken, not wrapped, and TAB and NEWLINE characters will be displayed as question marks. These differences do not represent any loss of data but only a different mode of display. (You can view this effect, for example, if you also have INFORMIX-SQL installed on your system, and you use the Query Language menu to display character data values that were entered using WORDWRAP.) If a value prepared under the multiple-line editor is again edited without WORDWRAP, however, some formatting might be lost. For example, a user might type over a TAB or NEWLINE character, not realizing what it was. Similarly, a user might remove a blank from the rst column of a line and thus join a word to the last word on the previous line. These mistakes will be visible when the value is next displayed in a WORDWRAP eld or in a 4GL report that uses the WORDWRAP operator.
INSTRUCTIONS Section
INSTRUCTIONS Section
The INSTRUCTIONS section is the optional nal section of a form specication le. This section can declare nondefault screen records and screen arrays. The INSTRUCTIONS section appears after the last eld description (or after the optional END keyword) of the ATTRIBUTES section.
INSTRUCTIONS Section INSTRUCTIONS SCREEN RECORD record array [ size ] DELIMITERS "opening closing "
)
END
Description is the 4GL identier that you declare here for the screen array. (It is also the name of the screen record that comprises each line of the array.) is the closing eld delimiter. is the opening eld delimiter. is the 4GL identier that you declare here for the screen record. is a literal integer, enclosed in brackets ( [ ] ), to specify the number of screen records in the screen array.
The END keyword is optional and provides compatibility with earlier Informix products.
Screen Records
A screen record is a group of elds that screen interaction statements of the 4GL program can reference as a single object. By establishing a correspondence between a set of screen elds (the screen record) and a set of 4GL variables (typically a program record), you can pass values between the program and the elds of the screen record. In many applications, it is convenient to dene a screen record that corresponds to a row of a database table.
6-74
Screen Records
,
table
*
last rst THROUGH THRU table
Description is a eld name that you declared in the ATTRIBUTES section. is a eld name that you declared later than rst. is the 4GL identier that you declare for the screen record. is the name, alias, or synonym of a table (or FORMONLY keyword).
The eld name is the SQL identier of a database column linked to the eld, unless you specify FORMONLY as the table reference. If the database server has the IFX_LONGID environment variable set to 1, then table identiers can require up to 128 bytes of storage. The record name of a nondefault screen record can require up to 128 bytes of storage, and must comply with the rules for 4GL identiers (as described in 4GL Identiers on page 2-14).
Screen Records
If the database server has the IFX_LONGID environment variable set to 1, then a table identier (for the name of a default screen record) or column identiers (for member elds within a default screen record) can require up to 128 bytes of storage. The name of the default screen record is the table name (or the alias, if you declared an alias for that table in the TABLES section). For example, all the elds linked to columns of the customer table constitute a default screen record whose name is customer. If a form includes one or more FORMONLY elds, those elds constitute a default screen record called formonly. Like the name of a screen eld, the identier of a screen record must be unique within the form, and it has a scope that is restricted to when its form is open. Statements can reference record only when the screen form that includes it is being displayed. FORM4GL returns an error if record is the same as the name or alias of a table in the TABLES section.
6-76
Screen Arrays
Here the asterisks ( * ) represent all of the elds in the form that the ATTRIBUTES section associated with columns in the items and state tables. These elds do not necessarily correspond to all of the columns in these tables unless the form includes elds that are linked to all of the columns. You can use the keyword THRU to specify consecutive elds, in the order of their listing in the ATTRIBUTES section from eld name1 to eld name2, inclusive. (The keyword THROUGH is a synonym for THRU.) For example, the following instruction creates a screen record called address from elds linked to some columns of the customer table. This record can simplify 4GL statements to update customer address and telephone data.
SCREEN RECORD address (customer.address1 THRU customer.phone)
The order of elds in the portion of a screen record specied by the table.* or THRU notation is the order of the eld names within the ATTRIBUTES section.
Screen Arrays
A screen array is usually a repetitive array of elds in the screen layout, each containing identical groups of screen elds. Each row of a screen array is a screen record. Each column of a screen array consists of elds with the same eld tag in the SCREEN section of the form specication le. You must declare screen arrays in the INSTRUCTIONS section and use syntax like the syntax described for a screen record in the previous section, but with an additional parameter to specify the number of screen records in the array.
Screen Array SCREEN RECORD array [ size ]
Description is the 4GL identier that you declare here for the screen array. (It is also the identier of the screen record that comprises each line of the array.) is a literal integer, enclosed in square brackets ( [ ] ), to specify how many screen records are in the screen array.
Screen Arrays
The size value should be the number of lines in the logical form where the set of elds that comprise each screen record is repeated within the screen array. For example, a SCREEN section might represent a screen array like this:
SCREEN { CARRIER [ f00001] [ f00001] [ f00001] }
This example requires a size of [3]. Except for the size parameter, syntax for specifying the identier and the eld names of a screen array is the same as for a simple screen record (as described in Nondefault Screen Records on page 6-75). Unlike 4GL program arrays, which can have up to three dimensions, every 4GL screen array has exactly one dimension. The next example declares an array of six records, each of which includes two default screen records, namely the manufact.* and state.* screen records:
SCREEN RECORD mant_array [6] (manufact.*, state.*, cust_calls.user_id, FORMONLY.delta)
To illustrate the declaration of a typical screen array in more detail, consider the following fragment of a form specication le:
SCREEN { ... Item 1 [p ][q ][u ][t ] Item 2 [p ][q ][u ][t ] Item 3 [p ][q ][u ][t ] Item 4 [p ][q ][u ][t ] Item 5 [p ][q ][u ][t ] } TABLES orders items stock ATTRIBUTES ... p = stock.stock_num; q = items.quantity; u = stock.unit_price; t = items.total_price; ... INSTRUCTIONS SCREEN RECORD sc_items[5] (stock.stock_num, items.quantity, stock.unit_price, items.total_price)
6-78
Field Delimiters
The sc_items screen array has ve rows and four columns and includes elds linked to columns from two database tables. Rows are numbered from 1 to 5. The screen record that follows the display label Item 3 in the screen layout, for example, can be referenced as sc_items[3] in a 4GL statement. If there are no other columns of the items table in the form, the default screen record items contains two elds, which correspond to the items.quantity and items.total_price elds that are linked to columns of the items table. If a screen array contains a default screen record, you can reference its elds in specic lines of the screen array (such as items[5] for the q and t elds in the last line), as if you had declared an array of records linked to that table. You can reference array-name in the DISPLAY, DISPLAY ARRAY, INPUT, INPUT ARRAY, and SCROLL statements of 4GL but only when the screen form that includes the screen array is the current form. Screen records and screen arrays can display program records. If the elds in the screen record have the same sequence of data types as the columns in a database table, you can use the screen record to simplify 4GL operations that pass values between program variables and rows of the database.
Field Delimiters
You can change the delimiters that 4GL uses for elds from brackets ( [ ] ) to any other printable character, including blank spaces. The DELIMITERS instruction tells 4GL what symbols to use as eld delimiters when it displays the form on the screen. The opening and closing delimiter marks must be enclosed within quotation marks ( " ). The following specications display < and > as opening and closing delimiters of screen elds:
INSTRUCTIONS DELIMITERS "<>" END
Each delimiter occupies a space, so two elds on the same line are ordinarily separated by at least two spaces. To specify only one space between consecutive screen elds, use the following procedure.
Default Attributes
In the SCREEN section, substitute a pipe symbol ( | ) for paired backto-back ( ][ ) brackets that separate adjacent elds. In the INSTRUCTIONS section, dene some symbol as both the beginning and the ending delimiter. For example, you could specify "| |" or "/ /" or ": :" or " " (blanks).
The following specications substitute | for ][ between adjacent elds in the same line of the screen layout and display a colon as both the opening and closing delimiter:
SCREEN { . . . Full Name-[f011 . . . } . . . INSTRUCTIONS DELIMITERS "::" |f012 ]
Here the elds whose tags are f011 and f012 will be displayed as:
Full Name-: | :
If you substitute blanks for colons as DELIMITERS symbols, eld boundaries are not marked (or are only marked if they have attributes that contrast with the surrounding background). Important: FORM4GL requires brackets ( [ ] ) in the SCREEN section of a form specication le, regardless of any DELIMITERS instruction.
Default Attributes
Field attributes can also be specied in two special tables in the database, syscolval and syscolatt. These tables are maintained by the upscol utility, as described in Appendix B. FORM4GL searches these tables for default validation and display attribute specications. It applies these specications to form elds whose names match the names of the specied database columns or that reference these columns in the DISPLAY LIKE or VALIDATE LIKE attribute specications.
6-80 IBM Informix 4GL Reference Manual
Default Attributes
Here tabname and colname are the names of the table and column to which the attributes apply. Here colname cannot be a BYTE nor TEXT column. Valid values for the attrname and attrval columns in syscolval are as follows.
attrname AUTONEXT COMMENTS DEFAULT INCLUDE PICTURE SHIFT VERIFY attrval YES, NO (the default) As in this chapter As in this chapter As in this chapter As in this chapter UP, DOWN, NO (the default) YES, NO (the default)
FORM4GL adds the attributes from these tables to any attributes that are listed
in the form specication le. In case of conict, attributes from the form specication le take priority. 4GL applies the resulting set of eld attributes during execution of INPUT and INPUT ARRAY statements (by using syscolval) and during execution of DISPLAY and DISPLAY ARRAY statements (by using syscolatt).
Default Attributes
The color column in syscolatt stores an integer that describes color (for color terminals) or intensities (for monochrome terminals). The next table shows the displays specied by each value of color and the correspondence between default color names, number codes, and intensities.
Number Color Terminal Monochrome Terminal 0 WHITE NORMAL 1 YELLOW BOLD 2 MAGENTA BOLD 3 RED BOLD 4 CYAN DIM 5 GREEN DIM 6 BLUE DIM 7 BLACK DIM If BOLD is specied as the attribute, the eld is displayed as RED on a color screen. If the keyword DIM is specied as the attribute, the eld is displayed as BLUE on a color screen. Color terminals display NORMAL as WHITE.
The background for colors is BLACK in all cases. The same keywords are also supported by the COLOR attribute for color and monochrome terminals. The valid values for inverse, underline, blink and left are Y (yes) and N (no). The default for each of these columns is N; that is, normal display (bright characters in a dark eld), no underline, steady font, and right-aligned numbers. Which of these attributes can be displayed simultaneously with the color combinations or with each other is terminal dependent. The def_format column takes the same string that you would enter for the FORMAT attribute in a screen form. Do not use quotation marks. The condition column takes string values that are a restricted set of the WHERE clauses of a SELECT statement, except that the WHERE keyword and the column name are omitted. 4GL assumes that the value in the column identied by tabname and colname is the subject of all comparisons. Examples of valid entries for the condition column follow:
<= 100 MATCHES "[A-M]*" IN ("CA", "OR", "WA") BETWEEN 101 AND 1000 >= 1001 NOT LIKE "%analyst%"
6-82
The VALIDATE statement (described in Chapter 3) compares the members of a program record or variable list to the validation rules in syscolval. The INITIALIZE statement (described in Chapter 4) can read the default values in syscolval for a list of columns and assign these values to a corresponding list of 4GL variables. Some statements (including CONSTRUCT, DISPLAY, DISPLAY ARRAY, ERROR, INPUT, INPUT ARRAY, MESSAGE, PROMPT, OPEN WINDOW, and OPTIONS) support an ATTRIBUTE clause (described in ATTRIBUTE Clause on page 3-96) that can specify color and intensity attributes. You can override default attributes in syscolatt by assigning other attributes in the form specication le or in the ATTRIBUTE clause of the CONSTRUCT, DISPLAY, DISPLAY ARRAY, INPUT, or INPUT ARRAY statement. If the current 4GL statement is one of these and includes an ATTRIBUTE clause, the eld displays only the attributes that are specied in that clause. For example, if a column is designated as RED and BLINK in syscolatt, or in the form specication le, and your 4GL program executes the following statement, the eld has only the BLUE attribute, not blinking BLUE:
DISPLAY . . . ATTRIBUTE BLUE
If an ATTRIBUTE clause is present in the currently executing statement, there is no implicit carry-over of display attributes from the compiled form (except FORMAT).
The ATTRIBUTE clause of the current 4GL statement The eld descriptions in the ATTRIBUTES section of the current form The default attributes specied in the syscolatt table of any elds linked to database columns To modify the syscolatt table, use the upscol utility. For information on using this utility, see Appendix B.
4.
5. 6.
The ATTRIBUTE clause of the current form in the most recent DISPLAY FORM statement The ATTRIBUTE clause of the current 4GL window in the most recent OPEN WINDOW statement
ANSI
If table is an alias for owner.table, FORM4GL uses the upscol tables of the owner specied by table, if they exist. If no upscol tables exist, the DISPLAY LIKE and VALIDATE LIKE attributes have no effect. If owner is not the correct owner, the compilation fails and an error message is issued. See also the INITIALIZE and VALIDATE statements in Chapter 4.
6-84
If you have the C Compiler version, enter i4gl. If you have the Rapid Development System, enter r4gl.
2. 3.
Press F at the INFORMIX-4GL menu to select the Form option. Press G to select the Generate from the Form menu. (Alternatively, you can select the New option. 4GL then prompts you for a form name, prompts you for an editor if you have not already selected one, and invokes that editor with an empty form specication le. Now you must enter form specications. The Generate option is usually a more efcient way to create a customized form.)
4.
Enter the name of the database and the name that you want to assign to the form (for example, myform).
4GL asks you for the names of the tables whose columns you want in
your form.
5.
Enter the names of the tables you want to use. After you select the tables, FORM4GL creates a default form specication le, as well as a compiled default form, and then displays the FORM design menu. The default form specication le formats the screen as a list of all the columns in the tables that you entered in step 4. It does not provide any special instructions to 4GL about how to display the data.
6.
Press M to select the Modify option, and 4GL presents the MODIFY FORM menu:
a. b.
Select the default form specication (given as myform earlier), and 4GL calls a system editor to display the le. Edit the default form specication le to produce your customized screen form and associated instructions. (You can specify an editor by using the DBEDIT environment variable. This strategy is fully explained in Appendix D, Environment Variables.)
c. 7.
Save your le and quit the editor, and 4GL returns you to the MODIFY FORM menu.
Press C to select Compile. If your form specication le compiles successfully, FORM4GL creates a form le with the extension .frm (for example, myform.frm). In this case, skip to step 9. If your form specication le does not compile successfully, go on to step 8.
8.
Press RETURN to select the Correct option from the COMPILE FORM menu.
4GL again calls your editor to display the form specication le, with
the compilation errors marked. When correcting your errors, you need not delete the error messages. 4GL does that for you. Save the le and go back to step 7.
9.
6-86
-q
- l lines - c width
-v
-d
lename
database
table
-V
Element database lename lines table width Description is the SQL identier of a database. is the name of a form specication le (with no .per extension). is an integer that species the height of the form in lines of characters that the terminal can display. (The default is 24.) is the name of a database table, as declared in the TABLES section. is an integer that species the width of the form in characters. (The default is the number of characters in the longest line of the screen layout, as specied in the SCREEN section.)
The -v option instructs the form compiler to verify that all elds are as wide as any corresponding character elds that the ATTRIBUTES section species. The -V option instructs the form compiler to display the version number and then exit, without compiling anything. Use the -d option to generate a default form specication le. If you use this option, the compiler prompts you for the names of your form le, database, and tables. For more information, see the next section, Default Forms.
Create a default form specication le by entering the following command at the operating system prompt:
form4gl -d
FORM4GL asks for the name of your form specication le, the name
of your database, and the name of a table whose columns you want in your form. It continues to ask for another table name until you press RETURN for the name of a table. FORM4GL then creates a default form specication le and appends the extension .per to its name. It also creates a compiled default form with the extension .frm.
2.
Use the system editor to modify the default form specication le to meet your specications. If, as an alternative, you create a new form specication le and skip step 1, be sure to give the lename the extension .per.
3.
Here myform is the name of your form specication le (without the .per extension). If the compilation is successful, FORM4GL creates a compiled form le called myform.frm and you are nished creating your customized screen form. If not, FORM4GL instead creates a le named myform.err, and you need to go on to step 4.
4. 5.
Review the le myform.err to discover the compilation errors. Make corrections in the le myform.per, and then go back to step 3.
6-88
Default Forms
Default Forms
For many applications, it is convenient to create a default form and then edit this form to satisfy your specic application requirements. When you create a default form, you must specify its lename, a database name, and the name of at least one table whose columns are to be linked to elds in the form. The width of a display eld is the number of characters that can be placed between the delimiters. In a default form specication, FORM4GL assigns lengths to elds according to the declared data type of the column.
Data Type BYTE CHAR , NCHAR DATE DATETIME DECIMAL FLOAT INTEGER INTERVAL MONEY SMALLINT SMALLFLOAT TEXT VARCHAR, NVARCHAR Default Field Width (in Characters) 12 MIN ( 57, n ), where n is the length from the data-type declaration 10 From 2 to 25, as implied in data-type declaration (Each unit of time = 2 (except YEAR and FRACTION); every separator = 1.) (2 + m), where m is the precision from the data type declaration 14 11 From 3 to 25 (as implied in data type declaration, plus one) (3 + m), where m is the precision from the data type declaration 6 14 12 MIN ( 57, n ), where n is the maximum declared length
SERIAL columns are linked to INTEGER elds. Field length is not directly related to the data display in BYTE and TEXT elds, both of which require the PROGRAM attribute to invoke an external program or editor. The 4GL form can display as many TEXT characters as t in the eld and displays the string <BYTE value> in a BYTE eld. (For details about how to display BYTE and TEXT values, see PROGRAM on page 6-60.)
Default Forms
If you edit a default form, make sure that the elds are wide enough to accommodate the widest value that might be entered or displayed. To prevent 4GL from truncating displayed data, follow these rules:
s
Make character elds as wide as the corresponding database column. You can use multiple-segment elds to display long strings (as described in Multiple-Segment Fields on page 6-31). Make number, DATETIME, and INTERVAL elds wide enough to accommodate the largest displayed value.
Default eld tags like f000 are assigned to the rst display eld, f001 to the second, and so on, by FORM4GL. It assigns a eld tag like a0 to any two- or three-character eld that cannot accommodate a four-character default eld tag. Up to 26 single-character elds can be assigned the single characters a, b, c, and so forth, as default eld tags. The default screen layout has as many lines as the number of columns in the tables. Each line of the screen layout contains a single eld, beginning in the 20th character position. FORM4GL uses column names as default eld labels, which appear at the left of each eld. The next example shows a default form that is based only on the customer table of the stores7 database:
database stores7 screen size 24 by 80 { customer_num [f000 fname [f001 lname [f002 company [f003 address1 [f004 address2 [f005 city [f006 state [a0] zipcode [f007 ] phone [f008 } end tables customer attributes f000 = customer.customer_num; f001 = customer.fname; f002 = customer.lname; f003 = customer.company; f004 = customer.address1;
] ] ] ] ] ] ]
6-90
If the number of elds is greater than (lines - 4), you must edit the default le, either to increase the lines value after the SIZE keyword (if the screen size permits this) or else to reduce the number of lines in the screen layout.
Only the DELIMITERS keyword in the INSTRUCTIONS section of a PERFORM form is supported by 4GL. Other keywords in that section are ignored. To support other INSTRUCTIONS features of PERFORM requires coding in your 4GL program. (See the BEFORE and AFTER clauses of the INPUT statement.)
4GL does not support multiple-page forms (those with more than one
screen layout); these forms produce undesirable overlays. (Use multiple 4GL forms to produce the effects of forms that have several pages.)
s
There is no concept of current table in 4GL. An INPUT or INPUT ARRAY statement allows the user to enter data into elds that correspond to columns in different tables or even in different databases.
Joins dened in the PERFORM form are ignored in 4GL. You can associate two eld names with the same eld tag by using the same notation as in a PERFORM join, but no join is effected. However, you can create more complex joins and lookups in 4GL with the full power of SQL. The PERFORM attributes LOOKUP, NOUPDATE, QUERYCLEAR, RIGHT, and ZEROFILL are inoperative in 4GL. The DISPLAY, DISPLAY ARRAY, DISPLAY FORM, MESSAGE, and OPEN WINDOW statements of 4GL all ignore the INVISIBLE attribute. The conditions of a COLOR attribute cannot reference other eld tags or aggregate functions. Default attributes listed in syscolval and syscolatt do not apply to PERFORM forms unless you recompile the forms with FORM4GL.
6-92
Chapter
INFORMIX-4GL Reports
7
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-3 7-4 7-5 7-5 7-7 7-8 7-9 7-10 7-12 7-15 7-16 7-16 7-17 7-19 7-20 7-21 7-23 7-24 7-25 7-27 7-28 7-29
In This Chapter .
. .
. .
. .
. .
. .
. .
. .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
Producing 4GL Reports . . . . . . . . The Report Driver . . . . . . . . The Report Denition . . . . . . . The Report Prototype . . . . . . Components of the Report Denition . DEFINE Section . . . . . . . . . . . . . . . . . . . . . . . . . . .
OUTPUT Section . . . . . . . . The BOTTOM MARGIN Clause The LEFT MARGIN Clause . . The PAGE LENGTH Clause . . The REPORT TO Clause . . . The RIGHT MARGIN Clause . The TOP MARGIN Clause . . The TOP OF PAGE Clause . .
ORDER BY Section . . . . . . . . . . . . . . . . . . . The Sort List . . . . . . . . . . . . . . . . . . The Sequence of Execution of GROUP OF Control Blocks . . . The EXTERNAL Keyword . . . . . . . . . . . . . FORMAT Section EVERY ROW . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
FORMAT Section Control Blocks . . . . . . . . . . . . . Statements Prohibited in FORMAT Section Control Blocks . . . AFTER GROUP OF . . . . . . . . . . . . . . . . The Order of Processing AFTER GROUP OF Control Blocks . The GROUP Keyword in Aggregate Functions. . . . . . BEFORE GROUP OF . . . . . . . . . . . . . . . . The Order of Processing BEFORE GROUP OF Control Blocks FIRST PAGE HEADER . . . . . . . . . . . . . . . Displaying Titles and Headings . . . . . . . . . . . Restrictions on the List of Statements . . . . . . . . . ON EVERY ROW . . . . . . . . . . . . . . . . . Group Control Blocks . . . . . . . . . . . . . . ON LAST ROW . . . . . . . . . . . . . . . . . . PAGE HEADER. . . . . . . . . . . . . . . . . . PAGE TRAILER . . . . . . . . . . . . . . . . . Restrictions on the List of Statements . . . . . . . . . Statements in REPORT Control Blocks . . . . Statements Valid Only in the FORMAT Section EXIT REPORT . . . . . . . . . . . NEED . . . . . . . . . . . . . . PAUSE . . . . . . . . . . . . . . PRINT . . . . . . . . . . . . . . The FILE Option . . . . . . . . . The Character Position . . . . . . . The Expression List . . . . . . . . Aggregate Report Functions . . . . . The ASCII Operator . . . . . . . . The COLUMN Operator . . . . . . The LINENO Operator . . . . . . . The PAGENO Operator. . . . . . . The SPACE or SPACES Operator . . . The WORDWRAP Operator . . . . . SKIP. . . . . . . . . . . . . . . Restrictions on SKIP Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7-32 7-33 7-34 7-35 7-36 7-37 7-38 7-40 7-41 7-41 7-42 7-43 7-44 7-45 7-47 7-48 7-48 7-49 7-50 7-52 7-54 7-55 7-57 7-57 7-59 7-60 7-62 7-62 7-63 7-63 7-64 7-65 7-68 7-69
7-2
In This Chapter
Creating reports is the method of producing output from 4GL programs that offers the greatest formatting exibility. This chapter describes how to dene reports to format data sets. The following list summarizes the features besides reports that INFORMIX-4GL offers for outputting values from a relational database or values from 4GL program variables:
s
Output of unformatted database rows to an ASCII le by using the UNLOAD statement (as described in UNLOAD on page 4-367) Direct screen output by using the DISPLAY statement to display values that the SELECT statement has retrieved from the database and stored in 4GL program variables (as described in DISPLAY on page 4-90) (The SELECT statement is described in the Informix Guide to SQL: Syntax.)
Output to a 4GL form (as described in Chapter 6, Screen Forms) through the DISPLAY or DISPLAY ARRAY statements Output to a reserved line of 4GL through the ERROR, PROMPT, MENU, or MESSAGE statement, or the COMMENTS attribute (as described in Reserved Lines on page 4-114) Output of TEXT or BYTE values to an external editor that you specify through the PROGRAM eld attribute of a 4GL form (as described in PROGRAM on page 6-60) Output to the screen or to a le (or to another program, such as a text editor) from a 4GL report (as described in Sending Report Output to the Screen on page 7-19)
The option to display report output to the screen for editing Full control over page layout for your 4GL report, including rstpage and generic page headers, page trailers, columnar presentation, and special formatting before and after groups sorted by value Facilities for creating the report either from the rows returned by a cursor or from input records assembled from any other source, such as output from several different SELECT statements Control blocks to manipulate data from a database cursor on a rowby-row basis, either before or after the row is formatted by the report Aggregate functions that can calculate and display frequencies, percentages, sums, averages, maxima, and minima The USING operator and other built-in 4GL functions and operators for formatting and displaying information in output from the report The WORDWRAP operator to format long character strings that occupy multiple lines of output from the report The option to update the database or execute any sequence of SQL and other 4GL statements while writing a report, if the intermediate values calculated by the report meet specied criteria; for example, to write an alert message containing a second report
7-4
The report driver species what data the report includes. The REPORT routine (also called the report denition) formats the data.
The report driver retrieves the specied rows from a database, stores their values in program variables, and sends these, one input record at a time, to the report denition. After the last input record is received and formatted, 4GL calculates any aggregate values that are based on all the data and then sends the entire report to some output device. By separating the two tasks of data retrieval and data formatting in this way, 4GL simplies the production of recurrent reports and makes it easy to apply the same report format to different data sets.
The following diagram (simplied to omit most of the control logic) shows the elements of a report driver. These elements can appear in different program blocks, but they are typically embedded within a FOR, FOREACH, or WHILE loop.
START REPORT p. 4-354 OUTPUT TO REPORT p. 4-308 FINISH REPORT p. 4-125 TERMINATE REPORT page 4-364
Uses START REPORT to initialize the report Begins a FOR, FOREACH, or WHILE loop to control the repeated fetching of rows, and to store the retrieved data as input records Uses OUTPUT TO REPORT to pass data to the report Terminates the loop (with the END FOR, END FOREACH, or END WHILE keywords) after all the values have been passed to the report Uses FINISH REPORT to execute any ON LAST ROW control block and to activate two-pass report processing (as described in The EXTERNAL Keyword on page 7-27) or else uses TERMINATE REPORT to exit from the report before processing is completed (typically because of an error)
s s
For information about the statements in the preceding list, see Chapter 4, INFORMIX-4GL Statements.
7-6
) ,
argument
END REPORT
)
OUTPUT Section p. 7-12 ORDER BY Section p. 7-23
Element argument
Description is the name of a formal argument in each input record. The list can include arguments of the RECORD data type, but the record.* notation and ARRAY data type are not valid here.) is the 4GL identier that you declare here for the report.
report
A REPORT prototype to declare the name of the report, and the names of the formal arguments of input records that the report formats A DEFINE section to declare local variables and formal arguments Optional OUTPUT and ORDER BY sections to specify (respectively) the page layout of output from the report, and sorting instructions Control blocks within the FORMAT section to produce headers, footers, and formatted output from the data in the input records The END REPORT keywords that terminate the report denition
s s
In a typical 4GL application, the input records that the report formats contain values retrieved from a database, but a 4GL report can also process input records that were not derived from any database.
A report name has global scope and must not conict with names of other reports, functions, or global variables or with its own formal arguments. A formal argument cannot be an ARRAY variable or a RECORD variable that contains an ARRAY member. Unless the argument list is empty, its arguments must be declared in the DEFINE section as local variables. You must specify an argument list value whenever any condition is true among those listed in DEFINE Section on page 7-10 for declaring report arguments. If you do not specify an argument list, output from the report can include text from the control blocks, but the only data that the report can include must be contained in variables of global or module scope.
7-8
variables used within the report, and of any variables (the input records) that are passed as arguments to the report by the calling statement. Reports without arguments or local variables do not require a DEFINE section.
s
each containing a xed number of lines whose margins and maximum number of characters is xed. This section can set margin and page size values, and can also specify where to send the formatted output.
s
records are to be sorted. It is required if the report driver does not send sorted data to the report. The specied sort order determines the order in which 4GL processes any GROUP OF control blocks in the FORMAT section.
s
of the report, including page headers, page trailers, and aggregate functions of the data. It can also contain control blocks that specify actions to take before or after specic groups of rows are processed. (Alternatively, it can produce a default report by only specifying FORMAT EVERY ROW.) Each of these four sections begins with the keyword for which it is named. These elements of a report denition are described in sections that follow. Like MAIN or FUNCTION, the report denition must appear outside any other program block. It must begin with the REPORT statement and must end with the END REPORT keywords. The FORMAT section is always required (and DEFINE is usually required). You can include other sections as needed.
DEFINE Section
DEFINE Section
This section declares a data type for each formal argument in the REPORT prototype and for any additional local variables that can be referenced only within the REPORT program block. The DEFINE section is required if you pass arguments to the report or if you reference local variables in the report. ,
DEFINE variable data type Data Type Declaration (Subset) p. 4-84
Element variable
Usage
For declaring local variables, the same rules apply to the DEFINE section as to the DEFINE statement (described in DEFINE on page 4-81) in MAIN and FUNCTION program blocks. Two exceptions, however, restrict the data types of formal arguments:
s s
Report arguments cannot be of type ARRAY. Report arguments cannot be records that include ARRAY members.
Data types of local variables that are not formal arguments are unrestricted. You must include arguments in the report prototype and declare them in the DEFINE section, if any of the following conditions is true:
s
If you specify FORMAT EVERY ROW to create a default report, you must pass all the values for each record of the report. If an ORDER BY section is included, you must pass all the values that ORDER BY references for each input record of the report. If you use the AFTER GROUP OF control block, you must pass at least the arguments that are named in that control block. If an aggregate that depends on all records of the report appears anywhere except in the ON LAST ROW control block, you must pass each of the records of the report through the argument list.
7-10
DEFINE Section
(The statements mentioned in the preceding list are described later in this chapter.) Aggregates dependent on all records include:
s s
any aggregate without the GROUP keyword (anywhere outside the ON LAST ROW control block)
For more information, see The COUNT ( * ) and PERCENT ( * ) Aggregates on page 7-61. If your report calls an aggregate function, an error might result if any argument of an aggregate function is not also a format argument of the report. You can, however, use global or module variables as arguments of aggregates if the value of the variable does not change while the report is executing. If you use the LIKE keyword to specify data types indirectly, the DATABASE statement must appear before the rst program block of the same module that includes the report denition, as described in The Default Database at Compile Time on page 4-73. For more information, see also Indirect Typing on page 4-83. If the DEFINE section declares a variable or argument with the same identier as a global or module variable, the global or module variable is not visible in the report. See also DEFINE on page 4-81. A report can reference variables of global or module scope that are not declared in the DEFINE section. Their values can be printed, but they can cause problems in aggregates and in BEFORE GROUP OF and AFTER GROUP OF clauses. Any references to nonlocal variables can produce unexpected results, however, if their values change while a two-pass report is executing.
OUTPUT Section
OUTPUT Section
The OUTPUT section can specify the destination and dimensions for output from the report and the page-eject sequence for the printer. If you omit the OUTPUT section, the report uses default values to format each page. (This section is superseded by any corresponding START REPORT specications.)
OUTPUT
1 REPORT TO
PRINTER SCREEN
1 TOP 1 LEFT 1 BOTTOM 1 RIGHT 1 PAGE LENGTH 1 TOP OF PAGE MARGIN PIPE
FILE
"lename "
IN FORM MODE IN LINE MODE program
= "string "
size
Description is a quoted string that species the name of a le to receive the report output. The lename can also include a pathname. is a quoted string (or CHAR or VARCHAR variable) that species a program, shell script, or command line to receive the output. is a literal integer that species the height (in lines) or width (in characters) of a page of output from the report or of its margins. is a quoted string that species the page-eject character sequence.
7-12
OUTPUT Section
Usage
The OUTPUT section can direct the output from the report to a printer, le, or pipe, and can initialize the page dimensions and margins of report output. The START REPORT statement of the report driver can override all of these specications by assigning another destination in its TO clause or by assigning other dimensions, margins, or another page-eject sequence in the WITH clause. For more information, see START REPORT on page 4-354. Because the size specications for the dimensions and margins of a page of report output that the OUTPUT section can specify must be literal integers, you might prefer to reset these values in the START REPORT statement, where you can use variables to assign these values dynamically at runtime. Important: Versions of 4GL earlier than 7.3 were not able to assign the destination or the page dimensions of output dynamically through the START REPORT statement. These START REPORT features are described in The TO Clause on page 4-355 and The WITH Clause on page 4-360. The OUTPUT section consists of the OUTPUT keyword, followed by one or more specications. The OUTPUT section has the following structure:
s
The REPORT TO clause species a default destination for output. If you omit this clause, the default is to the screen. If REPORT TO species PRINTER, the TOP OF PAGE clause can specify a 1- or 2-character page-eject sequence that causes the printer to begin a new page of report output rather than padding each page with blank lines.
OUTPUT Section
LEFT MARGIN size (default = 5 characters) TOP MARGIN size (default = 3 lines)
BOTTOM MARGIN size (default = 3 lines) RIGHT MARGIN size (default = 132 characters) (for default reports or PRINT WORDWRAP only)
The ve clauses that are shown in Figure 7-1 specify the physical dimensions of a 4GL report page:
s
The LEFT MARGIN clause species how many blank spaces to include at the beginning of each new line of output. The default is 5 blank spaces. The RIGHT MARGIN clause species the maximum number of characters in each line of output, including the left margin. If you omit this clause but specify FORMAT EVERY ROW, the default is 132 characters wide. The TOP MARGIN clause species how many blank lines appear above the rst line of text on each page of output. The default is 3 blank lines. The BOTTOM MARGIN clause species how many blank lines follow the last line of output on each page. The default is 3 blank lines. The PAGE LENGTH clause species the total number of lines on each page, including data, the margins, and any page headers or page trailers from the FORMAT section. The default page length is 66 lines.
7-14
OUTPUT Section
These values cannot be negative and cannot be larger than 32,766. Sections that follow describe these OUTPUT section specications in alphabetical order.
Element size
Description is a literal integer (as described in Literal Integers on page 3-65) that species the non-negative vertical height (in lines) of the bottom margin of each page.
The bottom margin appears as size blank lines below any output specied by the PAGE TRAILER control block of the FORMAT section. If you do not include a BOTTOM MARGIN specication, the default bottom margin is three lines, meaning that at least three lines are left blank at the end of each page. The restriction 1 size 32,766 applies (as for all OUTPUT section specications). The following BOTTOM MARGIN specication instructs 4GL to continue printing to the bottom of each page, with no blank lines as a bottom margin:
OUTPUT REPORT TO "sendthis.out" TOP MARGIN 0 BOTTOM MARGIN 0 PAGE LENGTH 6
OUTPUT Section
Element Description size is a literal integer (described in Literal Integers on page 3-65) to specify the non-negative width (in characters) of the left margin of each page.
Output begins in the (size + 1) character position. Measurements indicated by arguments to the COLUMN function are always relative to the margin set by LEFT MARGIN. If you do not include a LEFT MARGIN clause, the default value for the left margin is ve character positions. When this default is in effect, any output of data begins in the sixth character position. The following LEFT MARGIN specication instructs 4GL to begin printing each line of output as far to the left as possible.
OUTPUT REPORT TO "about.out" LEFT MARGIN 0 PAGE LENGTH 6
Element size
Description is a literal integer (as described in Literal Integers on page 3-65) that species the non-negative height (in lines) of each page, including top and bottom margins.
7-16
OUTPUT Section
Any top or bottom margin is included within the size that you specify here. If you omit the PAGE LENGTH specication, the default page length is 66 lines. The next example species a PAGE LENGTH value of 22 lines:
OUTPUT PAGE LENGTH 22 BOTTOM MARGIN 0
Depending on font size, 22 lines is the maximum length that some systems can use with the PAUSE statement without causing undesirable scrolling.
Description is a quoted string that contains the name of a le to receive the report output. This lename can also include a pathname. is a quoted string that species a program, shell script, or command line to receive the output from the report.
If the START REPORT statement includes a valid TO clause that directs output of the report to some destination, the START REPORT destination takes precedence, and any REPORT TO clause in the OUTPUT section has no effect.
OUTPUT Section
If no screen mode is specied, IN FORM MODE is the default unless a previous OPTIONS statement has set IN LINE MODE as the default. For more information about line mode and formatted mode in 4GL operations that produce screen output, see Screen Display Modes on page 4-341. The quoted string that follows the PIPE (and optional screen mode) keywords must contain the name of a program, shell script, or command line that is to receive the report output. This string can also include command-line arguments. The following OUTPUT section directs the report output to the more utility:
OUTPUT REPORT TO PIPE "more"
7-18
OUTPUT Section
Element size
Description is a literal integer that species the maximum number of characters on each line, including the left margin.
This clause sets the right margin by specifying a line width, in characters. The size value is not dependent on the LEFT MARGIN but starts its count from the left edge of the page, so the width of the LEFT MARGIN is included in the size of RIGHT MARGIN. The 132-character default size is effective only when both of the following conditions are true:
s s
The RIGHT MARGIN clause is omitted from the OUTPUT section. The FORMAT section contains the EVERY ROW specication for a default report format, or else a PRINT statement with WORDWRAP is executing.
A default EVERY ROW report lists the variable names across the top of the page and presents the data in columns beneath these headings. If there is not sufcient room between left and right margins to do this, 4GL produces a two-column output format that lists the variable name and the data value of each output record on each line of output.
INFORMIX-4GL Reports 7-19
OUTPUT Section
The following example illustrates a RIGHT MARGIN clause. After processing the OUTPUT section, 4GL sets a maximum line width of 70 and does not allow text to be printed to the right of the 70th character position:
REPORT simple(customer) DEFINE customer LIKE customer.* OUTPUT RIGHT MARGIN 70 FORMAT EVERY ROW END REPORT
Element size
Description is a literal integer (as described in Literal Integers on page 3-65) that species the vertical height (in lines) of the top margin of each page.
If you omit the TOP MARGIN specication, the default top margin is three lines, and any page header begins in the fourth line. The following TOP MARGIN clause begins printing at the top of each page:
OUTPUT TOP MARGIN 0 PAGE LENGTH 65
7-20
OUTPUT Section
The number of blank lines specied as the top margin size value appears in report output above any page header that you specify in a PAGE HEADER or FIRST PAGE HEADER control block of the FORMAT section.
LEFT MARGIN size TOP MARGIN size Begin output from PAGE HEADER or FIRST PAGE HEADER PAGE LENGTH size Figure 7-2 Margins of a Page of Report Output
The sum of the size values that you specify as your top and bottom margins, plus the number of lines (if any) for the page header and trailer, represents the portion of each page that is not available for displaying data. Unless the page length is greater than this total, your report cannot display any records.
Element string
OUTPUT Section
If you include the TOP OF PAGE clause, 4GL uses the specied page-eject character to set up new pages. For example, the TOP OF PAGE clause in the following example species CONTROL-L as the page-eject character:
REPORT labels_report (rl) DEFINE rl RECORD LIKE customer.* OUTPUT TOP OF PAGE "^L" REPORT TO "r_out"
On many printers, this string is "^L", the ASCII form-feed character. 4GL uses the rst character of the string as the TOP OF PAGE character unless it is the caret ( ^ ). In this case, 4GL interprets the second character as a control character. (If you are not sure of what character string to specify for a given printer, refer to the documentation for that printer.) If the report denition includes the TOP OF PAGE clause, all page breaks in the output are initiated by using the specied page-eject character rather than by padding with blank lines. If no TOP OF PAGE clause is included, LINEFEED characters are used (before the page trailer) to pad each page to the proper length before each page break.
PRINT attempts to print on a page that is already full. SKIP TO TOP OF PAGE is executed. SKIP n LINES species more lines than are available on the current
page.
s
NEED species more lines than are available on the current page.
If you omit the TOP OF PAGE clause, 4GL lls the remaining lines of the current page with LINEFEED characters when a new page is set up.
7-22
ORDER BY Section
ORDER BY Section
The ORDER BY section species how to sort input records, and determines the sequence of execution of GROUP OF control blocks in the FORMAT section. ,
ORDER EXTERNAL BY argument ASC DESC
Element argument
Description is the name of an argument from the report prototype (as described in The Report Prototype on page 7-8). The list of variables that you specify here is called the sort list.
Usage
The ORDER BY section species a sort list for the input records. Include this section if values that the report denition receives from the report driver are signicant in determining how BEFORE GROUP OF or AFTER GROUP OF control blocks will process the data in the formatted report output. If you omit the ORDER BY section, 4GL processes input records in the order received from the report driver and processes any GROUP OF control blocks in their order of appearance in the FORMAT section. If records are not sorted in the report driver, the GROUP OF control blocks might be executed at random intervals (that is, after any input record) because unsorted values tend to change from record to record. For more information, see AFTER GROUP OF on page 7-34 and BEFORE GROUP OF on page 7-37. If you specify only one variable in the GROUP OF control blocks, and the input records are already sorted in sequence on that variable by the SELECT statement, you do not need to include an ORDER BY section in the report.
ORDER BY Section
If you include more than one variable in the sort list, 4GL uses the left-to-right sequence of variables as the order of decreasing precedence. Unless the DESC keyword is specied, records are sorted in ascending (lowest-to-highest) order by values of the rst (highest-priority) variable. Records having the same value for the rst variable are ordered by values of the second variable and so on. Records with the same values on all but the last (lowest-priority) variable in the sort list are ordered by that variable.
GLS
Sorting that is based on character values uses the code-set order, unless you set the DBNLS environment variable to 1 and dene a nondefault collation sequence in the COLLATION category of the locale les. If you specify the DESC keyword, the report sorts records in descending (highest-to-lowest) order of values for the specied variables; precedence of variables within the sort list, however, is the same as with the ASC keyword, based on the left-to-right order of variables within the sort list. The next program fragment sorts records rst by zipcode, and then within the same zipcode by comp_name, and within comp_name by address1:
REPORT labels_rpt(c) DEFINE c RECORD LIKE custome.* ORDER BY c.zipcode, c.comp_name, c.address1
You can also sort the records by specifying a sort list in the ORDER BY clause of the SELECT statement (in the report driver). If you specify sort lists in both the report driver and the report denition, the sort list in the ORDER BY section of the REPORT takes precedence. If all the input records come from database rows that are returned by a single cursor, the report executes more quickly if you use the ORDER BY clause of the SELECT statement instead of the ORDER BY section of the report.
7-24 IBM Informix 4GL Reference Manual
ORDER BY Section
Even if the report denition receives records sorted by the report driver, you might want to specify ORDER EXTERNAL BY to specify the exact order in which GROUP OF control blocks are processed. The EXTERNAL keyword can prevent the input records from being sorted again. For more information, see The EXTERNAL Keyword on page 7-27.
Each time the value of the current group variable changes Each time the value of a higher-priority variable changes
How often the value of the group variable changes depends in part on whether the input records have been sorted:
s
If the records are sorted, AFTER GROUP OF executes after 4GL processes the last record of the group of records; BEFORE GROUP OF executes before 4GL processes the rst records with the same value for the group variable. If the records are not sorted, the BEFORE GROUP OF and AFTER GROUP OF control blocks might be executed before and after each record because the value of the group variable might change with each record. All the AFTER GROUP OF and BEFORE GROUP OF control blocks are executed in the same lexical order in which they appear in the FORMAT section.
ORDER BY Section
The following program illustrates how the ORDER BY section and the GROUP OF control blocks interact:
MAIN START REPORT sample_rpt TO "sample.out" OUTPUT TO REPORT sample_rpt (1,1,1) OUTPUT TO REPORT sample_rpt (2,2,2) FINISH REPORT sample_rtp END MAIN REPORT sample_rpt (a,b,c) DEFINE a,b,c, col INTEGER ORDER EXTERNAL BY a,b,c FORMAT FIRST PAGE HEADER LET col = 0 ON EVERY ROW PRINT COLUMN col, "**rec**", a,b,c AFTER GROUP OF c PRINT COLUMN col, "after c" LET col = col - 4 AFTER GROUP OF a PRINT COLUMN col, "after a" LET col = col - 4 AFTER GROUP OF b PRINT COLUMN col, "after b" LET col = col -4 BEFORE GROUP OF b LET col = col + 4 PRINT COLUMN col, "before b" BEFORE GROUP OF a LET col = col + 4 PRINT COLUMN col, "before a" BEFORE GROUP OF c LET col = col + 4 PRINT COLUMN col, "before c" END REPORT
The sample_rpt report in the previous example produces output in a, b, c order (for the BEFORE GROUP OF control blocks) and c, b, a order (for the AFTER GROUP OF control blocks), based on the a, b, c order that the ORDER BY section species:
before a before b before c **rec** after c after b after a before a
7-26
ORDER BY Section
If you delete or comment out the ORDER BY section, however, the resulting code would produce the following output, based on the physical sequence of variables in GROUP OF control blocks (here c, a, b) in the FORMAT section:
before c before a before b **rec** after b after a after c before c before a before b **rec** after b after a after c
FORMAT Section
In the previous code example, the EXTERNAL keyword in the ORDER BY section instructs the report to accept the input records without sorting them. Without this keyword, the report needs access to a database to create its temporary table for sorting. (If no database is open and you run a two-pass report, a runtime error occurs when 4GL cannot create the temporary table.) If the input records for your report come sequenced in the desired order (for example, from the rows returned by only one cursor), or to sequence values in descending order, use the ORDER BY clause in the SELECT statement that is associated with the cursor. Then use the EXTERNAL keyword in the ORDER BY section of your report.
FORMAT Section
A report denition must contain a FORMAT section. The FORMAT section determines how the output from the report will look. It works with the values that are passed to the REPORT program block through the argument list or with global or module variables in each record of the report. In a source le, the FORMAT section begins with the FORMAT keyword and ends with the END REPORT keywords.
4GL supports two types of FORMAT sections. The simplest (a default report) contains only the EVERY ROW keywords between the FORMAT and END REPORT keywords.
More complex FORMAT sections can contain control blocks like ON EVERY ROW or BEFORE GROUP OF, which contain statements to execute while the report is being processed. Control blocks can contain report execution statements and other executable 4GL statements that are not SQL statements. For more information, see Statements in REPORT Control Blocks on page 48. Sections that follow describe the syntax of default FORMAT sections, of the seven types of FORMAT section control blocks, and of the report execution statements that can appear only within a control block.
7-28
EVERY ROW
If you do not use the EVERY ROW keywords to specify a default report, you can combine one or more control blocks in any order within the FORMAT section. Except for BEFORE GROUP OF and AFTER GROUP OF control blocks, each type of control block must be unique within the report.
EVERY ROW
The EVERY ROW keywords specify a default output format, including every input record that is passed to the report. If you use the EVERY ROW option, no other statements or control blocks are valid.
EVERY ROW
EVERY ROW
Usage
This option formats the report in a simple default format, containing only the values that are passed to the REPORT program block through its arguments, and the names of the arguments. You cannot modify the EVERY ROW statement with any of the statements listed in Statements in REPORT Control Blocks on page 7-48, nor can you include any control blocks in the FORMAT section. To display every record in a format other than the default format, use the ON EVERY ROW control block (as described in the FORMAT Section Control Blocks on page 7-32). The following example of a report denition uses the EVERY ROW option:
REPORT minimal(customer) DEFINE customer RECORD LIKE customer.* FORMAT EVERY ROW END REPORT
7-30
EVERY ROW
Reports generated with the EVERY ROW option use as column headings the names of the variables that the report driver passes as arguments at runtime. If all elds of each input record can t horizontally on a single line, the default report prints the names across the top of each page and the values beneath. Otherwise, it formats the report with the names down the left side of the page and the values to the right, as in the previous example. When a variable contains a null value, the default report prints only the name of the variable, with nothing for the value. The following example is a brief report specication that uses the EVERY ROW statement. (Assume here that the cursor that retrieved the input records for this report was declared with an ORDER BY clause, so that no ORDER BY section is needed in this report denition.)
DATABASE stores7 REPORT simple(order_num, customer_num, order_date) DEFINE order_num LIKE orders.order_num, customer_num LIKE orders.customer_num, order_date LIKE orders.order_date FORMAT EVERY ROW END REPORT
The following example is part of the output from the preceding report denition:
order_num customer_num order_date 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 104 101 104 106 116 112 117 110 111 115 104 117 01/20/1993 06/01/1993 10/12/1993 04/12/1993 12/04/1993 09/19/1993 03/25/1993 11/17/1993 02/14/1993 05/29/1993 03/23/1993 06/05/1993
You can use the RIGHT MARGIN keywords in the OUTPUT section to control the width of a report that uses the EVERY ROW statement.
A report can include BEFORE GROUP OF, AFTER GROUP OF, and ON EVERY ROW control blocks where the GROUP OF blocks reference the same variable. In this case, when the value of the variable changes, the report processes all BEFORE GROUP OF blocks before the ON EVERY ROW block and the ON EVERY ROW block before all AFTER GROUP OF blocks. If a report driver includes START REPORT and FINISH REPORT statements, but no data records are passed to the report, no control blocks are executed. That is, unless the report executes an OUTPUT TO REPORT statement that passes at least one input record to the report; then neither the FIRST PAGE HEADER control block nor any other control block is executed.
7-32
The sequence in which the BEFORE GROUP OF and AFTER GROUP OF control blocks are executed depends on the sort list in the ORDER BY section. For example, assume that the ORDER BY section species a sort list of variables a, b, and c in that order (as in the example in The Sequence of Execution of GROUP OF Control Blocks on page 7-25). 4GL processes the control blocks in the following order, regardless of the physical sequence in which these control blocks appear within the FORMAT section.
BEFORE GROUP OF a BEFORE GROUP OF b BEFORE GROUP OF c ON EVERY ROW AFTER GROUP OF c AFTER GROUP OF b AFTER GROUP OF a {1} {2} {3} {4} {3} {2} {1}
Figure 7-3 The Order of Group Processing, if a,b,c Is the Sort List in the ORDER BY Section
In this example, a control block can be executed multiple times relative to any other block that is marked with a lower number in the right column. Without an ORDER BY section, the default is the physical order of rst mention of the variables in either BEFORE or AFTER GROUP OF control blocks. Important: New values assigned to variables in the PAGE HEADER control block are not available until after the rst PRINT, SKIP, or NEED statement is executed in an ON EVERY ROW control block. This situation guarantees that any group values printed in the PAGE HEADER control block have the same values as in the ON EVERY ROW control block. Versions of 4GL earlier than 4.1 did not support this feature.
In this version of 4GL, a compile-time error is issued if you attempt to include any of these statements in a control block of a report. You can, however, call a function that includes any of these statements (except MAIN and DEFER).
AFTER GROUP OF
AFTER GROUP OF
The AFTER GROUP OF control block species the action that 4GL takes after it processes a group of sorted records. Grouping is determined by the ORDER BY specication in the SELECT statement or in the report denition.
statement
Description is a report execution statement (as described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement. is the name of a formal argument to the report denition. You must pass at least the value of variable through the arguments.
Usage
A group of records is all of the input records that contain the same value for the variable whose name follows the AFTER GROUP OF keywords. This group variable must be passed through the report arguments. A report can include no more than one AFTER GROUP OF control block for any group variable. When 4GL executes the statements in a AFTER GROUP OF control block, local variables have the values from the last record of the current group. From this perspective, the AFTER GROUP OF control block could be thought of as the on last record of group control block.
7-34
AFTER GROUP OF
Whenever the value of the group variable changes Whenever the value of a higher-priority variable in the sort list changes At the end of the report (after processing the last input record but before 4GL executes any ON LAST ROW or PAGE TRAILER control blocks) In this case, each AFTER GROUP OF of control block is executed in ascending priority.
The Sort List on page 7-24 describes how input records are sorted according to a group variable (or a list of group variables) and the order of precedence among several variables in the sort list. How often the value of the group variable changes depends in part on whether the input records have been sorted by the SELECT statement:
s
If records are already sorted when the report driver passes them to the report, the AFTER GROUP OF block is executed after 4GL has processed the last record of the group. If records are not sorted, the AFTER GROUP OF control blocks might be executed after any record because the value of the group variable might change with each record. If the report includes no ORDER BY section, all AFTER GROUP OF control blocks are executed in the same order in which they appear in the FORMAT section.
The AFTER GROUP OF control block is designed to work with sorted data. You can sort the records by specifying a sort list in either of the following ways:
s s
An ORDER BY section in the report denition The ORDER BY clause of the SELECT statement in the report driver
AFTER GROUP OF
To sort data in the ORDER BY clause of the SELECT statement, perform the following tasks:
s
Use the column value in the ORDER BY clause of the SELECT statement as the group variable in the AFTER GROUP OF control block. If the report contains BEFORE or AFTER GROUP OF control blocks, make sure to include an ORDER EXTERNAL BY section in the report denition to specify the precedence of variables in the sort list.
To sort data in the report denition (with an ORDER BY section), include the name of a formal argument as the group variable in both the ORDER BY section and in the AFTER GROUP OF control block. If you specify sort lists in both the report driver and in the report denition, the sort list in the ORDER BY section of the report denition takes precedence. If the sort list includes more than one variable, 4GL sorts the records by values in the rst variable (highest priority). Records that have the same value for the rst variable are then ordered by the second variable and so on until records that have the same values for all other variables are ordered by the last variable (lowest priority) in the sort list.
Using the GROUP keyword to qualify an aggregate function is only valid within the AFTER GROUP OF control block. It is not valid, for example, in the BEFORE GROUP OF control block. The aggregate report functions of 4GL are described in Chapter 5 and in Aggregate Report Functions on page 7-60. After the last input record is processed, 4GL executes the AFTER GROUP OF control blocks before it executes the ON LAST ROW control block.
7-36 IBM Informix 4GL Reference Manual
BEFORE GROUP OF
BEFORE GROUP OF
The BEFORE GROUP OF control block species what action 4GL takes before it processes a group of input records. Group hierarchy is determined by the ORDER BY specication in the SELECT statement or in the report denition.
statement
Description is a report execution statement (described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement. is the name of a variable from the list of formal arguments to the report denition. You must pass at least the value of variable through the arguments of the report denition.
Usage
A group of records is all of the input records that contain the same value for the variable specied after the BEFORE GROUP OF keywords. You can include no more than one BEFORE GROUP OF control block for each group variable. When 4GL executes the statements in a BEFORE GROUP OF control block, the report variables have the values from the rst record of the new group. From this perspective, the BEFORE GROUP OF control block could be thought of as the on rst record of group control block.
BEFORE GROUP OF
Whenever the value of the group variable changes (after any AFTER GROUP OF block for the old value completes execution) Whenever the value of a higher-priority variable in the sort list changes (after any AFTER GROUP OF block for the old value completes execution)
How often the value of the group variable changes depends in part on whether the input records have been sorted by the SELECT statement:
s
If records are already sorted, the BEFORE GROUP OF block executes before 4GL processes the rst record of the group. If records are not sorted, the BEFORE GROUP OF block might be executed after any record because the value of the group variable can change with each record. If no ORDER BY section is specied, all BEFORE GROUP OF control blocks are executed in the same order in which they appear in the FORMAT section.
The BEFORE GROUP OF control block is designed to work with sorted data. You can sort the records by specifying a sort list in either of the following areas:
s s
An ORDER BY section in the report denition The ORDER BY clause of the SELECT statement in the report driver
To sort data in the report denition (with an ORDER BY section), make sure that the name of the group variable appears in both the ORDER BY section and in the BEFORE GROUP OF control block.
7-38
BEFORE GROUP OF
To sort data in the ORDER BY clause of a SELECT statement, perform the following tasks:
s
Use the column name in the ORDER BY clause of the SELECT statement as the group variable in the BEFORE GROUP OF control block. If the report contains BEFORE or AFTER GROUP OF control blocks, make sure that you include an ORDER EXTERNAL BY section in the report to specify the precedence of variables in the sort list.
If you specify sort lists in both the report driver and the report denition, the sort list in the ORDER BY section of the REPORT takes precedence. When 4GL starts to generate a report, it rst executes the BEFORE GROUP OF control blocks in descending order of priority before it executes the ON EVERY ROW control block. (See also Figure 7-3 on page 7-33.) If the report is not already at the top of the page, the SKIP TO TOP OF PAGE statement in a BEFORE GROUP OF control block causes the output for each group to start at the top of a page.
BEFORE GROUP OF r.customer_num SKIP TO TOP OF PAGE
statement
Element statement
Description is a report execution statement (described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement.
Usage
Because 4GL executes the FIRST PAGE HEADER control block before generating any output, you can use this control block to initialize variables that you use in the FORMAT section. In the following example, from a report that produces multiple labels across the page, the FIRST PAGE HEADER does not display any information:
FIRST PAGE HEADER {Nothing is displayed in this control block. It just initializes variables that are used in the ON EVERY ROW control block.} {Initialize label counter.} LET i = 1 {Determine label width; allow 8 spaces between labels).} LET l_size = 72/count1 {Divide 8 spaces among the labels across the page.} LET white = 8/count1
If a report driver includes START REPORT and FINISH REPORT statements, but no data records are passed to the report, this control block is not executed. That is, unless the report executes an OUTPUT TO REPORT statement that passes at least one input record to the report, neither the FIRST PAGE HEADER control block nor any other control block is executed.
7-40 IBM Informix 4GL Reference Manual
You cannot include a SKIP integer LINES statement inside a loop within this control block. The NEED statement is not valid within this control block. If you use an IFTHENELSE statement within this control block, the number of lines displayed by any PRINT statements following the THEN keyword must be equal to the number of lines displayed by any PRINT statements following the ELSE keyword. If you use a CASE, FOR, or WHILE statement that contains a PRINT statement within this control block, you must terminate the PRINT statement with a semicolon ( ; ). The semicolon suppresses any LINEFEED characters in the loop, keeping the number of lines in the header constant from page to page. You cannot use a PRINT lename statement to read and display text from a le within this control block.
s s
Corresponding restrictions also apply to CASE, FOR, IF, NEED, SKIP, PRINT, and WHILE statements in PAGE HEADER and PAGE TRAILER control blocks.
ON EVERY ROW
ON EVERY ROW
The ON EVERY ROW control block species the action to be taken by 4GL for every input record that is passed to the report denition.
ON EVERY ROW
statement
Element statement
Description is a report execution statement (described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement.
Usage
4GL executes the statements within the ON EVERY ROW control block for each new input record that is passed to the report. The following example is from a report that lists all the customers, their addresses, and their telephone numbers across the page:
ON EVERY ROW PRINT customer_num USING "###&", COLUMN 12, fname CLIPPED, 1 SPACE, lname CLIPPED, COLUMN 35, city CLIPPED, ", " , state, COLUMN 57, zipcode, COLUMN 65, phone
The next example displays information about items and their prices:
ON EVERY ROW PRINT snum USING "##&", COLUMN 10, manu_code, COLUMN 18, description CLIPPED, COLUMN 38, quantity USING "##&", COLUMN 43, unit_price USING "$$$$.&&", COLUMN 55, total_price USING "$$,$$$,$$$.&&"
7-42
ON EVERY ROW
4GL delays processing the PAGE HEADER control block (or the FIRST PAGE HEADER control block, if it exists) until it encounters the rst PRINT, SKIP, or NEED statement in the ON EVERY ROW control block.
ON LAST ROW
ON LAST ROW
The ON LAST ROW control block species the action that 4GL is to take after it processes the last input record that was passed to the report denition and encounters the FINISH REPORT statement.
ON LAST ROW
statement
Element statement
Description is a report execution statement (described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement.
Usage
The statements in the ON LAST ROW control block are executed after the statements in the ON EVERY ROW and AFTER GROUP OF control blocks if these blocks are present. When 4GL processes the statements in an ON LAST ROW control block, the variables that the report is processing still have the values from the nal record that the report processed. The ON LAST ROW control block can use aggregate functions to display report totals, as in this example:
ON LAST ROW SKIP 1 LINE PRINT COLUMN 12, "TOTAL NUMBER OF CUSTOMERS:", COLUMN 57, COUNT(*) USING "#&"
If the report driver executes the TERMINATE REPORT statement (rather than FINISH REPORT), the ON LAST ROW control block is not executed.
7-44
PAGE HEADER
PAGE HEADER
The PAGE HEADER control block species the action that 4GL takes before it begins processing each page of the report. It can specify what information, if any, appears at the top of each new page of output from the report.
PAGE HEADER
statement
Element statement
Description is a report execution statement (described in Statements in REPORT Control Blocks on page 7-48) or another 4GL statement.
Usage
You can use a PAGE HEADER control block to display column headings. The following example produces column headings for printing data across the page:
PAGE HEADER PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE
This control block is executed whenever a new page is added to the report. The TOP MARGIN specication (in the OUTPUT section) affects how many blank lines appear above the output produced by statements in the PAGE HEADER control block. You can use the PAGENO operator in a PRINT statement within a PAGE HEADER control block to display the current page number automatically at the top of every page. The FIRST PAGE HEADER control block overrides this control block on the rst page of a report.
PAGE HEADER
New group values can appear in the PAGE HEADER control block when this control block is executed after a simultaneous end-of-group and end-of-page situation. 4GL delays the processing of the PAGE HEADER control block until it encounters the rst PRINT, SKIP, or NEED statement in the ON EVERY ROW, BEFORE GROUP OF, or AFTER GROUP OF control block. This order guarantees that any group columns printed in the PAGE HEADER control block have the same values as the columns printed in the ON EVERY ROW control block. The same restrictions apply to CASE, FOR, IF, NEED, SKIP, PRINT, and WHILE statements in the PAGE HEADER control block as apply to the FIRST PAGE HEADER and PAGE TRAILER control blocks.
7-46
PAGE TRAILER
PAGE TRAILER
The PAGE TRAILER control block species what information, if any, appears at the bottom of each page of output from the report. ,
PAGE TRAILER statement
Element statement
Usage
4GL executes the statements in the PAGE TRAILER control block before the PAGE HEADER control block when a new page is needed. New pages can be
PRINT attempts to print on a page that is already full. SKIP TO TOP OF PAGE is executed. SKIP n LINES species more lines than are available on the current
page.
s
NEED species more lines than are available on the current page.
You can use the PAGENO operator in a PRINT statement within a PAGE TRAILER control block to display the page number automatically at the bottom of every page, as in the following example:
PAGE TRAILER PRINT COLUMN 28, PAGENO USING "page <<<<"
The BOTTOM MARGIN specication (in the OUTPUT section) affects how close to the bottom of the page the output displays the page trailer.
7-48
EXIT REPORT Terminates processing of the report NEED PAUSE Forces a page break unless some specied number of lines is available on the current page of the report Allows the user to control scrolling of screen output (This statement has no effect if output is sent to any destination except the screen.) Appends a specied item to the output of the report Inserts blank lines into a report or forces a page break
PRINT SKIP
Descriptions of these report execution statements follow. None of them are valid within a MAIN or FUNCTION program block.
EXIT REPORT
EXIT REPORT
This statement causes processing of the report to terminate and returns control of execution to the next statement following the most recently executed OUTPUT TO REPORT statement of the report driver.
EXIT REPORT
Usage
Executing the EXIT REPORT statement has the following effects:
s s
Terminates the processing of the current report Deletes any intermediate les or temporary tables that were created in processing the REPORT statement
The EXIT REPORT statement has the same effect as TERMINATE REPORT except that EXIT REPORT must appear within the denition of the report that it terminates. This statement is useful after the program (or the user) becomes aware that a problem prevents the report from producing part of its intended output. For details of output that is not produced when a report terminates before it has nished processing, see TERMINATE REPORT on page 4-364. The distinction between EXIT REPORT and TERMINATE REPORT is contextual:
s s
EXIT REPORT is valid only within the REPORT denition. TERMINATE REPORT is valid only within the report driver.
You can include the TERMINATE REPORT statement in a REPORT denition, but there it can only reference a different report. In this case, it is logically part of the driver of the other report. The RETURN statement cannot be used as a substitute for EXIT REPORT. An error is issued if RETURN is encountered within the denition of a 4GL report.
7-50
EXIT REPORT
References
NEED, PAUSE, PRINT, REPORT, RETURN, SKIP, TERMINATE REPORT
NEED
NEED
This statement causes any subsequent display to start on the next page if fewer than the specied number of lines remain between the current line and the bottom margin of the current page of report output.
NEED lines LINES
Element lines
Description is an integer expression that returns a positive whole number that is less than the page length.
Usage
This statement has the effect of a conditional SKIP TO TOP OF PAGE statement, the condition being that the number to which the integer expression evaluates is greater than the number of lines that remain on the current page. The NEED statement can prevent the report from dividing parts of the output that you want to keep together on a single page. In the following example, the NEED statement causes the PRINT statement to send output to the next page unless at least six lines remain on the current page:
AFTER GROUP OF r.order_num NEED 6 LINES PRINT " ",r.order_date, 7 SPACES, GROUP SUM(r.total_price) USING "$$$$,$$$,$$$.&&"
The lines value species how many lines must remain between the line above the current character position and the bottom margin for the next PRINT statement to produce output on the current page. If fewer than lines remain on the page, 4GL prints both the PAGE TRAILER and the PAGE HEADER. The NEED statement does not include the BOTTOM MARGIN value when it compares lines to the number of lines remaining on the current page. NEED is not valid in FIRST PAGE HEADER, PAGE HEADER, or PAGE TRAILER blocks.
7-52
NEED
References
PAUSE, PRINT, REPORT, SKIP
PAUSE
PAUSE
The PAUSE statement temporarily suspends output to the screen until the user presses RETURN.
PAUSE
"string "
Element string Description is a quoted string that PAUSE displays. If you do not supply a message, PAUSE displays no message.
Usage
Output is sent by default to the screen unless the START REPORT statement or the OUTPUT section species a destination for report output. The PAUSE statement can be executed only if the report sends its output to the screen. It has no effect if you include a TO clause in either of these contexts:
s
In the OUTPUT section of the report denition (as described in The REPORT TO Clause on page 7-17) In the START REPORT statement of the report driver (as described in The TO Clause on page 4-355)
Include the PAUSE statement in the PAGE HEADER or PAGE TRAILER block of the report. For example, the following code causes 4GL to skip a line and pause at the end of each page of report output displayed on the screen:
PAGE TRAILER SKIP 1 LINE PAUSE "Press RETURN to display next screen."
References
NEED, PRINT, REPORT, SKIP
7-54
PRINT
The PRINT statement produces output from a report denition.
,
PRINT 4GL Expression p. 3-49 COLUMN left offset PAGENO LINENO BYTE variable Integer Expression p. 3-63 Aggregate Report Functions p. 5-14 Character Expression p. 3-69 TEXT variable FILE "lename" SPACE SPACES
WORDWRAP
Description is the identier of a 4GL variable of data type BYTE. is a quoted string that species the name of a text le to include in the output from the report. This string can include a pathname. is an expression that returns a positive whole number. It species a character position offset (from the left margin) no greater than the difference (right margin - left margin). is an expression that evaluates to a positive whole number. It species the absolute position of a temporary right margin. is the identier of an 4GL variable of the TEXT data type.
For the syntax of 4GL expressions like left offset, relative offset, and temporary that return integer values, see Integer Expressions on page 3-63.
Usage
This statement can include character data in the form of an ASCII le, a TEXT variable, or a comma-separated expression list of character expressions in the output of the report. (For TEXT variable or lename, you cannot specify additional output in the same PRINT statement.) You cannot display a BYTE value. Unless its scope of reference is global or the current module, any program variable in expression list must be declared in the DEFINE section. Output is sent to the destination specied in the REPORT TO clause of the OUTPUT section or in the TO clause of the START REPORT statement of the report driver. Otherwise, the screen is the destination. (For more information, see Sending Report Output to the Screen on page 7-19.) The following example is from the FORMAT section of a report denition that displays both quoted strings and values from rows of the customer table:
FIRST PAGE HEADER PRINT COLUMN 30, "CUSTOMER LIST" SKIP 2 LINES PRINT "Listings for the State of ", thisstate SKIP 2 LINES PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE PAGE HEADER PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE ON EVERY ROW PRINT customer_num USING "###&", COLUMN 12, fname CLIPPED, 1 SPACE, lname CLIPPED, COLUMN 35, city CLIPPED, ", " , state, COLUMN 57, zipcode, COLUMN 65, phone
You cannot use PRINT to display a BYTE value. The string "<byte value>" is the only output from PRINT of any object that is not of the TEXT data type.
7-56
If lename stores the value of a TEXT variable, the PRINT FILE lename statement has the same effect as specifying PRINT variable. (But only PRINT variable can include the WORDWRAP operator, as described in The WORDWRAP Operator on page 7-65.)
called simply the current position. On each page of a report, the initial default character position is the rst character position in the rst line. This position can be offset horizontally and vertically by margin and header specications and by executing any of the following statements:
s s s
The SKIP statement moves it down to the left margin of a new line. The NEED statement can conditionally move it to a new page. The PRINT statement moves it horizontally (and sometimes down).
Unless you use the keyword CLIPPED or USING, values are displayed with widths (including any sign) that depend on their declared data types.
Data Type BYTE CHAR DATE DATETIME DECIMAL Default Display Width (in characters) 12 (4GL displays the string <byte value> as the only output.) The length from the data type declaration 10 From 2 to 25, as implied in the data type declaration (2 + m), where m is the precision from the data type declaration (1 of 2) INFORMIX-4GL Reports 7-57
Data Type FLOAT INTEGER INTERVAL MONEY NCHAR NVARCHAR SMALLFLOAT SMALLINT TEXT VARCHAR
Default Display Width (in characters) 14 11 From 3 to 25, as implied in the data type declaration (3 + m), where m is the precision from the data type declaration The length from the data type declaration The data length of the character string 14 6 The data length of the character string The data length of the character string (2 of 2)
Unless you specify the FILE or WORDWRAP option, each PRINT statement displays output on a single line. This fragment displays output on two lines:
PRINT fname, lname PRINT city, ", " , state, 2 SPACES, zipcode
If you terminate a PRINT statement with a semicolon, however, you suppress the implicit LINEFEED character at the end of the line. The next example has the same effect as the PRINT statements in the previous example:
PRINT PRINT PRINT PRINT fname; lname city, ", "; state, 2 SPACES, zipcode
7-58
LENGTH( )
LINENOr MAX( )s
can use these expressions only within the FORMAT section of a REPORT denition. (A description appears later in this section.)
s You can use these aggregate functions only in the FORMAT section of a REPORT or
in statements of SQL. (The PERCENT( * ) aggregate cannot appear in these SQL statements.)
If the expression list applies the USING operator to format a DATE or MONEY value, the format string of the USING operator takes precedence over the DBDATE, DBMONEY, and DBFORMAT environment variables. For more information, see USING on page 5-123.
The expression (in parentheses) that SUM( ), AVG( ), MIN( ), or MAX( ) takes as an argument is typically of a number or INTERVAL data type; ARRAY, BYTE, RECORD, and TEXT are not valid. The AVG( ), SUM( ), MIN( ), and MAX( ) aggregates ignore input records for which their arguments have null values, but each returns NULL if every record has a null value for the argument.
7-60
Because no WHERE clause is specied here, GROUP SUM( ) combines the total_price of every item in the group included in the order.
GLS
Character values are sorted in code-set order, unless the COLLATION category in the locale les species a nondefault collation sequence (and the DBNLS environment variable is set to 1).
This returns the character whose numeric code you specify, just as described in Chapter 5, with one exception. To print a NULL character in a report, call the ASCII operator with 0 in a PRINT statement. For example, the following statement prints the NULL character:
PRINT ASCII 0
ASCII 0 only displays a NULL character in the PRINT statement. In other contexts, ASCII 0 returns a blank space. (See also ASCII on page 5-31.)
The operand must be a non-negative integer that species a character position offset (from the left margin) no greater than the line width (that is, no greater than the difference (right margin - left margin). This designation moves the character position to a left-offset, where 1 is the rst position after the left margin. If current position is greater than the operand, the COLUMN specication is ignored. (See also COLUMN on page 5-47.)
7-62
You can use PAGENO in the PAGE HEADER or PAGE TRAILER block, or in other control blocks to number sequentially the pages of a report. If you use the SQL aggregate COUNT(*) in the SELECT statement to nd how many records are returned by the query, and if the number of records that appear on each page of output is both xed and known, you can calculate the total number of pages, as in the following example:
SELECT COUNT(*) num FROM customer INTO TEMP cnt SELECT * FROM customer, cnt --Note temp table in FROM clause . . . --and no join is necessary FORMAT FIRST PAGE HEADER LET y = cnt/50--assumes 50 records per page; you must --round up if there is a remainder.} PAGE TRAILER PRINT "Page ", PAGENO USING "<<" " of ", y USING "<<"
If the calculated number of pages was 20, the rst page trailer would be:
Page 1 of 20
PAGENO is incremented with each page, so the last page trailer would be:
Page 20 of 20
This operator returns a string of blanks, equivalent to a quoted string containing the specied number of blanks. In a PRINT statement, these blanks are inserted at the current character position. Its operand must be an integer expression (as described in Integer Expressions on page 3-63) that returns a positive number, specifying an offset (from the current character position) no greater than the difference (right margin - current position). After PRINT SPACES has executed, the new current character position has moved to the right by the specied number of characters. Outside PRINT statements, SPACE or SPACES) and its operand must appear within parentheses. The following statements use this operator to separate values in PRINT statements, to concatenate six blank spaces to the string "=ZIP" and to print the result after the variable zipcode:
FORMAT ON EVERY ROW LET mystring = (6 SPACES), "=ZIP" PRINT fname, 2 SPACES, lname PRINT company PRINT address1 PRINT city, ", " , state, 2 SPACES, zipcode, mystring
7-64
Element temporary
Description is a literal integer (as described in Literal Integers on page 3-65) that species a character position (from the left edge of the page) of a temporary right margin. is the name of a 4GL variable of the TEXT data type.
TEXT variable
The WORDWRAP operator automatically wraps successive segments of long character strings onto successive lines of report output. Any string value that is too long to t between the current position and the right margin is divided into segments and displayed between temporary margins:
s s
The current character position becomes the temporary left margin. Unless you specify RIGHT MARGIN, the right margin defaults to 132, or to the size value from the RIGHT MARGIN clause of the OUTPUT section.
Specify WORDWRAP RIGHT MARGIN temporary to set a temporary right margin, counting from the left edge of the page. This value cannot be smaller than the current character position or greater than 132 (or the size value from the RIGHT MARGIN clause of the OUTPUT section). The current character position becomes the temporary left margin. These temporary values override the specied or default left and right margins from the OUTPUT section. After the PRINT statement has executed, any explicit or default margins from the OUTPUT section are restored. The following PRINT statement species a temporary left margin in column 10 and a temporary right margin in column 70 to display the character string that is stored in the 4GL variable called mynovel:
PRINT COLUMN 10, mynovel WORDWRAP RIGHT MARGIN 70
Prints blank characters only to the right margin Discards any remaining blanks from the blank string or tab Starts a new line at the temporary left margin Processes the next word
4GL starts a new line when a word plus the next blank space cannot t on the
current line. If all words are separated by a single space, this action creates an even left margin. 4GL applies the following rules (in descending order of precedence) to the portion of the data string within the right margin:
s s
Break at any LINEFEED, or ENTER, or LINEFEED, ENTER pair. Break at the last blank (ASCII 32) or TAB character before the right margin. Break at the right margin, if no character farther to the left is a blank, ENTER, TAB, or LINEFEED character.
4GL maintains page discipline under the WORDWRAP option. If the string is too long for the current page, 4GL executes the statements in any page trailer
and header control blocks before continuing output onto a new page.
GLS
7-66
4GL reports use the wrap-down method for WORDWRAP and kinsoku
processing. The wrap-down method forces down to the next line characters that are prohibited from ending a line. A character that precedes another that is prohibited from beginning a line can also wrap down to the next line. Characters that are prohibited from beginning or ending a line must be listed in the locale. 4GL tests for prohibited characters at the beginning and ending of a line, testing the rst and last visible characters. The kinsoku processing only happens once for each line. That is, no further kinsoku processing occurs, even if prohibited characters are still on the same line after the rst kinsoku processing.
References
DISPLAY, NEED, REPORT, SKIP
SKIP
SKIP
The SKIP statement can insert blank lines into the output of a report or advance the character position to the top of the next page of report output.
SKIP TO TOP OF PAGE integer LINE LINES
Element integer
Description is a literal integer (as described in Literal Integers on page 3-65) that species the number of lines.
Usage
The SKIP statement allows you to insert blank lines into report output or to skip to the top of the next page as if you had included an equivalent number of PRINT statements without specifying any expression list. The LINE and LINES keywords are synonyms in the SKIP statement. Output from any PAGE HEADER or PAGE TRAILER control block appears in its usual location. This program fragment prints names and addresses:
FIRST PAGE HEADER PRINT COLUMN 30, "CUSTOMER LIST" SKIP 2 LINES PRINT "Listings for the State of ", thisstate SKIP 2 LINES PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE PAGE HEADER PRINT "NUMBER", COLUMN 12, "NAME", COLUMN 35, "LOCATION", COLUMN 57, "ZIP", COLUMN 65, "PHONE" SKIP 1 LINE ON EVERY ROW PRINT customer_num USING "####", COLUMN 12, fname CLIPPED, 1 SPACE, lname CLIPPED, COLUMN 35, city CLIPPED, ", " , state, COLUMN 57, zipcode, COLUMN 65, phone
7-68
SKIP
List of Appendixes
Appendix A Appendix B Appendix C Appendix D Appendix E Appendix F Appendix G Appendix H Appendix I Appendix J
The ASCII Character Set INFORMIX-4GL Utility Programs Using C with INFORMIX-4GL Environment Variables Developing Applications with Global Language Support Modifying termcap and terminfo Reserved Words The Demonstration Application SQL Statements That Can Be Embedded in 4GL Code Notices
Appendix
This appendix lists the ASCII (American Standard Code for Information Interchange) character set, in ascending order of numeric codes 0 through 127. In the default (U.S. English) locale, this ASCII collating sequence is the basis for relational comparisons of strings in INFORMIX-4GL and SQL Boolean expressions.
GLS
Nondefault locales always include the ASCII characters but can include additional non-ASCII characters and can specify other collation sequences. When character strings are sorted by 4GL, however, the code-set order is always the basis for collation; any other collation sequence specied in the locale les is ignored. See the Informix Guide to GLS Functionality for details of how Informix database servers perform collation in nondefault locales. In some situations (involving NCHAR or NVARCHAR values and nondefault locales), the database server and 4GL do not follow the same rules for collating character strings. See also Collation Order on page E-4. In the table that follows, a caret ( ^ ) prex in the rst Character column represents the CONTROL key.
Code 0 1 2 3 4 5 6 7 Character ^@ ^A ^B ^C ^D ^E ^F ^G Code 43 44 45 46 47 48 49 50 Character + , . / 0 1 2 Code 86 87 88 89 90 91 92 93 Character V W X Y Z [ \ ] (1 of 2)
Code 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
Code 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
Code 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
Character ^ _ ` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~ del
(2 of 2)
Appendix
The mkmessage utility compiles programmer-dened help messages for 4GL applications. The upscol utility enables you to establish default attributes for display elds that are linked to database columns in your screen forms. It can also establish initial default values for program variables and screen elds that you associate with columns of tables in your database.
help les, but only one can be in effect at a time. The structure of the message source le is as follows:
.num message-text
In the example, .num is a period followed by an integer, and message-text is one or more lines of characters. (Characters can include blanks and must be from the code set of the locale.) The le can contain as many messages as you like. Each help message should be preceded by a line with nothing on it but a period (in the rst column) and a unique integer num. The message-text line starts on the next line and continues until the next numbered line. Each line must end in a RETURN. All blank lines between two numbered lines are considered part of the message that belongs to the rst of the two numbers. Lines that begin with # are interpreted as comment lines (and ignored).
The integer num can specify the help message in your 4GL programs. (For 4GL statements that support a HELP clause for displaying contextual help messages, see the CONSTRUCT, INPUT, INPUT ARRAY, MENU, and PROMPT statement descriptions in Chapter 4, INFORMIX-4GL Statements.) If the message text occupies more than 20 lines, 4GL automatically breaks the message into pages of 20 lines. You can change these default page breaks by placing the CONTROL-L character in the rst column of a line in your message le to start a new page. 4GL handles clearing and redisplaying the screen. For an example of a message le, see helpdemo.src on page H-30.
Description is an ASCII source le of help messages. s the pathname of the executable output le.
After creating an output le with the mkmessage utility, specify out-le in the OPTIONS statement to identify it as the current help le. To use help messages from the help le on a eld-by-eld basis in an INPUT or INPUT ARRAY statement, you must use the INFIELD( ) and SHOWHELP( ) library functions that are supplied with 4GL. For example, you can use these functions as the following code segment demonstrates:
OPTIONS HELP FILE "stores7.hlp", HELP KEY F1 ... INPUT pr_fname, pr_lname, pr_phone FROM fname, lname, phone HELP 101 ON KEY (F1) CASE WHEN INFIELD(lname) CALL showhelp(111) WHEN INFIELD(fname)
CALL showhelp(112) WHEN INFIELD(phone) CALL showhelp(113) OTHERWISE CALL showhelp(101) END CASE END INPUT
The executable le 4glusr.iem is initially installed in the directory $INFORMIX/msg. 4GL looks for message les in one of two directories, namely /$INFORMIXDIR/$DBLANG or else /$INFORMIXDIR/msg. If DBLANG is dened, 4GL looks only in /$INFORMIXDIR/$DBLANG. If this directory is not dened, 4GL looks only in /$INFORMIXDIR/msg. You must place the newly modied le 4glusr.iem in the appropriate /$INFORMIXDIR/msg or /$INFORMIXDIR/$DBLANG directory.
Validate. Updates the information in syscolval. Attributes. Updates the information in syscolatt. Exit. Returns to the operating system.
If you select either Validate or Attributes, upscol checks whether the corresponding table exists and, if not, upscol asks whether you want to create the table. In the text that follows, the corresponding table is called syscol. If you choose not to create it, enter n, and you return to the UPDATE SYSCOL menu. If the data validation table already exists, or if you enter y to create it, upscol displays the CHOOSE TABLE screen and prompts you for the name of a table in the database. After you select a table, the CHOOSE COLUMN screen prompts you to select the name of a column whose default values you want to modify in syscol. In the illustrations that follow, tab-name represents the selected table (from the specied db-name database), and col-name represents the selected column within the tab-name table. An actual upscol session would display the SQL identiers of whatever database, table, and column you specied.
INFORMIX-4GL Utility Programs B-5
The selected table and column names appear, with the database name, on the dividing line beneath the next menu, which is called the ACTION menu.
ACTION: Add Update Remove Next Query Table Column Exit Add an entry to the data validation [or screen display attribute] table. --------- db-name:tab-name:col-name ------- Press CTRL-W for Help ------
Now upscol displays the rst row of syscol that relates to the table and column in the work area beneath this menu. If no such entries exist, a message stating this appears on the Error line. The options in the ACTION menu are these:
s s s
Add. Adds new rows to the syscol table. Update. Updates the currently displayed row. Remove. Removes the currently displayed row (after a prompt for verication). Next. Displays the next row of syscol. Query. Restarts the display at the rst row of syscol for the table and column. Table. Selects a new database table and column. Column. Selects a new column within the chosen table. Exit. Return to the UPDATE SYSCOL menu.
s s
s s s
The options are attribute names and their selection has the following effects:
s
Autonext. Produces a menu with three options, Yes, No, and Exit. Exit returns you to the VALIDATE menu. The default is No. Comment. Produces a prompt to enter a Comment line message. No quotation marks are required around the message, but it must t on a single screen line. Default. Produces a prompt to enter the DEFAULT attribute, formatted as described in Chapter 6. Quotation marks are required where necessary to avoid ambiguity. Include. Produces a prompt to enter the INCLUDE attribute, formatted as described in Chapter 6. Quotation marks are required where necessary to avoid ambiguity. Picture. Produces a prompt to enter the PICTURE attribute, formatted as described in Chapter 6. No quotation marks are required. Shift. Produces a menu with four options, Up, Down, None, and Exit. Up corresponds to the UPSHIFT attribute and Down to the DOWNSHIFT attribute. Exit returns you to the VALIDATE menu. The default is None. Verify. Produces a menu with three options, Yes, No, and Exit. Exit returns you to the VALIDATE menu. The default is No. Exit. Returns you to the ACTION menu.
The upscol utility adds or modies a row of syscolval after you complete each of these options except Exit.
INFORMIX-4GL Utility Programs B-7
The Update option on the ACTION menu takes you immediately to the ATTRIBUTE menu or prompt that corresponds to the current attribute for the current column. You can look at another attribute for the current column by using the Next option, start through the list again by using the Query option, remove the current attribute with the Remove option, and select a new column or table with the Column or Table option.
If you are adding a new row to syscolatt, a default row is displayed in the work area below the menu. If you are updating an existing row of syscolatt, the current row appears. No entry is made in syscolatt until you choose Exit_Set, so you can alter all the attributes before you decide whether to modify syscolatt (with Exit_Set) or to cancel the changes (with Discrd_Exit). The options of the ATTRIBUTE menu include screen attribute names, and their selection has the following effects:
s
Blink. Produces a menu with three options, Yes, No, and Exit. The default is No. Color. Produces a menu with the available color options (for color terminals) or intensities (for monochrome terminals) for display of data values in tab-name.col-name. You can toggle back and forth among the colors or intensities by pressing CONTROL-N. Fmt. Prompts you for the format string to be used when tabname.col-name is displayed.
Left. Produces a menu with three options, Yes, No, and Exit. Yes causes numeric data to be left-aligned within the screen eld. The default is No. Rev. Produces a menu with three options, Yes, No, and Exit. Yes causes the eld to be displayed in reverse video. The default is No. Under. Produces a menu with three options, Yes, No, and Exit. Yes causes the eld to be displayed with underlining. The default is No. Where. Prompts for the values and value ranges under which these attributes will apply. See Chapter 6 for allowable syntax. Discrd_Exit. Discards the indicated changes and returns you to the ACTION menu. Exit_Set. Enters the indicated changes into the syscolatt table and returns you to the ACTION menu.
After you complete each of these options except Discrd_Exit, upscol adds or modies a row of syscolatt. Whoever runs the upscol utility produces a pair of tables, syscolval and syscolatt, which provide default values for all the users of a database that is not ANSI compliant. If the current database is ANSI-compliant, however, the user who runs upscol becomes the owner of the syscolatt and syscolval tables specied at the upscol menus, but other users can produce their own user.syscolval and user.syscolatt tables. The default specications in an upscol table are applied by 4GL only to columns of tables that have the same owner as the upscol table. (For details, see Default Attributes in an ANSI-Compliant Database on page 6-84, and the INITIALIZE and VALIDATE statements in Chapter 6.)
Appendix
Write a 4GL program that calls C functions. Write a C program that calls 4GL functions.
To call either a C function or a 4GL function, you must know about the argument stack mechanism (discussed in Using the Argument Stack on page C-3) that 4GL uses to pass arguments between the functions and the calling code. This appendix discusses issues that relate to the application programming interface (API) between the 4GL language and the C language:
s
Calling a C function from a 4GL program The CALL statement of 4GL can invoke C functions that observe the calling conventions of the 4GL argument stack (as described in Calling a C Function from a 4GL Program on page C-12).
Calling a 4GL function from a C program For a C program to call a 4GL function, it must include a special header le. 4GL provides macros to initialize the argument stack and to support other requirements of the C language (as described in Macros for Calling 4GL Functions on page C-21).
from every data type of the C language (as described in Decimal Functions for C on page C-26).
The sections that describe these functions also contain code examples.
C-2 IBM Informix 4GL Reference Manual
Passing values between 4GL functions Receiving values from 4GL Passing values to 4GL
C code that calls any of the library functions that push, pop, or return values in the pushdown stack should include the le fglsys.h at the top of the le:
#include <fglsys.h>
When the program executes the CALL statement, 4GL rst notes the current argument stack depth. Then it pushes the function arguments onto the top of the stack in sequence from left to right (rst j and then k in the example). The stack receives not only the value of an argument but its data type as well (SMALLINT in the example).
C-3
The called function pops the arguments off the stack into local variables (a and b, respectively). In the example, the types of these variables (DECIMAL) are different from the types of the arguments that were pushed by the caller (SMALLINT). However, because the stack stores the type of each passed value, 4GL is able to convert the arguments to the proper type. In this instance, 4GL easily converts SMALLINT values to DECIMAL. Any type conversion that is supported by the LET statement is supported when popping stacked values. The RETURN statement pushes the returned values onto the stack in sequence from left to right (rst s and then d in the example). The RETURNING clause in the originating CALL statement then pops these values off the stack and into the specied variables (sum and diff, respectively) and converts the data types DECIMAL back to SMALLINT. When 4GL calls a function within an expression, the use of the stack is the same as in the CALL statement. The function is expected to return a single value on the stack, and 4GL attempts to convert this value as required to evaluate the expression. Important: Releases of 4GL earlier than Version 7.31 provided function libraries that used different function names. For details, see the fglsys.h le, included in 4GL. To consistently maintain differences on 32-bit and 64-bit platforms, 4GL 7.31 introduces new mappings for C data types. These new data types should be used when calling any 4GL library. For more details of the mapping between the new data types and Cdened variables, see the fgltypes.h le, included in 4GL. Function prototypes in the sections that follow use the function names that were provided in releases of 4GL earlier than Version 7.31, but show the data types of the current functions. The corresponding new function names are shown immediately after each list of pre-Version 7.31 function prototypes. Important: If you are compiling C programs with your 4GL program based on the pre-Version 7.31 functions for manipulating the 4GL function stack, in order to get the correct mappings from the old functions names to the new functions names, you must include fglsys.h as the header le in the C program.
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name popint popshort poplong popflo popdub popdec New Function Name ibm_lib4gl_popMInt ibm_lib4gl_popInt2 ibm_lib4gl_popInt4 ibm_lib4gl_popFloat ibm_lib4gl_popDouble ibm_lib4gl_popDecimal
Each of these functions, like all library functions for popping values, performs the following actions:
1. 2. 3.
Removes one value from the argument stack Converts its data type if necessary Copies it to the designated variable
C-5
If the value on the stack cannot be converted to the specied type, the result is undened. If the ibm_lib4gl_popInt2( ) function returns a value outside the range of -32767 to 32767, a conversion error has occurred. The dec_t structure referred to by ibm_lib4gl_popDecimal( ) is used to hold a DECIMAL value. It is discussed later in this appendix.
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name popquote popstring popvchar New Function Name ibm_lib4gl_popQuotedStr ibm_lib4gl_popString ibm_lib4gl_popVarChar
Both ibm_lib4gl_popQuotedStr( ) and ibm_lib4gl_popVarChar( ) copy exactly len bytes into the string buffer *qv. Here ibm_lib4gl_popQuotedStr( ) pads with spaces as necessary, but ibm_lib4gl_popVarChar( ) does not pad to the full length. The nal byte copied to the buffer is a null byte to terminate the string, so the maximum string data length is len-1. If the stacked argument is longer than len-1, its trailing bytes are lost. The len argument sets the maximum size of the receiving string buffer. Using ibm_lib4gl_popQuotedStr( ), you receive exactly len bytes (including trailing blank spaces and the null), even if the value on the stack is an empty string. To nd the true data length of a string retrieved by ibm_lib4gl_popQuotedStr( ), you must trim trailing spaces from the popped value. (The functions ibm_lib4gl_popString( ) and ibm_lib4gl_popQuotedStr( ) are identical, except that ibm_lib4gl_popString( ) automatically trims any trailing blanks.)
Because 4GL can convert values to CHAR from any data type except TEXT or BYTE, you can use these functions to pop almost any argument.
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name popdate popdtime popinv New Function Name ibm_lib4gl_popDate ibm_lib4gl_popDateTime ibm_lib4gl_popInterval
The structure types dtime_t and intrvl_t are used to represent DATETIME and INTERVAL data in a C program. They are discussed in the INFORMIX-ESQL/C Programmers Manual. The qual argument receives the binary representation of the DATETIME or INTERVAL qualier. The INFORMIX-ESQL/C Programmers Manual also discusses library functions for manipulating and printing DATE, DATETIME, and INTERVAL variables.
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name poplocator New Function Name ibm_lib4gl_popBlobLocator
C-7
The structure type loc_t denes a BYTE or TEXT value. Its use is discussed in your Administrators Guide. The ibm_lib4gl_popBlobLocator( ) function is unusual in that it does not copy the passed value. The function copies only the address of the passed value (as is indicated by the double asterisk in the function prototype). The following C fragment illustrates this:
mint get_a_text(mint nargs) { loc_t *theText; ibm_lib4gl_popBlobLocator(&theText) ... }
What ibm_lib4gl_popBlobLocator( ) stores at the address specied by its parameter is the address of the locator structure owned by the calling function. A change to the locator or the value that it describes is visible to the calling program, which is not the case with other data types. Any BYTE or TEXT argument must be popped as BYTE or TEXT because 4GL provides no automatic data type conversion.
When returning values to a 4GL program from a C function, you use the external return functions that are provided with 4GL to put the arguments on the stack. When passing values to a 4GL function from a C program, you use the external push functions that are provided with 4GL to put the arguments on the stack.
The external return functions copy their arguments to storage allocated outside the calling function. This storage is released when the returned value is popped. This situation makes it possible to return values from local variables of the function. The external push functions do not make a copy of the pushed data value in allocated memory. They require a pushed value to be a variable that will be valid for the duration of the call. It is up to the calling code to dispose of the values, as necessary, after the call. Sections that follow describe the external return and push functions.
C-8 IBM Informix 4GL Reference Manual
extern void retquote(int1 *str0) extern void retstring(int1 *str0) extern void retvchar(int1 *vc) extern void retdate(int4 date) extern void retdtime(dtime_t *dtv) extern void retinv(intrvl_t *inv)
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name retint retshort retlong retflo retdub retdec retquote retstring retvchar retdate retdtime retinv New Function Name ibm_lib4gl_returnMInt ibm_lib4gl_returnInt2 ibm_lib4gl_returnInt4 ibm_lib4gl_returnFloat ibm_lib4gl_returnDouble ibm_lib4gl_returnDecimal ibm_lib4gl_returnQuotedStr ibm_lib4gl_returnString ibm_lib4gl_returnVarChar ibm_lib4gl_returnDate ibm_lib4gl_returnDateTime ibm_lib4gl_returnInterval
The argument of ibm_lib4gl_returnQuotedStr( ) is a null-terminated string. The ibm_lib4gl_returnString( ) function is included only for symmetry; it internally calls ibm_lib4gl_returnQuotedStr( ). No library function is available for returning BYTE or TEXT values, which are passed by reference.
C-9
The C function can return data in whatever form is convenient. If conversion is possible, 4GL converts the data type as required when popping the value. If data type conversion is not possible, an error occurs. C functions called from 4GL must always exit with the statement return(n), where n is the number of return values pushed onto the stack. A function that returns nothing must exit with return(0).
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name pushint pushshort pushlong pushflo pushdub pushdec New Function Name ibm_lib4gl_pushMInt ibm_lib4gl_pushInt2 ibm_lib4gl_pushInt4 ibm_lib4gl_pushFloat ibm_lib4gl_pushDouble ibm_lib4gl_pushDecimal
The dec_t structure type and the C functions for manipulating decimal data are discussed later in this appendix. The second argument of ibm_lib4gl_pushDecimal( ), namely decp, species the decimal precision and scale. For example, to give a decimal variable named dec_var the precision of 15 and the scale of 2, you could specify the following values:
ibm_lib4gl_pushDecimal(dec_var, PRECMAKE(15,2));
You can use the following library functions to push character values:
extern void pushquote(int1 *cv, mint len) extern void pushvchar(int1 *vcv, mint len)
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name pushquote pushvchar New Function Name ibm_lib4gl_pushQuotedStr ibm_lib4gl_pushVarChar
The arguments to ibm_lib4gl_pushQuotedStr( ) and ibm_lib4gl_pushVarChar( ) are an unterminated character string and the count of characters that it contains (not including any null terminator). You can use the following library functions to push DATE, DATETIME, and
INTERVAL values:
extern void pushdate(int4 datv) extern void pushdtime(dtime_t *dtv) extern void pushinv(intrvl_t *inv)
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name pushdate pushdtime pushinv New Function Name ibm_lib4gl_pushDate ibm_lib4gl_pushDateTime ibm_lib4gl_pushInterval
The correspondence between pre-Version 7.31 function names and new function names follows.
Old Function Name pushlocator New Function Name ibm_lib4gl_pushBlobLocator
C-11
The name of the C function Any arguments to pass to the C function Any variables to return to the 4GL program
Important: To run or debug a 4GL Rapid Development System program that calls C functions, you must rst create a customized runner. For a complete description of this process, refer to Creating a Customized Runner on page 1-87. For example, the following CALL statement calls the C function sendmsg( ). It passes two arguments (chartype and 4, respectively) to the function and expects two arguments to be passed back (msg_status and return_code, respectively):
CALL sendmsg(chartype, 4) RETURNING msg_status, return_code
The C function receives an integer argument that species how many values were pushed on the argument stack (in this case, two arguments). This is the number of values to be popped off the stack in the C function. The function also needs to return values for the msg_status and return_code arguments before passing control back to the 4GL program. The C function should not assume it has been passed the correct number of stacked values. The C function should test its integer argument to see how many 4GL arguments were stacked for it. (If a function is called from two or more statements in the same source module, 4GL veries that the same number of arguments is used in each call. A function could be called, however, from different source modules, with a different number of arguments from each module. This error, if it is an error, is not caught by 4GL.)
The function returns the date of the next business day after a given date. Because the function must receive exactly one argument, the function checks for the number of arguments passed. If the function receives a different number of arguments, it terminates the program (with an identifying message).
C-13
The C function in the next example can operate with one, two, or three arguments. The purpose of the function is to return the index of the next occurrence of a given character in a string. The string is the rst argument and is required. The second argument is the character to search for; if it is omitted, a space character is used. The third argument is an offset at which to start the search; if it is omitted, zero is used.
#include <fglsys.h> #include <fgltypes.h> ... ... #define STSIZE 512+1 mint fglindex(mint nargs); { int1 theString[STSIZE], theChar[2]; mint offset, pos; *theChar = ''; /* initialize defaults */ offset = 0; switch(nargs) { case 3: /* fglindex(s,c,n) */ ibm_lib4gl_pushMInt(&offset); case 2: /* fglindex(s,c) */ ibm_lib4gl_pushQuotedStr(theChar,2); case 1: /* fglindex(s) */ ibm_lib4gl_pushQuotedStr(theString,STSIZE); break; default: /* zero or >3 parms, ret 0 */ for(;nargs;nargs) ibm_lib4gl_pushQuotedStr(theString,STSIZE); ibm_lib4gl_returnMInt(999); return(1); } if (pos = index(theString+offset,*theChar) ) ibm_lib4gl_returnMInt(offset+pos-1); else ibm_lib4gl_returnMInt(0); return(1); }
The switch statement is useful in popping the correct number of arguments from the stack. By arranging the valid cases in descending order, the correct number of arguments can be popped in the correct sequence with minimal coding. In this example, the C function does not terminate the 4GL program when given an incorrect number of arguments. Instead, it disposes of all stacked arguments by popping them as character strings. Then it returns an impossible value.
Important: A 4GL Rapid Development System program that calls C functions cannot specify as an argument to the C function a 4GL program variable whose scope of reference is global.
Include the fglapi.h header le. Execute the fgl_start( ) macro to perform initialization tasks. Execute the fgl_call( ) macro to call each 4GL function. If the 4GL function displays a form, execute the fgl_exitfm( ) macro to reset your terminal for character mode. At the end of the program, execute the fgl_end( ) macro to free resources.
To pass values between the C program and 4GL function, use the push and pop functions described in Using the Argument Stack on page C-3.
C-15
This section rst explains how to use these features of the API with C:
s s s s s
Including the fglapi.h le Initializing values Calling 4GL functions Handling Interrupt signals Compiling and executing the C program
It initializes the argument stack so that you can pass arguments between the C program and the 4GL functions. If you are using the p-code compiler, it species the lename (and path) of the le that contains the 4GL functions.
The following example demonstrates how to call the fgl_start( ) macro. It species a le named test as the le that contains the 4GL functions:
#include <fglapi.h> o4Main() { fgl_start("test"); ... }
If you compile the 4GL function to C code, the lename argument is optional and is ignored if you specify it. In this case, you can call fgl_start( ) as follows:
#include <fglapi.h> o4Main() { fgl_start(); ... }
Push the argument values that the function expects onto the argument stack Use the fgl_call( ) macro to identify the name of the 4GL function and to tell it how many arguments to expect
The 4GL function must perform the following actions to receive arguments from and to pass values back to the C program:
1. 2. 3.
Include the appropriate arguments in the FUNCTION statement Use the DEFINE statement to dene variables for all the arguments passed to the function Use the RETURN statement in the 4GL function to return control to the C program and to list any values to pass to the calling C program
The C program can then pop the values passed from the function off the argument stack.
C-17
For example, the C program listed on the next page calls a 4GL function named get_customer( ). The program passes one argument to the get_customer( ) function. Then get_customer( ) passes one argument back to the C program. The argument passed to the function is the lename and path of the demonstration database. The C program prompts the user for this lename. The get_customer( ) function displays a menu of the rst 10 customers in the customer table of the specied database. The user then chooses a customer name from the menu, and the function passes the chosen name back to the C program. Finally, the C program displays the name of the customer.
#include #include #include #include <fglapi.h> <fglsys.h> <fgltypes.h> <stdio.h>
o4Main() { int1 str[80]; fgl_start("example"); printf("enter the full path name of a STORES database: "); fflush(stdout); scanf("%s", str); ibm_lib4gl_pushQuotedStr(str, strlen(str)); fgl_call(get_customer, 1); ibm_lib4gl_popQuotedStr(str, 80); printf("name entered: %s\n", str); fgl_end(); }
COMMAND COMMAND COMMAND COMMAND COMMAND COMMAND COMMAND COMMAND END MENU END FUNCTION
cust_array[3] RETURN cust_array[3] cust_array[4] RETURN cust_array[4] cust_array[5] RETURN cust_array[5] cust_array[6] RETURN cust_array[6] cust_array[7] RETURN cust_array[7] cust_array[8] RETURN cust_array[8] cust_array[9] RETURN cust_array[9] cust_array[10] RETURN cust_array[10]
When compiling a C program that calls a 4GL function, you must specify the -api option of the compilation command. Do not specify the fgiusr.c le on the command line unless you are calling external C functions from 4GL.
C-19
The following examples illustrate the compilation and execution, using two source code les and one executable:
s s s
The le mymain.c contains the C program. The le my4gl.4gl contains the 4GL function. The le myprog.exe is the resulting executable.
For complete information on the c4gl command, see Compiling a 4GL Module on page 1-35.
For complete information on the fglpc command, see Compiling an RDS Source File on page 1-77. For complete information on the cfglgo command, see Creating a Customized Runner on page 1-87.
fgl_start( )
The fgl_start( ) macro initializes the 4GL argument stack, prepares for signal handling, and, if you are using the 4GL Rapid Development System, species the path of the le that contains the 4GL functions.
fgl_start(filename) int1 *filename;
lename
is the lename (and the directory path) of the le that contains the 4GL functions to call.
You can specify lename by using either a quoted string or a character variable. The le extension, .4go or .4gi, is optional. The following list describes the return codes of fgl_start( ) and the conditions that evoke them.
0 < 0
You must specify the fgl_start( ) macro before using any of the following items:
s s
C-21
Important: To avoid confusion, you might want to make fgl_start( ) the rst function call in a C program that calls 4GL functions. If you are using the 4GL Rapid Development System, you must specify lename. If you are using the C Compiler, lename is optional. For compatibility, however, you might want to specify an empty string, such as " ", as a placeholder for lename. Specifying an empty string makes it easier to convert a C Compiler program to an RDS program. This code example species test as the le that contains the 4GL functions:
#include <fglapi.h> o4Main() { ... fgl_start("test"); ... }
Once a 4GL function begins execution through use of the fgl_call( ) macro, the function has access to the arguments passed to it by fgl_call( ) and the command line arguments passed to the calling C function itself. The arguments passed by fgl_call( ) are accessed by the 4GL function in the normal mannerthrough its argument list. The command-line arguments passed to the calling C function, however, are accessed by the 4GL function through use of the 4GL functions ARG_VAL( ) and NUM_ARGS( ). These latter two functions operate in the normal way, as though the command-line arguments passed to the C function had been instead used as command-line arguments to execute the 4GL MAIN function block.
fgl_call( )
The fgl_call( ) macro calls the 4GL function to execute. This macro passes the following arguments to the 4GL function:
s s
The fgl_call( ) macro returns the number of arguments being passed back to the program from the function.
fgl_call(funcname, nparams) int1* funcname; mint nparams;
funcname nparams
is the name of the function to call. is the number of arguments you are passing to the function.
You must push onto the argument stack any values to be passed to the 4GL function before executing the fgl_call( ) macro. For more information on using the push functions, see The Push Library Functions on page C-10. To read any arguments passed back to the C program from the 4GL function, use the pop functions. For more information on using the pop functions, see Receiving Values from 4GL on page C-5. The following C source code pushes three arguments onto the argument stack, and then calls the out_rep1( ) function:
#include <fglapi.h> #include <fglsys.h> ... o4Main() { ... { fgl_start() ... ibm_lib4gl_pushQuotedStr(p->pw_name, strlen(p->pw_name)); ibm_lib4gl_pushQuotedStr(p->pw_dir, strlen(p->pw_dir)); ibm_lib4gl_pushMInt(p->pw_uid); fgl_call(out_rep1, 3); ... } ... }
C-23
fgl_exitfm( )
The fgl_exitfm( ) macro resets the terminal for character mode. Use this macro after calling a 4GL function that displays a form.
fgl_exitfm( )
Place this function after any fgl_call( ) macro that causes 4GL to display one or more forms. This macro resets the terminal for character mode. If you do not execute this macro, the terminal might behave unusually, and the end user might be unable to enter any input. The following example pushes a value onto the argument stack, calls the 4GL function, pops the returned value, and then executes the fgl_exitfm( ) macro to reset the terminal to character mode:
#include <fglapi.h> #include <fglsys.h> #include <stdio.h> o4Main() { fgl_start() ... ibm_lib4gl_pushQuotedStr(str, strlen(str)); fgl_call(get_customer, 1); ibm_lib4gl_popQuotedStr(str, 80); fgl_exitfm(); ... }
fgl_end( )
The fgl_end( ) macro frees resources resulting from the execution of a C program that calls a 4GL function.
fgl_end(
Deletes any temp les created by TEXT or BYTE objects Closes any les opened by the 4GL function Frees the allocated memory
Call this macro at the end of a C program that calls a 4GL function.
The following example demonstrates popping the value returned from 4GL, printing this value, and then freeing resources:
#include <fglapi.h> #include <fglsys.h> #include <stdio.h> o4Main() { fgl_start() ... ibm_lib4gl_popQuotedStr(str, 80); printf("name entered: %s\n", str); fgl_end() }
C-25
part) in base 100. In normalized form, the rst digit of the mantissa must be greater than zero. When used within a C program, DECIMAL-type numbers are stored in a C structure of the following type:
#define DECSIZE 16 struct decimal { int2 dec_exp; int2 dec_pos; int2 dec_ndgts; int1 dec_dgts[DECSIZE]; }; typedef struct decimal dec_t;
The decimal structure and the type denition dec_t can be found in the header le decimal.h. Include this le in all C source les that use any of the 4GL decimal functions. The decimal structure has four parts:
s
dec_exp. Holds the exponent of the normalized DECIMAL-type number. This exponent represents a power of 100. dec_pos. Holds the sign of the DECIMAL-type number (1 when the number is zero or greater; 0 when less than zero). dec_ndgts. Contains the number of base-100 signicant digits of the DECIMAL-type number. dec_dgts. A character array that holds the signicant digits of the normalized DECIMAL-type number (dec_dgts[0] != 0). Each character in the array is a one-byte binary number in base 100. The number of signicant digits in dec_dgts is stored in dec_ndgts.
All operations on DECIMAL-type numbers should take place through the functions provided in the 4GL library, as described in the following pages. Any other operations, modications, or analysis of DECIMAL-type numbers can produce unpredictable results. The following C function calls are available in 4GL to process DECIMAL-type numbers.
Function deccvasc( ) dectoasc( ) deccvint( ) dectoint( ) deccvlong( ) dectolong( ) deccvt( ) dectot( ) deccvdbl( ) dectodbl( ) decadd( ) decsub( ) decmul( ) decdiv( ) deccmp( ) deccopy( ) dececvt( ) decfcvt( ) Effect Convert C int1 type to DECIMAL type Convert DECIMAL type to C int1 type Convert C int type to DECIMAL type Convert DECIMAL type to C int type Convert C int4 type to DECIMAL type Convert DECIMAL type to C int4 type Convert C oat type to DECIMAL type Convert DECIMAL type to C oat type Convert C double type to DECIMAL type Convert DECIMAL type to C double type Add two DECIMAL numbers Subtract two DECIMAL numbers Multiply two DECIMAL numbers Divide two DECIMAL numbers Compare two DECIMAL numbers Copy a DECIMAL number Convert DECIMAL value to ASCII string Convert DECIMAL value to ASCII string Page C-28 C-30 C-32 C-33 C-34 C-35 C-36 C-37 C-38 C-39 C-40 C-40 C-40 C-40 C-41 C-42 C-43 C-43
C-27
deccvasc( )
Use deccvasc( ) to convert a value stored as a printable character in a C int1 type into a DECIMAL-type number.
deccvasc(cp, len, np) int1 *cp; mint len; dec_t *np;
cp
points to a string that holds the value to be converted. Leading blank spaces in the character string are ignored. The character string can have a leading plus ( + ) or minus ( - ) sign, a decimal point ( . ), and numbers to the right of the decimal point. The character string can contain an exponent preceded by either e or E. The exponent value can also be preceded by a plus or minus sign.
len np
is the length of the string. is a pointer to a dec_t structure that receives the result of the conversion.
These are the return codes of deccvasc( ) and the conditions that evoke them:
0 -1200 -1201 -1213 -1216
Function was successful. Number is too large to t into a DECIMAL-type (overow). Number is too small to t into a DECIMAL-type (underow). String has non-numeric characters. String has bad exponent.
Example
The following segment of code gets the character string input from the terminal, and converts it to number, a DECIMAL-type number:
#include <decimal.h> int1 input[80]; dec_t number; . . . /* get input from terminal */ getline(input); /* convert input into decimal number */ deccvasc(input, 32, &number);
C-29
dectoasc( )
Use dectoasc( ) to convert a DECIMAL-type number to an ASCII string.
dectoasc(np, cp, len, right) dec_t *np; int1 *cp; mint len; mint right;
np cp len
is a pointer to the decimal structure whose associated decimal value is to be converted to an ASCII string. is a pointer to the beginning of the character buffer to hold the ASCII string. is the maximum length (in bytes) of the string buffer. If the number does not t into a character string of length len, dectoasc( ) converts the number to exponential notation. If the number still does not t, dectoasc( ) lls the string with asterisks. If the number is shorter than the string, it is left-aligned and padded on the right with blank characters.
right
is an integer that indicates the number of decimal places to the right of the decimal point. If right equals -1, the number of decimal places is determined by the decimal value of *np.
Because the ASCII string returned by dectoasc( ) is not null-terminated, your program must add a null character to the string before printing it. The following list describes the return codes of dectoasc( ) and the conditions that evoke them:
0 -1
Example
The following segment of code accepts the character string input from the terminal and converts it to number, a DECIMAL-type number. The number value is then converted to the character string output, a null character is appended, and the string is printed.
#include <decimal.h> int1 input[80]; int1 output[16]; dec_t number; . . . /* get input from terminal */ getline(input); /* convert input into decimal number */ deccvasc(input, 32, &number); /* convert number to ASCII string */ dectoasc(&number, output, 15, 1); /* add null character to end of string prior to printing */ output[15] = ; /* print the value just entered */ printf("You just entered %s", output);
C-31
deccvint( )
Use deccvint( ) to convert a C type int to a DECIMAL-type number.
deccvint(integer, np) mint integer; dec_t *np;
integer np
is the integer that is to be converted. is a pointer to a dec_t structure that receives the result of the conversion.
The following list describes the return codes of deccvint( ) and the conditions that evoke them:
0 -1
Example
#include <decimal.h> dec_t decnum; /* convert the integer value -999 * into a DECIMAL-type number */ deccvint(-999, &decnum);
dectoint( )
Use dectoint( ) to convert a DECIMAL-type number to a C type int.
dectoint(np, ip) dec_t *np; mint *ip;
np ip
is a pointer to a decimal structure whose value is converted to an integer. is a pointer to the integer that receives the result of the conversion.
The following list describes the return codes of dectoint( ) and the conditions that evoke them:
0
Example
#include <decimal.h> dec_t mydecimal; mint myinteger; /* convert the value in * mydecimal into an integer * and place the results in * the variable myinteger. */ dectoint(&mydecimal, &myinteger);
C-33
deccvlong( )
Use deccvlong( ) to convert a C type int4 value to a DECIMAL-type number.
deccvlong(lng, np) int4 lng; dec_t *np;
lng np
is a pointer to a long integer. is a pointer to a dec_t structure that receives the result of the conversion.
Example
#include <decimal.h> dec_t mydecimal; int4 mylong; /* Set the decimal structure * mydecimal to 37. */ deccvlong(37L, &mydecimal); . . . mylong = 123456L; /* Convert the variable mylong into * a DECIMAL-type number held in * mydecimal. */ deccvlong(mylong, &mydecimal);
dectolong( )
Use dectolong( ) to convert a DECIMAL-type number to a C type int4.
dectolong(np, lngp) dec_t *np; int4 *lngp;
np lngp
is a pointer to a decimal structure. is a pointer to a long type that receives the result of the conversion.
These are the return codes of dectolong( ) and the conditions that evoke them:
0
Example
#include <decimal.h> dec_t mydecimal; int4 mylong; /* convert the DECIMAL-type value * held in the decimal structure * mydecimal to a long pointed to * by mylong. */ dectolong(&mydecimal, &mylong);
C-35
deccvt( )
Use deccvt( ) to convert a C type oat to a DECIMAL-type number.
deccvflt(flt, np) float flt; dec_t *np;
t np
is a oating-point number. is a pointer to a dec_t structure that receives the result of the conversion.
Example
#include <decimal.h> dec_t mydecimal; float myfloat; /* Set the decimal structure * myfloat to 3.14159. */ deccvflt(3.14159, &mydecimal); myfloat = 123456.78; /* Convert the variable myfloat into * a DECIMAL-type number held in * mydecimal. */ deccvflt(myfloat, &mydecimal);
dectot( )
Use dectot( ) to convert a DECIMAL-type number to a C type oat.
dectoflt(np, fltp) dec_t *np; float *fltp;
np tp
is a pointer to a decimal structure. is a pointer to a oating-point number that receives the result of the conversion.
On most implementations of C, the resulting oating-point number has eight signicant digits.
Example
#include <decimal.h> dec_t mydecimal; float myfloat; /* convert the DECIMAL-type value * held in the decimal structure * mydecimal to a floating point number pointed to * by myfloat. */ dectoflt(&mydecimal, &myfloat);
C-37
deccvdbl( )
Use deccvdbl( ) to convert a C type double to a DECIMAL-type number.
deccvdbl(dbl, np) double dbl; dec_t *np;
dbl np
is a double-precision oating-point number. is a pointer to a dec_t structure that receives the result of the conversion.
Example
#include <decimal.h> dec_t mydecimal; double mydouble; /* Set the decimal structure * mydecimal to 3.14159. */ deccvdbl(3.14159, &mydecimal); mydouble = 123456.78; /* Convert the variable mydouble into * a DECIMAL-type number held in * mydecimal. */ deccvdbl(mydouble, &mydecimal);
dectodbl( )
Use dectodbl( ) to convert a DECIMAL-type number to a C type double.
dectodbl(np, dblp) dec_t *np; double *dblp;
np dblp
is a pointer to a decimal structure. is a pointer to a double-precision, oating-point number that receives the result of the conversion.
The resulting double-precision value receives a total of 16 signicant digits on most implementations of the C language.
Example
#include <decimal.h> dec_t mydecimal; double mydouble; /* convert the DECIMAL-type value * held in the decimal structure * mydecimal to a double pointed to * by mydouble. */ dectodbl(&mydecimal, &mydouble);
C-39
n1 n2 result
is a pointer to the decimal structure of the rst operand. is a pointer to the decimal structure of the second operand. is a pointer to the decimal structure of the result of the operation. The result value can use the same pointer as either n1 or n2.
The following list describes the return codes of the decimal arithmetic routines and the conditions that evoke them:
0
-1200 Operation resulted in overow. -1201 Operation resulted in underow. -1202 Operation attempts to divide by zero.
deccmp( )
Use deccmp( ) to compare two DECIMAL-type numbers.
mint deccmp(n1, n2) dec_t *n1; dec_t *n2;
n1 n2
is a pointer to the decimal structure of the rst number. is a pointer to the decimal structure of the second number.
The following list describes the return codes of deccmp( ) and the conditions that evoke them:
0 -1 +1
The two values are the same. The rst value is less than the second. The rst value is greater than the second.
C-41
deccopy( )
Use deccopy( ) to copy the value of one dec_t structure to another.
deccopy(n1, n2) dec_t *n1; dec_t *n2;
n1 n2
is a pointer to the source dec_t structure. is a pointer to the destination dec_t structure.
np ndigit decpt
is a pointer to a dec_t structure that contains the value of the number that is to be converted to a string. is, for dececvt( ), the length of the ASCII string; for decfcvt( ), it is the number of digits to the right of the decimal point. points to an integer that is the position of the decimal point relative to the beginning of the string. A negative value for *decpt means to the left of the returned digits. is a pointer to the sign of the result. If the sign of the result is negative, *sign is nonzero; otherwise, the value is zero.
sign
The dececvt( ) function converts the decimal value pointed to by np into a null-terminated string of ndigit ASCII digits and returns a pointer to the string. The low-order digit of the DECIMAL number is rounded. The decfcvt( ) function is identical to dececvt( ) except that ndigit species the number of digits to the right of the decimal point instead of the total number of digits.
C-43
Examples
In the following example, np points to a dec_t structure that contains 12345.67, and *decpt points to an integer that contains a 5:
ptr ptr ptr ptr = = = = dececvt dececvt decfcvt decfcvt (np,4,&decpt,&sign); (np,10,&decpt,&sign); (np,1,&decpt,&sign); (np,3,&decpt,&sign); = = = = 1235 1234567000 123457 12345670
In this example, np points to a dec_t structure that contains a 0.001234 value, and *decpt points to an integer that contains a -2 value:
ptr ptr ptr ptr = = = = dececvt dececvt decfcvt decfcvt (np,4,&decpt,&sign); (np,10,&decpt,&sign); (np,1,&decpt,&sign); (np,3,&decpt,&sign); = 1234 = 1234000000 = = 1
Appendix
Environment Variables
Various environment variables can affect the functionality of your INFORMIX-4GL program. These environment variables can describe your terminal, specify search paths for les, or dene other parameters. This appendix describes environment variables that affect 4GL and shows how to set them. It is divided into three main sections:
s
Informix environment variables This section describes some Informix-dened environment variables that are used with 4GL. Many of these variables are not for frequent use but are included in case they are necessary for correct operation of 4GL.
GLS
You must set some or all of these variables to benet from GLS (global language support) if you are developing or running a 4GL application for a locale other than U.S. English. GLS is described in Appendix E, Developing Applications with Global Language Support.
s
database server recognizes This section describes some standard UNIX environment variables that are recognized by Informix products.
Some environment variables are required; others are optional. For example, you must set several UNIX environment variables (or else accept their default settings). This appendix also identies some environment variables that this version of 4GL ignores although earlier 4GL versions recognized them. (See also the Informix Guide to SQL: Reference for information about other environment variables that can affect Informix database servers.)
At the system prompt on the command line If you set an environment variable at the system prompt, you must reassign it the next time that you log in to the system.
For the C shell, .login or .cshrc For the Bourne shell or the Korn shell, .prole
An environment variable that is set in your .login, .cshrc, or .prole le is assigned automatically whenever you log in to the system. Warning: Make sure that you do not inadvertently set an environment variable differently in your .login and .cshrc C shell les.
s
In an environment-conguration le You can dene all the environment variables that are used by Informix products in this common or private le. Using a conguration le reduces the number of environment variables that you must set at the command line or in a shell le.
An environment-conguration le can contain comment lines (preceded by #) and variable lines and their values (separated by blanks and tabs), as in the following example:
# This is an example of an environment-configuration file # # These are Informix-defined variable settings # DBDATE DMY4DBFORMAT *:.:,:DM DBLANG german
Use the ENVIGNORE environment variable to later override one or more entries in this le. Use the following Informix chkenv utility to check the contents of an environment-conguration le and return an error message if there is a bad environment variable entry in the le or if the le is too large:
chkenv filename
The chkenv utility is described in the Informix Guide to SQL: Reference, in the chapter about SQL utilities. The common (shared) environment-conguration le resides in $INFORMIXDIR/etc/informix.rc. The permission for this shared le must be set to 644. A private environment-conguration le must be stored in the users home directory as .informix and must be readable by the user. Important: The rst time that you set an environment variable in a shell or conguration le, before you begin work with 4GL, rst log out and log back in, and then source the le (with C shell), or use . to execute an environment-conguration le (with a Bourne or Korn shell). This action allows the process to read your new setting. Resetting environment variables during a 4GL session generally has no effect on any 4GL program that is running because 4GL uses the settings that were in effect when you logged in rather than when program execution commenced.
Environment Variables
D-3
Use standard UNIX commands to set environment variables. Depending on the type of shell that you use, the following table shows how you set the (ctional) ABCD environment variable to value.
Shell C Bourne or Korn Korn Command
setenv ABCD value ABCD=value export ABCD export ABCD=value
When Bourne shell settings are shown in this appendix, the Korn shell (a superset of the Bourne shell) is always implied as well. Korn shell syntax allows for a shortcut, as shown in the preceding table. Important: The environment variables are case sensitive. For example, if you specify a lowercase letter where uppercase is required, your setting might result in the default value being used, rather than what you set, or other unexpected behavior.
The following diagram shows how the syntax for setting an environment variable is represented in this appendix. These diagrams always indicate the setting for the C shell; for the Bourne or Korn shell, follow the syntax in the preceding table.
setenv ABCD value
For more information on how to read syntax diagrams, see How to Read a Syntax Diagram on page 15 in the Introduction to this manual. To unset most of the environment variables shown in this appendix, enter the following command.
Shell C Bourne or Korn Command
unsetenv ABCD unset ABCD
The program, preprocessor, and any associated les and libraries of your product have been installed in the /usr/informix directory. The default database server for explicit or implicit connections is indicated by an entry in the $INFORMIXDIR/etc/sqlhosts le. (INFORMIXSERVER) The default directory for message les is $INFORMIXDIR/msg. (DBLANG unset; the LANG variable is no longer used by 4GL) If you are using INFORMIX-SE, the default or current database is in the current directory. (DBPATH)
Environment Variables
D-5
Temporary les for INFORMIX-SE are stored in the /tmp directory. (DBTEMP) The default terminal-dependent keyboard and screen capabilities are dened in the termcap le in the $INFORMIXDIR/etc directory. (INFORMIXTERM) For products that use an editor, the default editor is the predominant editor for the operating system, usually vi. (DBEDIT) The UNIX utility that sends les to a printer:
For UNIX System V, use lp. For BSD and other UNIX systems (DBPRINT), use lpr.
In the default locale (U.S. English), the default format for money values is $000.00. (DBMONEY set to $.) In the default locale (U.S. English), the default format for date values is MM/DD/YYYY. (DBDATE set to MDY4/) The default eld separator for data les of LOAD and UNLOAD statements is the pipe symbol (|=ASCII 124). (DBDELIMITER set to |)
Informix Environment Variable DBDELIMITER DBEDIT DBESCWT DBFORM DBFORMAT DBLANG DBMONEY DBPATH DBPRINT DBREMOTECMD DBSPACETEMP DBSRC DBTEMP DBTIME DBUPSPACE ENVIGNORE FET_BUF_SIZE FGLPCFLAGS FGLSKIPNXTPG INFORMIXC INFORMIXCONRETRY INFORMIXCONTIME INFORMIXDIR INFORMIXSERVER
Restrictions
Page D-19 D-20 D-21 D-23 D-25 D-28 D-30 D-32 D-35
Dynamic Server only Dynamic Server only Interactive Debugger only INFORMIX-SE only Not used by 4GL
D-36 D-37 D-38 D-39 D-39 D-40 D-41 D-42 D-43 D-43
Environment Variables
D-7
Informix Environment Variable INFORMIXSHMBASE INFORMIXSTACKSIZE INFORMIXTERM IXOLDFLDSCOPE LINES ONCONFIG PDQPRIORITY PROGRAM_DESIGN_DBS PSORT_DBTEMP PSORT_NPROCS SQLEXEC SQLRM SQLRMDIR SUPOUTPIPEMSG
Dynamic Server only Dynamic Server only No longer used Must be unset Must be unset
GLS
Restrictions
No longer used
(2 of 2)
For information about these GLS environment variables, see the Informix Guide to GLS Functionality and the Informix GLS Programmers Manual. The following table lists the UNIX environment variables.
UNIX Environment Variable PATH TERM TERMCAP TERMINFO Page D-67 D-69 D-70 D-71
Environment Variables
D-9
C4GLFLAGS
The environment variables C4GLFLAGS allows you to set certain compiler options as defaults so that they need not appear in the command line, simplifying many compilations. Typical values follow: -a -ansi -anyerr -keep -shared -z Checks array bounds at runtime. Issues warnings for Informix extensions to SQL syntax. Resets status when 4GL expressions are evaluated. Retains intermediate les during compilation. Uses shared 4GL program libraries. Supports functions with a variable number of arguments.
Informix recommends compiling all 4GL programs with -anyerr. If you use compiled 4GL and your port supports shared libraries, you can improve system performance and reduce program size by using the -shared option. Do not specify -phase, -e, or -c (or, for the C compiler, -P, -E, or -S) in this environment variable because these options prevent compilation from completing. For example, if you specify -e in the C4GLFLAGS variable, the system always stops compiling after producing a .c le, without producing object les or executable les. (See also FGLPCFLAGS later in this appendix.)
C4GLNOPARAMCHK
C4GLNOPARAMCHK
C4GLNOPARAMCHK is an environment variable that, if set, turns off the
error checking on the number of arguments passed into a function and on the number of values returned from it. By default, these items are now checked as stringently in 4GL that is compiled to C as they are in the p-code system (RDS). Compiled 4GL has always been different from RDS in how it checks the number of arguments passed to a function and the number of values returned from a function. RDS requires the number of arguments passed and the number of values returned to be correct. By default, 4GL now checks the number of arguments and number of return values, and generates a fatal error if the numbers are incorrect. Code that worked under RDS also works with the new compiled code; only code that did not work in p-code fails. You can disable this checking mechanism by setting C4GLNOPARAMCHK at compile time. The variable C4GLNOPARAMCHK must be set and exported in the user environment at compile time. It can have any value or no value. The ability to turn off parameter-count checking via C4GLNOPARAMCHK is provided as a migration aid only; it helps 4GL developers locate and correct parameter mismatches over time. The following behavior regarding parameter-count checking depends on C4GLNOPARAMCHK and on the error scope:
s
If the C4GLNOPARAMCHK environment variable is not set, all function calls and returned values are checked; an error is issued if there is a mismatch in the number of parameters passed or returned. If C4GLNOPARAMCHK is set and AnyError error scope is not in effect, parameter count checking code is not generated. If C4GLNOPARAMCHK is set and AnyError handling is in effect, if the WHENEVER ERROR action is CONTINUE, no parameter-count checking is generated; for any other error actions (such as STOP, GOTO, CALL), code for parameter-count checking is generated.
Environment Variables
D-11
CC
CC
The c4gl command uses the INFORMIXC and CC environment variables (defaulting to cc on most computers) in the final stage of compilation. Setting one of these environment variables lets you substitute any C compiler. Because CC is recognized by many versions of make, this environment variable is also compatible with other UNIX programs. You can use the following Bourne shell code to determine the compiler:
${INFORMIXC:=${CC:-cc}}
The C compiler used is the value of the INFORMIXC environment variable if it is not empty. If INFORMIXC is empty, the (non-empty) value of the CC environment variable is used. If both CC and INFORMIXC are empty, the default is cc. Important: If you use gcc, be aware that 4GL assumes that strings are writable, so you need to compile using the -fwritable-strings ag. Failure to specify this option can cause unpredictable results, possibly including core dumps.
COLUMNS
UNIX platforms support various ways to control the sizes of screens and
windows in terms of lines (or rows) and columns. Depending on the method that your platform uses, two environment variables, COLUMNS and LINES, might be useful in controlling the character dimensions of your screen. One common way to control the dimensions of screens is the use of input/ output control (ioctl()) calls. To see if your platform uses this method, enter the command stty -a. If the response includes explicit values for rows and columns, ioctl() control is in effect, as in the following example:
% stty -a speed 9600 baud; rows = 24; columns = 80; intr = ^c; quit = ^|; erase = ^h; kill = ^u;
If your platform uses ioctl() calls, the operating system or windowing facility probably provides a way to resize the screen using the mouse or trackball.
COLUMNS
If your platform does not use ioctl() calls to control screen dimensions, you can use the LINES and COLUMNS environment variables to specify the screen dimensions. Use the following syntax for setting COLUMNS.
setenv COLUMNS number
Element number
Description is a literal integer, specifying the horizontal width of the screen in columns (sometimes called character positions) in the screen display.
On such platforms, if LINES or COLUMNS is not set, the corresponding value is taken from the rows or columns eld in the terminfo or termcap entry in use, as indicated by the TERM environment variable. The following example sets COLUMNS to 80 and LINES to 24.
C shell
setenv COLUMNS 80 setenv LINES 24
If either LINES or COLUMNS is set to an invalid value (that is, to a value that is not a positive integer), the invalid value is ignored, and the required value is read from the termcap or terminfo entry as applicable.
Environment Variables
D-13
DBANSIWARN
DBANSIWARN
The DBANSIWARN environment variable indicates that you want to check for Informix extensions to the ANSI standard for SQL syntax. Unlike most environment variables, you do not need to set DBANSIWARN to a value. Setting it to any value or to no value, as follows, is sufcient.
setenv DBANSIWARN
Setting DBANSIWARN before you compile a 4GL program is functionally equivalent to including the -ansi ag in the command line. When the 4GL preprocessor recognizes Informix extensions to the ANSI standard for SQL syntax in your source code during compilation, warning messages are written to the screen. (Only SQL statements can cause such warnings; 4GL statements that are not SQL statements are not affected.) Similarly, setting the DBANSIWARN environment variable before executing a 4GL program is functionally equivalent to including the -ansi ag at the command line. If you set DBANSIWARN, a warning is displayed on the screen at runtime if 4GL detects an SQL statement that includes an Informix syntax extension to the ANSI standard for SQL. At runtime, DBANSIWARN causes the SQL Communication Area (SQLCA) variable SQLCA.SQLWARN.SQLAWARN[6] to be set to W when 4GL detects that an SQL statement that is not ANSI compliant is executed. (For more information on the SQLCA global record, see Error Handling with SQLCA on page 2-45 or refer to the Informix Guide to SQL: Reference.) Once you set DBANSIWARN, Informix extension checking is automatic until you log out or unset DBANSIWARN. To turn off checking for Informix syntax extensions, you can disable DBANSIWARN with the following command.
Shell C Bourne Command
unsetenv DBANSIWARN unset DBANSIWARN
DBCENTURY
DBCENTURY
The DBCENTURY environment variable species how to expand abbreviated one- and two-digit year specications within DATE and DATETIME values. Expansion is based on this setting (and on the system clock at runtime). In most versions prior to 4GL 7.2, if only the two trailing digits of a year were entered for literal DATE or DATETIME values, these digits were prexed with 19; thus, 12/31/01 was always expanded to 12/31/1901. DBCENTURY supports four new algorithms to expand abbreviated years into four-digit year values that end with the same digits (or digit) that the user entered.
setenv DBCENTURY = R C F P
Element C F P R
Description Use the past, future, or current year closest to the current date. Use the nearest year in the future to expand the entered value. Use the nearest year in the past to expand the entered value. Prex the entered value with the rst two digits of the current year.
Here past, current, and future are all relative to the system clock. Values are case sensitive; only these four uppercase letters are valid. If you specify anything else (for example, a lowercase letter), or if DBCENTURY is not set, R is used as the default. Three-digit years are not expanded. If a year is entered as a single digit, it is rst expanded to two digits by prexing it with a zero; DBCENTURY then expands this value to four digits. Years before 99 AD (or CE) require leading zeros (to avoid expansion).
Environment Variables
D-15
DBCENTURY
Important: If the database server and the client system have different settings for DBCENTURY, the client system setting takes precedence for abbreviations of years in dates entered through the 4GL application. Expansion is sensitive to the time of execution and to the accuracy of the system clock-calendar. You can avoid the need to rely on DBCENTURY by requiring the user to enter four-digit years or by setting the CENTURY attribute in the form specication of DATE and DATETIME elds. The following examples illustrate the effect of various DBCENTURY settings on expanding DATE and DATETIME values that include abbreviated years.
Runtime Date 11/11/1999 Abbreviated Value 1/1/10 DBCENTURY Setting R Resulting Value 01/01/1910 Runtime Date 11/11/1999 Abbreviated Value 1/1/0 DBCENTURY Setting R Resulting Value 01/01/1900 Runtime Date 04/06/2010 Abbreviated Value 1/1/50 DBCENTURY Setting R Resulting Value 01/01/2050 Runtime Date 4/6/1999 Abbreviated Value DATETIME (1-1) YEAR DBCENTURY Setting R Resulting Value 1901-1 Runtime Date 11/11/1999 Abbreviated Value DATETIME (1-12) YEAR TO MONTH DBCENTURY Setting R Resulting Value 1901-12
C F P C TO MONTH F P C F P C F P C F P
01/01/2010
01/01/2010
01/01/1910
01/01/2000
01/01/2000
01/01/1900
01/01/2050
01/01/2050
01/01/1950
2001-1
2001-1
1901-1
2001-12
2001-12
1901-12 (1 of 2)
DBDATE
Runtime Date 04/06/2010 Abbreviated Value DATETIME (50-1) YEAR TO MONTH DBCENTURY Setting R Resulting Value 2050-1
C F P
2050-1
2050-1
1950-1 (2 of 2)
A limitation of DBCENTURY is that it species a single global algorithm for all abbreviated years and applies that throughout the 4GL program. (For a more exible feature, see the CENTURY eld attribute in Chapter 6, Screen Forms. CENTURY can apply different expansion algorithms to abbreviated years at the individual eld level.)
DBDATE
DBDATE species the default display format for DATE values by indicating the following items:
s s s
The order of the month, day, and year time units within a date Whether the year is printed with two digits (Y2) or four digits (Y4) The time-unit separator between the month, day, and year
MD DM Y4 Y2 Y4 Y2 MD DM
setenv DBDATE
/ . 0
Element -, . / 0 D M Y2 Y4
Description are characters that are valid as time-unit separators. is the default time-unit separator for the default locale. is a zero that indicates no time-unit separator. is a character representing the day of the month. is a character representing the month. are characters that abbreviate the year as its last two digits. are characters that represent the year as four digits.
Environment Variables
D-17
DBDATE
Blank spaces are not valid between elements of the DBDATE setting. In the default locale, the default setting is MDY4/, where M represents the month, D represents the day, Y4 represents a four-digit year, and the slash (/) is a time-unit separator (for example, 9/22/1999 for September 22, 1999). Any printable character of your locale is valid as the time-unit separator except the digits one through nine. The zero ( 0 ) species that there is no separator. The slash ( / ) appears as the default separator if you attempt to specify any numeric character other than zero as the separator, or if you do not include any separator character in the DBDATE specication. The hyphen appears as the default separator in some non-English locales. You must always specify the separator character last. The number of digits that you specify for the year must always follow the Y. Date formatting specied in a USING clause or FORMAT attribute overrides the formatting specied in DBDATE. To make the date appear as mmddyy, set DBDATE as follows.
Shell C Bourne Command
setenv DBDATE MDY20 DBDATE=MDY20 export DBDATE
MDY represents the order of month, day, and year; 2 indicates two digits for the year; and 0 species no separator. As a result, the date is displayed as 122599.
To make the date appear in European format (dd-mm-yyyy), set the DBDATE environment variable as follows.
Shell C Bourne Command setenv DBDATE DMY4DBDATE=DMY4export DBDATE
DBDELIMITER
DMY represents the order of day, month, and year; 4 indicates four digits for the year; and - species a hyphen separator. As a result, the date is displayed as 25-12-1999.
DBDELIMITER
The DBDELIMITER environment variable species the eld delimiter used by the dbexport utility in unloaded data les or with the LOAD and UNLOAD statements in 4GL.
setenv DBDELIMITER 'delimiter'
Element delimiter
Any single character that is valid in the codeset of your locale is allowed, but do not specify any of the following characters:
s s s s s s
Hexadecimal numbers ( 0 through 9, a through f, A through F ) Newline character or CONTROL-J The backslash ( \ ) symbol The minus or hyphen ( - ) symbol (ASCII 45) The period ( . ) symbol (ASCII 46) Any character that your locale (or the DBFORMAT or DBMONEY environment variable) identies as the decimal separator.
Warning: No error message is issued if you specify any of these forbidden characters, but doing so can result in les of unloaded data that cannot be reloaded. The utilities that unload and load data do not automatically insert escape characters before the sign or before the decimal separator of number values.
Environment Variables
D-19
DBEDIT
The pipe ( | ) symbol (ASCII 124) is the default. To change the eld delimiter to a plus sign, set the DBDELIMITER environment variable as follows.
Shell C Bourne Command
setenv DBDELIMITER '+' DBDELIMITER='+' export DBDELIMITER
DBEDIT
The DBEDIT environment variable species the default text editor. If DBEDIT is set, the specied editor is called directly. If DBEDIT is not set, you are prompted to specify an editor as the default for the rest of the 4GL session.
setenv DBEDIT editor
Element editor
Description is the name of the text editor that you want as the default.
For most systems, the default editor is vi. If you use another editor, be sure that it creates ASCII les. Some word processors in document mode introduce printer control characters that can interfere with operation of 4GL. To specify the emacs text editor, set the DBEDIT environment variable as follows.
Shell C Bourne Command
setenv DBEDIT emacs DBEDIT=emacs export DBEDIT
DBESCWT
DBESCWT
The DBESCWT environment variable controls the way that 4GL programs interpret the sequence of characters that the function keys and arrow keys send on some types of terminals. When a user presses one of these keys, many terminal types send a sequence of characters that starts with the ESC character. 4GL uses the ESC character as the default ACCEPT key, so that after reading an ESC character, the software must read the next character to see whether it is one of those that make up a function key or arrow key sequence. If the computer or network is slow, the runtime software might interpret a function key keystroke as a distinct ESC character, later followed by one or more characters echoed to the screen. DBESCWT enables the programmer to distinguish such sequences by specifying the maximum delay between an ESC character and any subsequent character of the same escape sequence. The syntax for setting the DBESCWT environment variable follows.
setenv DBESCWT seconds
Element seconds
You can set DBESCWT to a value between 1 and 60, indicating the number of seconds that the software waits after it receives the ESC character from the keyboard before it decides that you have hit ESC rather than a function or arrow key. If DBESCWT is not set, the default wait time is one second. The following examples instruct 4GL to wait up to 2 seconds at runtime before interpreting an ESC character received from the keyboard as a distinct ESC character (rather than as the beginning of the escape sequence for an arrow key or function key).
C shell
setenv DBESCWT 2
Environment Variables
D-21
DBESCWT
Function and arrow keys normally generate escape sequences faster than a typist can type, so the 4GL application usually can make the distinction between the escape sequences of special keys and users typing the ESCAPE key. Only use DBESCWT on systems with poor response times or where the software is misinterpreting arrow and function key sequences. Setting DBESCWT slows the performance of your 4GL application.
DBFORM
DBFORM
The DBFORM environment variable species the subdirectory of $INFORMIXDIR (or full pathname) in which the menu form les for the currently active language reside. ($INFORMIXDIR stands for the name of the directory referenced by the environment variable INFORMIXDIR.) Menu form les provide a set of language-translated menus to replace the standard 4GL menus. Menu form les have the sufx .frm. Menu form les are included in language supplements, which contain instructions specifying where the les should be installed and what DBFORM settings to specify .
setenv DBFORM pathname
Element pathname
Description species the subdirectory of $INFORMIXDIR or the full pathname of the directory that contains the message les.
If DBFORM is not set, the default directory for menu form les is $INFORMIXDIR/forms/english. The les should be installed in a subdirectory under the forms subdirectory under $INFORMIXDIR. For example, French menu les could be installed in $INFORMIXDIR/forms/french or in $INFORMIXDIR/forms/fr.88591. The English language version will normally be installed in $INFORMIXDIR/forms or $INFORMIXDIR/forms/english. Non-English menu form les should not be installed in either of the locations where English les are normally found.
Environment Variables
D-23
DBFORM
Figure D-1 illustrates the search method employed for locating message les for a specic language (where the value set in the DBFORM environment variable is indicated as $DBFORM).
Figure D-1 Directory Search Order, Depending on $DBFORM
$INFORMIXDIR/forms/$DBFORM/
$INFORMIXDIR/forms/
$INFORMIXDIR/forms/english/
Use the mkdir command to create the appropriate subdirectory in $INFORMIXDIR/forms. Set the owner and group of the subdirectory to informix and the access permission for this directory to 755. Set the DBFORM environment variable to the new subdirectory, specifying only the subdirectory name and not the full pathname. Copy the .frm les to the new menu form directory specied by $INFORMIXDIR/forms/$DBFORM. All les in the menu form directory should have the owner and group informix and access permission 644.
5.
For example, you can store the set of menu form les for the French language in $INFORMIXDIR/forms/french as follows:
setenv DBFORM french
DBFORMAT
DBFORMAT
The DBFORMAT environment variable species the format in which values are entered, displayed, or passed to the database for number data types:
DECIMAL FLOAT INTEGER MONEY SMALLFLOAT SMALLINT
The default format specied in DBFORMAT affects numeric and monetary values in display, input, and output operations.
DBFORMAT can specify the leading and trailing currency symbols (but not
their default positions within a monetary value) and the decimal and thousands separators. The decimal and thousands separators dened by DBFORMAT apply to both monetary and other numeric data. Features of 4GL affected by the setting in DBFORMAT include (but are not restricted to) the following items:
s s s
USING operator or FORMAT attribute DISPLAY or PRINT statement LET statement, where a CHAR or VARCHAR variable is assigned a monetary or number value LOAD and UNLOAD statements that use ASCII les (or whatever the
*
front
*
thousands
decimal
*
back
'
Description is the trailing currency symbol. is a characters that you specify as a valid decimal separator. is the leading currency symbol. is a characters that you specify as a valid thousands separator. Environment Variables D-25
DBFORMAT
The asterisk ( * ) species that a symbol or separator is not applicable; it is the default for any front, thousands, or back term that you do not dene. If you specify more than one character for decimal or thousands, the values in the decimal or thousands list cannot be separated by spaces (nor by any other symbols). 4GL uses the rst value specied as the thousands or decimal separator when displaying the number or currency value in output. The user can include any of the decimal or thousands separators when entering values. Any printable character that your locale supports is valid for the thousands separator or for the decimal separator, except:
s s
The same character cannot be both the thousands and decimal separator. A blank space (ASCII 32) can be the thousands separator (and is conventionally used for this purpose in some locales). The asterisk ( * ) symbol is valid as the decimal separator, but is not valid as the thousands separator. In versions of 4GL prior to 6.0, the colon ( : ) was not allowed as the thousands separator. The colon symbol is supported in this version, but must be preceded by a backslash ( \ ), as in the specication :\::.:DM. The colon ( : ) symbol is supportd as a decimal separator but must be preceded by a backslash ( \ ) symbol in the DBFORMAT specication. You must include all three colons. Enclosing the DBFORMAT specication in a pair of single quotation marks is recommended to prevent the shell from attempting to interpret (or execute) any of the DBFORMAT characters. The setting in DBFORMAT also affects how formatting masks of the FORMAT attribute and of the USING operator are interpreted. In formatting masks of FORMAT and USING, the following symbols are not literal characters but are placeholders for what DBFORMAT species:
s s s
The dollar ( $ ) sign is a placeholder for the front currency symbol. The comma is a placeholder for the thousands separator. The period is a placeholder for the decimal separator.
In formatting masks of the FORMAT attribute, the at (@) sign is a placeholder for the back currency symbol. (The @ symbol has no special signicance in formatting masks for the USING operator.)
D-26 IBM Informix 4GL Reference Manual
DBFORMAT
The following table illustrates the results of different combinations of DBFORMAT setting and format string on the same value.
Value 1234.56 1234.56 1234.56 1234.56 Format String $$#,###.## $$#,###.## #,###.##@ #,###.##@ DBFORMAT Setting $:,:.: :.:,:DM $:,:.: :.:,:DM Displayed Result $1,234.56 1.234,56 1,234.56 1.234,56DM
When the user enters number or currency values, 4GL behaves as follows:
s
It disregards any front (leading) or back (trailing) currency symbol and any thousands separators that the user enters. If a symbol is entered that was dened as a decimal separator in DBFORMAT, it is interpreted as the decimal separator.
The DBFORMAT-dened leading or trailing currency symbol is displayed for MONEY values. If a leading or trailing currency symbol is specied by the FORMAT attribute for non-MONEY data types, the symbol is displayed. The thousands separator is not displayed unless it is included in a formatting mask of the FORMAT attribute or of the USING operator.
When MONEY values are converted to character strings by the LET statement, both automatic data type conversion and explicit conversion with a USING clause insert the DBFORMAT-dened separators and currency symbol into the converted strings. For example, suppose DBFORMAT is set as follows:
*:.:,:DM
Environment Variables
D-27
DBLANG
Here DM stands for deutsche marks. Values input by the user into a screen form are expected to contain commas, not periods, as their decimal separator because DBFORMAT has *:.:,:DM as its setting in this example.
DBLANG
The DBLANG variable species the subdirectory of $INFORMIXDIR (or the full pathname) in which the message les for the currently active language reside. (Here $INFORMIXDIR stands for the name of the directory referenced by the environment variable INFORMIXDIR.) Message les provide a set of error messages for the database server and tools that have been translated into a national language. Compiled message les have the sufx .iem. A language supplement contains the following items:
s s
Message les Instructions that specify where the les should be installed and what DBLANG settings to specify
DBLANG
Element pathname
Description species the subdirectory of $INFORMIXDIR or the full pathname of the directory that contains the message les.
If DBLANG is not set, the default directory in which message les are stored is $INFORMIXDIR/release/en_us/0333. For nondefault locales, some other le system must replace /en_us. For the directory structure of Informix GLS products, see Figure E-1 on page E-7. Figure D-2 illustrates the search method employed for locating message les for a particular language (where value of the variable DBLANG is designated as $DBLANG).
$INFORMIXDIR/msg/$DBLANG/ Figure D-2 Directory Search Order, Depending on $DBLANG
$INFORMIXDIR/msg/
$INFORMIXDIR/msg/english/
Environment Variables
D-29
DBMONEY
Use the mkdir command to create the appropriate subdirectory in $INFORMIXDIR/msg. Set the owner and group of the subdirectory to informix and the access permission for this directory to 755. Set the DBLANG environment variable to the new subdirectory, specifying only the subdirectory name and not the full pathname. Copy the .iem les to the directory $INFORMIXDIR/msg/$DBLANG. All les in the new message directory should have the owner and group informix and should have UNIX access permission 644.
Now you can run your 4GL program or otherwise continue your work. For example, you can store the set of message les for the French language in $INFORMIXDIR/msg/french as follows:
setenv DBLANG french
DBMONEY
The DBMONEY environment variable species the default display format for MONEY values and the default thousands separator and decimal separator for displaying DECIMAL values. The syntax for setting DBMONEY is as follows.
setenv DBMONEY
$
front
.
, back
Element front
back
Description is a character string representing a leading currency symbol that precedes the MONEY value. This string can be up to seven characters long and can contain any character except a comma or a period. is a character string representing a trailing currency symbol that follows the MONEY value. This string can be up to seven characters long and can contain any character except a comma or a period.
The term that follows front is a literal decimal separator symbol that separates the integral part from the fractional part of the MONEY value.
D-30 IBM Informix 4GL Reference Manual
DBMONEY
Because only its position within a DBMONEY setting indicates whether a symbol is the front or back currency symbol, the rst two terms are required. If you use DBMONEY to specify a back symbol, for example, you must also supply a front currency symbol and a decimal separator (a comma or period). Similarly, if you use DBMONEY to change the decimal separator from a period to a comma, you must also supply a front symbol. To avoid ambiguity in displayed numbers and currency values, do not use the thousands separator of DBFORMAT as the decimal separator of DBMONEY. For example, specifying comma as the DBFORMAT thousands separator dictates using the period as the DBMONEY decimal separator.
GLS
In the default (U.S. English) locale, the default setting for DBMONEY is:
$.
Here a dollar sign ( $ ) is the default front currency symbol that precedes the MONEY value, a period (.) separates the integral part from any fractional part of the MONEY value, and no trailing currency symbol is used. For example, in the default locale, 100.50 is formatted as $100.50. In some other locales, however, comma is the default decimal separator, and the conventions of some locales require a back trailing currency symbol. In some East Asian locales, currency symbols can be multibyte characters. Suppose that you want to represent MONEY values in deutsche marks, which conventionally use DM as the currency symbol and a comma as the decimal separator. You can set the DBMONEY environment variable as follows.
Shell C Bourne Command
setenv DBMONEY DM, DBMONEY=DM, export DBMONEY
Here, DM is the currency symbol preceding the MONEY value, and a comma separates the integral part from the fractional part of the MONEY value. As a result, the MONEY data value 100.50 is displayed as DM100,50.
Environment Variables
D-31
DBPATH
DBPATH
Use DBPATH to identify the database servers that contain databases (if you are using Dynamic Server) or the directories and database servers that contain databases (if you are using INFORMIX-SE ). The DBPATH environment variable also species a list of directories (in addition to the current directory) in which 4GL looks for command scripts (.sql les). The CONNECT, DATABASE, START DATABASE, and DROP DATABASE statements use DBPATH to locate the database under two conditions:
s
If the location of a database is not explicitly stated and if the database cannot be located in the default database server For INFORMIX-SE, to nd the default directory
The CREATE DATABASE statement does not use DBPATH. You can add a new DBPATH entry to existing entries. To do so, use the $ format described for the UNIX environment variable PATH. :
setenv DBPATH 166 pathname
//
servername
full_pathname
//
servername
Description is a full pathname, from root, for a directory in which .sql les are stored or in which INFORMIX-SE databases are stored. is a valid relative pathname for a directory in which .sql les are stored or in which INFORMIX-SE databases are stored. is the name of a Dynamic Server or INFORMIX-SE database server on which databases are stored. You cannot, however, reference database les by using a servername qualier.
DBPATH can contain up to 16 entries. Each entry (pathname, or servername, or servername and full_pathname) must be less than 128 characters long. In addition, the maximum length of DBPATH also depends on the hardware and operating system platform on which you are setting DBPATH.
DBPATH
When you access a database using the CONNECT, DATABASE, START DATABASE, or DROP DATABASE statement, the search for the database is done rst in the directory or database server specied in the statement. If no database server is specied, the default database server as set in the INFORMIXSERVER environment variable is used. For INFORMIX-SE, if no directory is specied in the statement, the default directory is searched for the database. (The default directory is the current working directory if the database server is on the local computer, or your login directory if the database server is on a remote computer.) If a directory is specied but is not a full path, the directory is considered to be relative to the default directory. If the database is not located during the initial search, and if DBPATH is set, the database servers or directories in DBPATH are searched for the indicated database. The entries to DBPATH are considered in order.
As shown in the previous example, if the pathname species a directory name but not a database server name, the directory is sought on the computer running the default database server as specied by the INFORMIXSERVER environment variable. For instance, with this example, if INFORMIXSERVER is set to quality, the DBPATH value is interpreted as follows, where the double slash precedes the database server name:
setenv DBPATH //quality/usr/joachim://quality/usr/sonja
Environment Variables
D-33
DBPATH
If you specify a local database server, the current working directory is searched for databases. If you specify a remote database server, the search for databases is done in the login directory of the user on the computer where the database server is running.
For INFORMIX-SE, you can set DBPATH to contain just the database server names (and no directory names) to locate only databases and not command scripts.
DBPRINT
DBPRINT
The DBPRINT environment variable species the print program that you want to use in producing output from your 4GL program to a list device.
setenv DBPRINT program
Element program
Description is the name of a command, shell script, or UNIX utility that supports standard ASCII input.
For most BSD UNIX systems, the default program is usually lpr. For UNIX System V, the default program is usually lp.
Set the DBPRINT environment variable as follows to specify the myprint print program.
Shell C Bourne or Korn Command
setenv DBPRINT myprint DBPRINT=myprint export DBPRINT
Environment Variables
D-35
DBREMOTECMD
DBREMOTECMD
You can set the DBREMOTECMD environment variable to override the default remote shell used when you perform remote tape operations with Dynamic Server. Set it by using either a simple command or the full pathname. If you use the full pathname, the database server searches your PATH for the specied command.
setenv DBREMOTECMD command pathname
Description is the command to override the default remote shell. is the pathname to override the default remote shell.
Informix highly recommends using the full pathname syntax on the interactive UNIX platform to avoid problems with like-named programs in other directories and possible confusion with the restricted shell (/usr/bin/rsh). Set the DBREMOTECMD environment variable as follows for a simple command name.
Shell C Bourne Command
setenv DBREMOTECMD rcmd DBREMOTECMD=rcmd export DBREMOTECMD
Set the DBREMOTECMD environment variable as follows to specify the full pathname.
Shell C Bourne Command
setenv DBREMOTECMD /usr/bin/remsh DBREMOTECMD=/usr/bin/remsh export DBREMOTECMD
DBSPACETEMP
For more information on DBREMOTECMD, see the Archive and Backup Guide. It discusses using remote tape devices for archives, restores, and logical log backups.
DBSPACETEMP
You can set the DBSPACETEMP environment variable to specify the dbspace to be used for building all temporary tables and for holding temporary les used for sorting. This arrangement spreads temporary space across any number of disk drives.
separator setenv DBSPACETEMP temp_dbspace
Description can be either colon or a comma. is a list of valid existing temporary dbspaces.
You can set the DBSPACETEMP environment variable to override the default dbspaces used for temporary tables and sorting space specied in the DBSPACETEMP conguration parameter in the conguration le. For example, you might set DBSPACETEMP as follows.
Shell C Bourne Command
setenv DBSPACETEMP sorttmp1: sorttmp2: sorttmp3 DBSPACETEMP=sorttmp1:sorttmp2:sorttmp3 export DBSPACETEMP
Separate the dbspace entries with either colons or commas. The number of dbspaces is limited by the maximum size of the environment variable, as dened by the UNIX shell. The default, if left unspecied, is the root dbspace. The database server does not create the specied dbspace if it does not exist.
Environment Variables
D-37
DBSRC
For the creation of temporary tables, if neither DBSPACETEMP nor the DBSPACETEMP parameter in the oncong le is set, the database server creates the temporary tables in the dbspace where the database was created. For sorting, the database server uses the following disk space for writing temporary information, in the following order of precedence:
1. 2. 3. 4.
The operating system directory (or directories) that are specied by PSORT_DBTEMP, if this environment variable is set The dbspace (or dbspaces) specied by DBSPACETEMP, if it is set The dbspace (or dbspaces) specied by the oncong parameter
DBSPACETEMP
DBSRC
The DBSRC environment variable species directories for .4gl source les. ;
setenv DBSRC pathname
Element pathname
The directories specied by DBSRC are part of the search path only during debugging session. (The Interactive Debugger must be purchased separately from 4GL.) You are not required to specify DBSRC. For example, the Debugger will search for les in the programs and krystl directories (outside its default search path) if you set DBSRC as follows.
Shell C Bourne Command
setenv DBSRC /b/junet/programs:/b/krystl DBSRC=/b/junet/programs:/b/krystl export DBSRC
DBTEMP
DBTEMP
The DBTEMP environment variable species the full pathname of the directory into which you want INFORMIX-SE to place its temporary les. You need not set DBTEMP if the default value, /tmp, is satisfactory.
setenv DBTEMP pathname
Element pathname
Set the DBTEMP environment variable as follows to specify the pathname usr/magda/mytemp.
Shell C Bourne Command
setenv DBTEMP usr/magda/mytemp DBTEMP=usr/magda/mytemp export DBTEMP
For the creation of temporary tables, if DBTEMP is not set, the temporary tables are created in the directory of the database (that is, the .dbs directory).
DBTIME
The DBTIME environment variable has no effect on 4GL programs. (For some Informix products, DBTIME can set a default format for DATETIME values.)
setenv DBTIME 'mask '
Element mask
Environment Variables
D-39
DBUPSPACE
DBUPSPACE
The DBUPSPACE environment variable lets you specify and thus constrain the amount of system disk space that the UPDATE STATISTICS statement can use when trying to simultaneously construct multiple column distributions.
setenv DBUPSPACE value
Element value
For example, if DBUPSPACE is set to 2500 (kilobytes) by the following command, no more than 2.5 megabytes of disk space is to be used to accomplish sorting during the execution of an UPDATE STATISTICS statement.
Shell C Bourne Command
setenv DBUPSPACE 2500 DBUPSPACE=2500 export DBUPSPACE
If a table requires 5 megabytes of disk space for sorting, UPDATE STATISTICS accomplishes the task in two passes; the distributions for one half of the columns are constructed with each pass. If you try to set DBUPSPACE to any value less than 1024 kilobytes, it is automatically set to 1024 kilobytes, but no error message is returned. If this value is not large enough to allow more than one distribution to be constructed at a time, at least one distribution is done, even if the amount of disk space required for the one is greater than specied in DBUPSPACE.
ENVIGNORE
ENVIGNORE
Use the ENVIGNORE environment variable to deactivate specied environment variable entries in the common (shared) and private environment-conguration les. :
setenv ENVIGNORE variable
Element variable
For example, to ignore the DBPATH and DBMONEY entries in the environment-conguration les, specify the following command.
Shell C Bourne Command
setenv ENVIGNORE DBPATH:DBMONEY ENVIGNORE=DBPATH:DBMONEY export ENVIGNORE
Directory $INFORMIXDIR/etc/informix.rc stores the common environmentconguration le. The private environment-conguration le is stored in the users home directory as .informix. See Where to Set Environment Variables on page D-2 for more information on creating or modifying an environment-conguration le.
ENVIGNORE itself cannot be set in an environment-conguration le.
Environment Variables
D-41
FET_BUF_SIZE
FET_BUF_SIZE
The fetch buffer is the buffer that the database server uses to send data (except for BYTE or TEXT data) to client applications. The buffer resides in the client process. You can set the size of the fetch buffer by setting the FET_BUF_SIZE environment variable to the desired value prior to runtime. This action sets the fetch buffer size for the duration of running the 4GL application.
setenv FET_BUF_SIZE size
Element size
Description is a literal integer that species the size of the fetch buffer (in bytes).
The bigger the buffer, the more data the database server can send to the application before returning control to the application. The greater the size of this buffer, the more rows can be returned, and the less often the application must wait while the database server retrieves rows. A large buffer can improve performance by reducing the overhead of relling the client-side buffer. For example, the following command sets this environment variable to 20,000 bytes (20 kilobytes).
Shell C Bourne Command
setenv FET_BUF_SIZE 20000 FET_BUF_SIZE=20000 export FET_BUF_SIZE
Specify the size value in bytes, up to a maximum value for a SMALLINT (or of a C language short) on your system. For most 32-bit systems, this value is 32,767 bytes. If the parameter is not set externally, a default is used. (As in most environment settings, a thousands separator is not valid in size.)
FGLPCFLAGS
FGLPCFLAGS
The environment variable FGLPCFLAGS allows you to set certain compiler options as defaults for 4GL programs that are compiled to p-code. These options simplify many compilations. Typical values are these: -ansi -anyerr -z Issues warnings for Informix extensions to SQL syntax. Resets status when 4GL expressions are evaluated. Supports functions with a variable number of arguments.
FGLSKIPNXTPG
The SKIP TO TOP OF PAGE command has no effect when a report is already at the top of the page (that is, when no data value has yet been sent to a new page). Programs that rely on the older behavior of SKIP TO TOP OF PAGE can override this effect if the environment variable FGLSKIPNXTPG is set at runtime to any non-blank value, using the following syntax.
setenv FGLSKIPNXTPG value
Element value
If you set FGLSKIPNXTPG to any value at report execution time, SKIP TO TOP OF PAGE forces a page change even if no data value has yet been printed in the body of the current page. The following examples set it to 1.
C shell
setenv FGLSKIPNXTPG 1
Environment Variables
D-43
INFORMIXC
INFORMIXC
The c4gl command uses the INFORMIXC and CC environment variables (defaulting to cc on most computers) in the final stage of compilation. Setting one of these environment variables lets you substitute any C compiler. Because CC is acknowledged by many versions of make, this environment variable is compatible with other programs also. Use the following Bourne shell code to determine the compiler:
${INFORMIXC:=${CC:-cc}}
For the compiler, 4GL uses an INFORMIXC value that is not empty. If no nonempty INFORMIXC value is specied, 4GL uses the (non-empty) value of the CC environment variable. If neither of those exist, the compiler defaults to cc. Important: For users of gcc, Informix assumes that strings are writable, so you need to compile using the -fwritable-strings option. Failure to do so can produce unpredictable results, possibly including core dumps.
INFORMIXCONRETRY
The INFORMIXCONRETRY environment variable enables you to specify the maximum number of additional connection attempts that should be made to each database server by the client. For example, if you set this environment variable to 4, no more than 5 attempts to connect will be made during the time limit specied by the INFORMIXCONTIME environment variable. Set the INFORMIXCONRETRY environment variable as follows.
setenv INFORMIXCONRETRY count
Element count
INFORMIXCONTIME
For example, you can set INFORMIXCONRETRY to three additional connection attempts (after the initial attempt) as follows.
Shell Bourne C Command
setenv INFORMIXCONRETRY 3 INFORMIXCONRETRY=3 export INFORMIXCONRETRY
The default value for INFORMIXCONRETRY is one retry after the initial connection attempt. The INFORMIXCONTIME setting, described in the next section, takes precedence over the INFORMIXCONRETRY setting. That is, if time expires after the third retry, no further attempts are made, even if INFORMIXCONRETRY was set to 10.
INFORMIXCONTIME
The INFORMIXCONTIME environment variable enables you to specify the minimum time limit, in seconds, for the SQL statement CONNECT to attempt to connect to a database server before it returns an error. You might encounter connection difculties related to system or network load problems. For instance, if the database server is busy establishing new SQL client threads, some of the clients might fail because the database server cannot issue a network function call fast enough. The INFORMIXCONTIME and INFORMIXCONRETRY environment variables let you congure your client-side connection capability to retry to connect instead of returning an error. Set the INFORMIXCONTIME environment variable as follows.
setenv INFORMIXCONTIME value
Element value
Description represents the minimum number of seconds spent in attempts to connect to each database server. Environment Variables D-45
INFORMIXCONTIME
If INFORMIXCONTIME is set to 60 and INFORMIXCONRETRY is set to 3, as shown in this appendix, attempts to connect to the database server (after the initial attempt at 0 seconds) will be made at 20, 40, and 60 seconds, if necessary, before aborting. This 20-second interval is the result of INFORMIXCONTIME divided by INFORMIXCONRETRY. If execution of the CONNECT statement involves searching DBPATH, the following rules apply:
s
All appropriate servers in the DBPATH setting are accessed at least once even though the INFORMIXCONTIME value might be exceeded. Thus, the CONNECT statement might take longer than the INFORMIXCONTIME time limit to return an error indicating connection failure or that the database was not found.
INFORMIXCONRETRY species how many additional attempted
The INFORMIXCONTIME value is initially divided among the number of database server entries specied in DBPATH. Thus, if DBPATH contains numerous database servers, increase the INFORMIXCONTIME value accordingly to allow for multiple connection attempts.
The default value for INFORMIXCONTIME is 15 seconds after the initial connection attempt. The INFORMIXCONTIME setting takes precedence over the INFORMIXCONRETRY setting; retry efforts could end after the INFORMIXCONTIME value has been exceeded, but before the INFORMIXCONRETRY value has been reached.
INFORMIXDIR
INFORMIXDIR
The INFORMIXDIR environment variable species the directory that contains the subdirectories in which your product les are installed. INFORMIXDIR must be set. If you have multiple versions of a database server, set INFORMIXDIR to the appropriate directory name for the version that you want to access. For more information about when to set the INFORMIXDIR environment variable, see the Installation Guide for your database server.
setenv INFORMIXDIR pathname
Element pathname
Description is the directory path where the product les are installed.
Do not set pathname to a path whose character-string value requires more than 64 bytes of storage. The following examples set the INFORMIXDIR environment variable to the recommended installation directory.
Shell C Bourne Command
setenv INFORMIXDIR /usr/informix INFORMIXDIR=/usr/informix export INFORMIXDIR
Environment Variables
D-47
INFORMIXSERVER
INFORMIXSERVER
The INFORMIXSERVER environment variable species the default database server to which an explicit or implicit connection is made by 4GL. The database server can be either local or remote.
setenv INFORMIXSERVER dbservername
Element dbservername
The value of INFORMIXSERVER must correspond to a valid dbservername entry in the $INFORMIXDIR/etc/sqlhosts le on the computer running the application. It must be specied using lowercase characters and cannot exceed 18 characters for Dynamic Server and cannot exceed 10 characters for INFORMIX-SE. For example, to specify the coral database server as the default for connection, enter the following command.
Shell C Bourne Command
setenv INFORMIXSERVER coral INFORMIXSERVER=coral export INFORMIXSERVER
INFORMIXSERVER species the database server to which an application connects if the CONNECT DEFAULT statement is executed. It also denes the
database server to which an initial implicit connection is established if the rst statement in an application is not a CONNECT statement. Important: INFORMIXSERVER must be set even if the application or 4GL does not use implicit or explicit default connections.
INFORMIXSHMBASE
INFORMIXSHMBASE
The INFORMIXSHMBASE environment variable affects only client applications connected to the database server using the IPC shared-memory (ipcshm) communication protocol. Use INFORMIXSHMBASE to specify where shared-memory communication segments are attached to the client process so that client applications can avoid collisions with other memory segments used by the application. If you do not set INFORMIXSHMBASE, the memory address of the communication segments defaults to an implementation-specic value such as 0x800000.
setenv INFORMIXSHMBASE value
Element value
The database server calculates the memory address where segments are attached by multiplying the value of INFORMIXSHMBASE by 1024. For example, to set the memory address to the value 0x800000, set the environment variable INFORMIXSHMBASE as follows.
Shell C Bourne Command
setenv INFORMIXSHMBASE 8192 INFORMIXSHMBASE=8192 export INFORMIXSHMBASE
Resetting INFORMIXSHMBASE requires a thorough understanding of how the application uses memory. Usually you do not reset INFORMIXSHMBASE. For more information, see your Administrators Guide.
Environment Variables
D-49
INFORMIXSTACKSIZE
INFORMIXSTACKSIZE
The INFORMIXSTACKSIZE environment variable affects only client applications connected to Dynamic Server. The database administrator can set INFORMIXSTACKSIZE to specify the stack size (in kilobytes) that the database server will use for a particular client session. Use INFORMIXSTACKSIZE to override the value of the oncong conguration parameter STACKSIZE for a particular application or user.
setenv INFORMIXSTACKSIZE value
Element value
For example, to decrease the INFORMIXSTACKSIZE to 20 kilobytes, enter the following command.
Shell C Bourne Command
setenv INFORMIXSTACKSIZE 20 INFORMIXSTACKSIZE=20 exportINFORMIXSTACKSIZE
Important: If INFORMIXSTACKSIZE is not set, the stack size is taken from the database server conguration parameter STACKSIZE, or it defaults to an implementation-specic value. The default stack size value for the primary thread for an SQL client is 32 kilobytes for nonrecursive database activity. Warning: For specic instructions for setting this value, see the Administrators Guide for your database server. If you incorrectly set the value of INFORMIXSTACKSIZE, it can cause the database server to fail.
INFORMIXTERM
INFORMIXTERM
On platforms that support terminfo capability, the INFORMIXTERM variable species whether 4GL should use the information in the termcap le or the terminfo directory. INFORMIXTERM determines terminal-dependent keyboard and screen capabilities such as the operation of function keys, color and intensity attributes in screen displays, and the denition of window border and graphics characters.
setenv INFORMIXTERM termcap terminfo
If INFORMIXTERM is not set, the default setting is termcap. When 4GL is installed on your system, a termcap le is placed in the etc subdirectory of $INFORMIXDIR. This le is a superset of an operating system termcap le. To use terminfo, your system must fully support the UNIX System V terminfo library interface. Not all UNIX platforms provide proper terminfo support. To determine whether your platform supports terminfo to Informix requirements (and therefore, whether setting INFORMIXDIR will have an effect), use the following command:
nm $INFORMIXDIR/bin/upscol | grep tigetstr
If the nm command yields no output, your platform does not have terminfo support, and setting INFORMIXTERM has no effect. If the command produces a reference line for the tigetstr function, your platform supports terminfo and you can use the INFORMIXTERM environment variable to select terminfo functionality. Here is an example of a reference line:
[3810] | 1281040| 80|FUNC |GLOB |0 |9 |tigetstr
You can use the termcap le supplied by Informix, the system termcap le, or a termcap le that you created yourself. You must set the TERMCAP environment variable if you do not use the default termcap le. The terminfo directory contains a le for each terminal name that has been dened. It is supported only on computers that provide full support for the UNIX System V terminfo library. For details, see the machine notes for your computer. (See also Appendix F, Modifying termcap and terminfo.)
Environment Variables D-51
INFORMIXTERM
If INFORMIXTERM is set to termcap, you must set the UNIX environment variable TERMCAP. Similarly, if INFORMIXTERM is set to terminfo, you must set the UNIX environment variable TERMINFO.
IXOLDFLDSCOPE
IXOLDFLDSCOPE
The IXOLDFLDSCOPE environment variable is recognized by Version 6.04 and later of 4GL. It allows programs that were written for Version 6.00 and earlier that have incorrect eld qualiers to avoid the eld qualier checking mechanism that was introduced with Version 6.01. To accomplish this task, you can use the following syntax for setting IXOLDFLDSCOPE.
setenv IXOLDFLDSCOPE value
Element value
Prior to Version 6.01, the following syntax ran successfully even if the qualier name did not match the name of the eld qualier in the form (table name, screen record name) or the literal FORMONLY:
{BEFORE|AFTER} FIELD qualifier.fieldname
Starting with Version 6.01, the qualiers for eld names and the qualiers on the form must match. As a result, some 4GL programs that ran prior to Version 6.01 now terminate with error -1129 at runtime because the qualier names, although stated explicitly, do not match. For example, the following fragment of a form specication declares a screen record called f_scrn_rec:
ATTRIBUTES a = FORMONLY.myfield1; ... INSTRUCTIONS SCREEN RECORD f_scrn_rec (FORMONLY.myfield1 THRU FORMONLY.myfieldn)
Suppose that a 4GL program referenced the same f_scrn_rec screen record in the following source code:
DEFINE progrec RECORD ... END RECORD ... INPUT progrec.* WITHOUT DEFAULTS FROM f_scrn_rec.* ... AFTER FIELD FORMONLY.myfield1 LET mykeyval = fgl_lastkey() END INPUT
Environment Variables
D-53
IXOLDFLDSCOPE
In the 4GL example, the INPUT statement uses the f_scrn_rec screen record name as the qualier, but the AFTER FIELD clause references the inherent qualier, FORMONLY. (If the elds were based on database columns, a table identier would replace FORMONLY.) The eld-matching code for CONSTRUCT and INPUT considers the proper qualier to be the one given in the FROM clause. A mismatch results, and a runtime error is issued:
-1129, Field in BEFORE/AFTER clause not found in form,
If you encounter this error, correct these references. If doing so presents a signicant barrier, however, to upgrading a 4GL program earlier than Version 6.01, you can use IXOLDFLDSCOPE as a backward-compatible mechanism to disable the qualier test. To activate this backward-compatible (no checking) mode, you must set and export the variable IXOLDFLDSCOPE in your environment at runtime (not at compile time). You can set IXOLDFLDSCOPE to any nonblank value, as in the following example, where the value is set to Y.
C shell
setenv IXOLDFLDSCOPE Y
Including IXOLDFLDSCOPE in the client environment disables checking eld qualiers. When it is set, however, you lose the benets of (for example) being able to use elds from multiple records in an INPUT statement even if a given eld name occurs in more than one participating record.
LINES
LINES
UNIX platforms support various ways to control the sizes of screens and
windows in terms of lines (or rows) and columns. Depending on the method that your platform uses, two environment variables, LINES and COLUMNS, might be useful in controlling the character dimensions of your screen. One common way to control the character dimensions of screens is the use of input/output control (ioctl()) calls. To see if your platform uses this method, enter the command stty -a. If the system response includes explicit values for rows and columns, ioctl() control is in effect. The following example illustrates this command:
% stty -a speed 9600 baud; rows = 24; columns = 80; intr = ^c; quit = ^|; erase = ^h; kill = ^u;
If your platform uses ioctl() calls to control screen dimensions, the operating system or windowing facility probably provides a way to resize the screen using a pointing device, such as the mouse or trackball. If your platform does not use ioctl() calls to control screen dimensions, you can use the LINES and COLUMNS environment variables to specify the screen dimensions. Use the following syntax for setting LINES.
setenv LINES number
Element number
Description is a literal integer, specifying the vertical height of the screen as a number of lines (sometimes called rows) in the screen display.
On such platforms, if LINES or COLUMNS is not set, the corresponding value is taken from the rows or columns eld in the terminfo or termcap entry in use, as indicated by the TERM environment variable.
Environment Variables
D-55
ONCONFIG
If either LINES or COLUMNS is set to an invalid value (that is, to a value that is not a positive integer), the invalid value is ignored, and the required value is read from the termcap or terminfo entry as applicable.
ONCONFIG
The database administrator can set the ONCONFIG environment variable (previously known as TBCONFIG), which contains the name of the UNIX le that holds the conguration parameters for the database server. This le is read as input to either the disk-space or shared-memory initialization procedure.
setenv ONCONFIG lename
Element lename
Description is the name of the le in $INFORMIXDIR/etc that contains the database server conguration parameters.
If you are not the database administrator, you need to set ONCONFIG only if more than one database server is initialized in your $INFORMIXDIR directory, and you want to maintain multiple conguration les with different values. If ONCONFIG is not set, the default is oncong.
PDQPRIORITY
Each database server has its own oncong le that must be stored in the $INFORMIXDIR/etc directory. You might prefer to name oncong so that it can easily be related to a specic database server. For example, when the desired lename is oncong3, you can set the ONCONFIG environment variable as follows.
Shell C Bourne Command
setenv ONCONFIG onconfig3 ONCONFIG=onconfig3 export ONCONFIG
For more information, see the Administrators Guide for your database server.
PDQPRIORITY
The PDQPRIORITY environment variable determines the amount of resources that the database server allocates to process a query in parallel. The following diagram shows the syntax for setting this variable.
setenv PDQPRIORITY LOW HIGH OFF percent-of-resources
Element percentage-of-resources
degree of parallelism.
s s
LOW: Data values are fetched from fragmented tables in parallel. OFF: Parallel data query is not enabled. Environment Variables D-57
PROGRAM_DESIGN_DBS
For example, if the desired setting is 25 percent, you can set the PDQPRIORITY environment variable as follows.
Shell C Bourne or Korn Command
setenv PDQPRIORITY 25 PDQPRIORITY=25 export PDQPRIORITY
PROGRAM_DESIGN_DBS
The 4GL and RDS Programmers Environments (i4gl and r4gl) use a relational database to store the names of the objects that are used to create programs and their build dependencies. This database is an Informix database. The default name for this database is syspgm4gl. In Versions 6.01 and later, both Programmers Environments let the user declare another name for the Programmers Environment database. This capability is particularly useful when you are using Dynamic Server because only one database can be named syspgm4gl at any given time. To specify a different name for the Programmers Environment database, set the PROGRAM_DESIGN_DBS environment variable to the desired name.
setenv PROGRAM_DESIGN_DBS db_name
Element db_name
Description is the nondefault name that you declare here for the Programmers Environment database.
Important: The dbname value must obey the rules for database names for your database server. That is, the name can contain only digits, letters, and underscores, and it can be no more than 10 bytes long (or 18 bytes for Dynamic Server).
PROGRAM_DESIGN_DBS
For example, to use the name jane_syspg for your Programmers Environment database, set PROGRAM_DESIGN_DBS to jane_syspg in your client environment before you run i4gl or r4gl.
Shell C Bourne or Korn Command
setenv PROGRAM_DESIGN_DBS jane_syspg PROGRAM_DESIGN_DBS=jane_syspg export PROGRAM_DESIGN_DBS
Environment Variables
D-59
PSORT_DBTEMP
PSORT_DBTEMP
The PSORT_DBTEMP environment variable affects only client applications connected to the database server.
PSORT_DBTEMP species a directory or directories where the Informix
database server writes the temporary les that it uses when sorting data. For more information on other places where the database server can write information during a sort, see DBSPACETEMP on page D-37. This variable is used even if the variable PSORT_NPROCS is not set. :
setenv PSORT_DBTEMP pathname
Element pathname
Description is the name of the UNIX directory used for intermediate writes during a sort.
Set the PSORT_DBTEMP environment variable as follows to specify the directory; for example, /usr/leif/tempsort.
Shell C Bourne Command
setenv PSORT_DBTEMP /usr/leif/tempsort PSORT_DBTEMP=/usr/leif/tempsort export PSORT_DBTEMP
For maximum performance, specify directories that reside in le systems on different disks.
PSORT_NPROCS
PSORT_NPROCS
The PSORT_NPROCS environment variable affects only client applications connected to the database server.
PSORT_NPROCS enables the Psort parallel-process sorting package to
improve performance. The setting denes the upper limit for the number of threads used to sort a query.
setenv PSORT_NPROCS value
Element value
Set the PSORT_NPROCS environment variable as follows to specify the maximum value.
Shell C Bourne Command
setenv PSORT_NPROCS 4 PSORT_NPROCS=4 export PSORT_NPROCS
To maximize the effectiveness of Psort, set PSORT_NPROCS to the number of available processors in the hardware. If PSORT_NPROCS is set to zero, Psort uses three (3) as the default number of threads. Use the following command to disable Psort.
Shell C Bourne Command
unsetenv PSORT_NPROCS unset PSORT_NPROCS
For additional information about the PSORT_NPROCS environment variable, see your Administrators Guide.
Environment Variables
D-61
SQLEXEC
SQLEXEC
This variable is not used in versions of 4GL later than 6.x. The SQLEXEC environment variable species the location of the Version 6.0 relay module executable that allows a Version 4.1 or earlier client to communicate indirectly with a local Version 6.0 Informix database server. You must, therefore, set SQLEXEC only to establish communications between a Version 4.1 or earlier client and a Version 6.0 database server.
setenv SQLEXEC pathname
Element pathname
Set SQLEXEC as follows to specify the full pathname of the relay module, which is in the lib subdirectory of your $INFORMIXDIR directory.
Shell C Bourne Command
setenv SQLEXEC $INFORMIXDIR/lib/sqlrm SQLEXEC=$INFORMIXDIR/lib/sqlrm export SQLEXEC
If you set the SQLEXEC environment variable on the C shell command line instead of in your .login or .cshrc le, you must include braces ( { } )symbols around the existing INFORMIXDIR, as follows.
Shell C Command
setenv SQLEXEC ${INFORMIXDIR}/lib/sqlrm
For information on the relay module, see the 6.0 version for the Administrators Guide for your database server. If you were previously using a 6.0 or later database server with 4GL 4.1, you were using either INFORMIX-NET or the INFORMIX Relay Module (sqlrm) to provide a compatible interface to the newer database servers.
D-62 IBM Informix 4GL Reference Manual
SUPOUTPIPEMSG
The SQLEXEC environment variable was set to a full or relative pathname ending in sqlexec (if using INFORMIX-NET) or sqlrm (if using the relay module), and the INFORMIXSERVER variable was set to the desired database server name. Additionally, if you were using the database server locally, the ONCONFIG environment variable might have been set to the name of the conguration le that belongs to the desired database server. After you install the new version of 4GL with your database servers, you need to change your environment variable settings as follows:
s
The SQLEXEC environment variable no longer applies. Unset it in your environments (including any login and shell conguration scripts). The INFORMIXSERVER (and ONCONFIG, if applicable) environment variable does not change as a direct result of the 4GL upgrade. For more about INFORMIXSERVER and ONCONFIG, see the Informix Guide to SQL: Reference.
Important: The specied database server must be on-line and accepting connections for 4GL to create or access a databases.
SUPOUTPIPEMSG
In a 4GL report, you can direct the output to a pipe either by appending TO PIPE to the START REPORT statement or by including the REPORT TO PIPE clause in the OUTPUT section of the report denition. A program that further processes the output, such as a shell script or printer routine, usually receives the output of the report through the pipe. In 4GL Versions 6.02 and earlier, if the program at the end of the pipe terminated while receiving data from the pipe, the 4GL application would exit silently without any indication of a problem. In 4GL Versions 6.03 and higher, when the receiving program at the reading end of the pipe dies, the next PRINT or SKIP statement will, by default, result in error -1324, A report output file cannot be written to. This situation cannot be handled by the 4GL program by using the WHENEVER ERROR statement.
Environment Variables
D-63
SQLRM
If you prefer the old behavior (where the 4GL program is silently terminated), you can retain that behavior using the SUPOUTPIPEMSG environment variable. Setting it to any value or to no value, as follows, is sufcient.
setenv DBANSIWARN
If SUPOUTPIPEMSG is set in the user environment at program execution time and a report output pipe dies prematurely, the 4GL program terminates without any error message.
SQLRM
This variable is not used in versions of 4GL later than 6.x. If the system administrator is conguring a client/server environment in which a Version 4.1 4GL client accesses a local Version 6.0 database server, the SQLRM environment variable must be unset before SQLEXEC can be used to spawn a Version 6.0 relay module. Unset SQLRM as follows.
Shell C Bourne Command
unsetenv SQLRM unset SQLRM
For information on the relay module, see the 6.0 version of your Administrators Guide.
SQLRMDIR
SQLRMDIR
This variable is not used in versions of 4GL later than 6.x. If the database administrator is conguring a client/server environment in which a Version 4.1 4GL client accesses a local Informix 6.0 database server, the SQLRM environment variable must be unset. Unset SQLRMDIR as follows.
Shell C Bourne Command
unsetenv SQLRMDIR unset SQLRMDIR
GLS
Environment Variables
D-65
For details, see the descriptions of these environment variables in the Informix Guide to GLS Functionality. These environment variables typically do not need to be set for applications that run only in the default (U.S. English) locale. If DBNLS is set to 1, 4GL looks in the locale les for a nondefault collation sequence. If a collation order is dened, 4GL uses it, rather than the code-set order, in all sort operations that it performs on character values. If DBNLS is not set, or if the locale les dene no collation sequence, 4GL sorts string values in code-set order.
Values in 4GL CL Value en_us.8859 ja_jp.ujis ja_jp.ujis en_us.8859 DL Value en_us.8859 ja_jp.ujis ja_jp.ujis ja_jp.ujis
ja_jp.ujis ja_jp.ujis --
In versions of 4GL later than 6.x, however, only tabs or blank spaces are valid in these les as the separator:
variable1 value2
If you are upgrading to this version from a 6.x version of 4GL for deployment in East Asian locales, you might need to edit these conguration les to replace any equal sign that was used as a separator in this context.
PATH
The PATH environment variable species the order in which the UNIX shell searches directories for executable programs. You must include the directory that contains 4GL in your PATH setting before you can use 4GL. :
setenv PATH pathname
Element pathname
Environment Variables
D-67
PATH
You can specify the correct search path in various ways. Be sure to include a colon ( : ) as a separator between UNIX directories. (On Windows NT systems, however, a semicolon ( ; ) is the pathname separator.) The following example uses the explicit path /usr/informix. This path must correspond to the INFORMIXDIR setting. The C shell example is valid for .login or .cshrc les.
Shell C Bourne Command
setenv PATH $PATH:/usr/informix/bin PATH=$PATH:/usr/informix/bin export PATH
The next example species $INFORMIXDIR instead of /usr/informix. It tells the shell to search the directories that were specied when INFORMIXDIR was set. The C shell example is valid for .login or .cshrc les.
Shell C Bourne or Korn Command
setenv PATH $PATH:$INFORMIXDIR/bin PATH=$PATH:$INFORMIXDIR/bin export PATH
You might prefer to use this version to ensure that your PATH entry does not conict with the path that was set in INFORMIXDIR and so that you do not need to reset PATH whenever you reset INFORMIXDIR. If you set PATH on the C shell command line instead of in your .login or .cshrc le, you must enclose the INFORMIXDIR and PATH settings within braces ( { } ), like this.
Shell C Command
setenv PATH ${INFORMIXDIR}/bin:${PATH }
TERM
TERM
The TERM environment variable is used for terminal handling. It enables 4GL to recognize and communicate with the terminal that you are using.
setenv TERM type
Element type
The terminal type specied in the TERM setting must correspond to an entry in the termcap le or terminfo directory. Before you can set the TERM environment variable, you must obtain the code for your terminal from the system administrator or database administrator. For example, to specify the terminal whose code is vt100, set the TERM environment variable as follows.
Shell C Bourne Command
setenv TERM vt100 TERM=vt100 export TERM
Environment Variables
D-69
TERMCAP
TERMCAP
The TERMCAP environment variable is used for terminal handling. It tells 4GL to communicate with the termcap le instead of the terminfo directory.
setenv TERMCAP pathname
Element pathname
The termcap le contains a list of various types of terminals and their characteristics. Set TERMCAP as follows.
Shell C Bourne or Korn Command
setenv TERMCAP /usr/informix/etc/termcap TERMCAP=/usr/informix/etc/termcap export TERMCAP
If you set the TERMCAP environment variable, be sure that the INFORMIXTERM environment variable is set to the default, termcap.
TERMINFO
TERMINFO
The TERMINFO environment variable is used for terminal handling. It is supported only on computers that provide full support for the UNIX System V terminfo library.
setenv TERMINFO /usr/lib/terminfo
TERMINFO tells 4GL to communicate with the terminfo directory instead of the termcap le. The terminfo directory has subdirectories that contain les pertaining to terminals and their characteristics.
If you set the TERMINFO environment variable, you also must set the INFORMIXTERM environment variable to terminfo. See also Appendix F, Modifying termcap and terminfo.
Environment Variables
D-71
Appendix
E-2
Localization usually involves setting the appropriate number, time, and currency formats for the intended country, as well as creating a translation of the runtime user interface (including help and error messages, prompts, menus, and reports). You can reduce the cost and effort of localization if the application is designed with international requirements in mind. This version of 4GL supports localization in several areas:
s s s s
Entry, display, and editing of non-English characters References to SQL identiers containing non-English characters Collation of strings containing non-English symbols Non-English formats for number, currency, and time values
For basic GLS concepts and for details of how Informix database servers and the Client SDK products implement GLS, see the Guide to GLS Functionality. Localization efforts are signicantly easier when internationalization is built into the application from the start. General Guidelines on page E-18 provides guidelines for writing 4GL programs that can be easily localized.
Collation Order
Code sets are based on logical characters, independent of the font that a display device uses to represent a given character. The size or font in which 4GL displays a given character is determined by factors independent of the code set. (For example, if you select a font that includes no representation of the Chinese character for star, only white space is displayed for that character until you specify a font that supports it.)
Collation Order
Collation order is the sequence in which character strings are sorted. Database servers can support collation in either code-set order (the sequence of code points) or localized order (some other predened sequence). See the chapter on GLS fundamentals in the Guide to GLS Functionality for details of localized collation.
4GL sorts strings in code-set order, unless the COLLATION category of the locale les species a localized order (and DBNLS is set to 1). Informix databases can use localized collation for NCHAR or NVARCHAR columns of the database but sort CHAR and VARCHAR values in code-set order.
E-4
Locales
Locales
For 4GL (and for Informix database servers and connectivity products), a locale is a set of les that specify the linguistic and cultural conventions that the user expects to see when the application runs. A locale can specify these:
s s s s s
The name of the code set The collation order for character-string data Culture-specic display formats for other data types The correspondence between uppercase and lowercase letters Determination of which characters are printable and which are nonprintable
The chapter on GLS fundamentals in the Guide to GLS Functionality provides details of formats for number, currency, and time values. If no locale is specied, default values are for United States English, which is the en_us.8859-1 locale on UNIX systems or Windows code page 1252. For deployment, 4GL is also delivered with the locale en_us.1252@dict, which corresponds to that Windows code page. The locale en_us.1252@dict allows you to compile and run programs that contain non-English characters from any single-byte language, but the default data formats are those of U.S. English. Alternatively, you can use the Setnet32 utility to specify some nondefault locale, such as one of those listed in Locales Supported by 4GL on page E-9.
languages other than U.S. English and for country-specic cultural issues, including the localized representation of dates, currency values, and numbers. 4GL supports the entry, retrieval, and display of multibyte characters in some East Asian languages, such as Japanese and Chinese. The following built-in functions or operators have been modied since version 6.0 of 4GL to provide support for non-English locales. Some can accept multibyte characters as arguments or operands, or can return values that include multibyte characters.
GLS-Enabled Built-In Function or Operator CLIPPED operator DOWNSHIFT( ) FGL_GETENV( ) FGL_KEYVAL( ) LENGTH( ) Substring ( [ ] ) operator UPSHIFT( ) WORDWRAP operator
See Chapter 5, Built-In Functions and Operators, for the syntax and semantics of these built-in functions and operators. (In addition, certain other built-in functions and operators of 4GL can also process or return multibyte values.)
E-6
The targeted hardware platform and operating system need to support the desired language and country combination. The operating system environment on both the client platform and the database server platform might require special versions to support the entry, manipulation, and display of non-English data.
The Informix products need to support the language. Informix products are 8-bit clean and allow entry, manipulation, and display of most European and Asian language data. Error messages generated by 4GL and the database server should be available in a localized version, so that only local languages appear in the runtime environment. All parts of the user interface created by the application developer (such as menus, prompts, error messages, and help) should be translated into the target language.
In many cases, the last three of these four requirements can be met by using an Informix language supplement. Your Informix sales representative can advise you regarding the availability of language supplements, of localized versions of Windows, and of database servers that are compatible with 4GL.
Language Supplements
Use of 4GL with some non-English languages might require an Informix language supplement specic to the conventions of the country or language. Language supplements are currently required, for example, for Informix database servers to support each of the following East Asian languages.
Country or Language Peoples Republic of China Taiwanese Japanese Korean Thai (simplied) E-8 IBM Informix 4GL Reference Manual Informix Language Supplement Language Supplement ZHCN 7.20 Language Supplement ZHTW 7.20 Language Supplement JA 7.20 Language Supplement KO 7.20 Language Supplement TH 7.20
Language supplements for these East Asian languages include locale les, translated message les, and translated menu les. Localized versions of 4GL for East Asian locales (for example, Japanese 4GL) will include the relevant les. See the release notes for additional information. A corresponding International Language Supplement includes locale les and code-set conversion les for most European languages. Because most of these les are included with the ESQL/C software that is provided with 4GL, this supplement need not be purchased by 4GL customers unless the required locale is not included with 4GL. When the Informix database server is installed in locales based on nonEnglish European languages, both the default (English) database server and the International Language Supplement must be installed. When 4GL is installed, the locale les must also be installed. Contact your Informix sales ofce for information regarding current support for specic locales.
4GL provides limited support for the Thai language through code set th_th.thai620, with Language Supplement TH 7.20, for non-composite Thai characters. (4GL does not support composite Thai characters.)
See the information on managing GLS les in the Informix Guide to GLS Functionality for an example of non-English locale les.
Set up the development environment. The system administration tools that you use must belong to the database server. You can use a UNIX terminal (if it supports the local code set).
2.
Write the code. Filenames (source and compiled) must contain only English characters.
E-10
3.
Compile and debug the code. The 4GL compiler can compile and link the components of the application. The Message Compiler can compile non-English text, so that runtime messages can be displayed in the local language. The user interface of the Message Compiler is in English. The INFORMIX-4GL Interactive Debugger is not GLS enabled. (The Dynamic 4GL Debugger has sufcient GLS capability to display non-English characters from the client locale.)
4.
Deploy the code. Deployment is relatively unrestricted. Applications that can be created through the steps outlined here are localized applications for a specic locale and therefore are not internationalized. (That is, they should not be used in another locale that requires, for example, a different code set from that of the message les.)
INFORMIX-4GL Language. Additional printable characters from the client locale, however, are valid within source code les in the following contexts:
s s s
Within comments Within 4GL identiers Within certain SQL identiers (as listed in the table in SQL and 4GL Identiers on page E-13) Within expressions where character-string literals are valid
In non-English locales, 4GL identiers can include non-ASCII characters in identiers if those characters are dened in the code set of the locale that CLIENT_LOCALE species. In multibyte East Asian locales that support languages whose written form is not alphabet-based, a 4GL identier need not begin with a letter, but the storage length cannot exceed 128 bytes. (A Chinese identier, for example, that contains 128 logical characters would exceed this limit if any logical character in the identier required more than one byte of storage.) Non-English characters in other contexts, or characters that the client locale does not support, will generally cause compilation errors. At runtime, the user can enter, edit, and display valid characters from the code set of the client locale. Whether a given character from a non-English code set is printable or nonprintable depends on the client locale. Values that include non-English characters can be passed between a 4GL application and the database server, if the client and server systems have the same locale. If the locales are different, data can still be transferred between the 4GL client and the database server, provided that the client locale includes appropriate code-set conversion tables. See Conguring the Language Environment on page E-24, or GLS fundamentals in the Informix Guide to GLS Functionality, for information about establishing a locale and about code-set conversion between locales. See also Handling Code-Set Conversion on page E-34.
Non-English Characters
The following features of the 4GL compiler are GLS-enabled to support nonEnglish characters that are valid in the client locale:
s s s s s
Names of identiers Values of CHAR and VARCHAR variables and formal arguments Characters within TEXT data Message text, quoted strings, and values returned by functions Text within comments, forms, menus, and output from reports
Named 4GL program entities include variables, functions, cursors, formal arguments, labels, reports, and prepared objects. 4GL has a limit of 128 bytes on the lengths of these names, but C compiler or linker restrictions might impose lower limits.
E-12 IBM Informix 4GL Reference Manual
names, indexes, and constraints. The rst character must be an alphabetic character, as dened by the locale, or an underscore (= ASCII 95) symbol. You can use alphanumeric characters and underscores ( _ ) for the rest of the SQL identier. Most SQL identiers can be up to 18 bytes in length, if the IFX_LONGID environment variable is not set, or if it is set to 0 on the database server. (If IFX_LONGID is set to 1, however, then SQL identiers can be up to 128 bytes in length.) What characters are valid in SQL identiers depends on the locale of the database server; see Client Locales and Database Server Locales on page E-10. Neither single-byte nor multibyte white space characters can appear in SQL identiers.
UNIX SE
For INFORMIX-SE database servers, whether non-English characters are permitted in the names of databases, tables, or log les depends on whether the operating system permits such characters in lenames. The user interface of the 4GL compiler is in English. If edit elds contain multibyte characters, there is no checking, and the results might be unpredictable. Embedded SQL statements can include valid non-English identiers for some database entities. The following tables summarize the instances where non-English characters are valid as identiers within 4GL source code modules. The rst table lists SQL identiers.
SQL Identier Column name Constraint name Database name Index name Log lename Stored procedure name Synonym Table name View name Allow Non-English Characters? Yes Yes Yes (Operating system limitations on INFORMIX-SE) Yes Yes (Operating system limitations on INFORMIX-SE) Yes Yes Yes (Operating system limitations on INFORMIX-SE) Yes
Input and output lenames for the 4GL compiler cannot be localized. Only ASCII characters are valid in input and output pathnames or lenames. (If support for uppercase ASCII letters is required, specify en_us.1252@dict as the locale at compile time. Uppercase letters are not dened in en_us.1252.)
Collation Sequence
The default collation (sorting) sequence in 4GL statements is implied by the code-set order in the les that dene the client locale. If the DBNLS environment variable is set to 1, 4GL looks in the locale les for the COLLATION category. If this category denes a nondefault collation order, 4GL uses this order, rather than the code-set order, for all sort operations that it performs on character values. (Here the COLLATION category functionally replaces the LC_COLLATE environment variable, which specied the nondefault sort order in earlier versions.) If the locale les dene a nondefault collation, this order is applied to all strings that the 4GL application sorts. In contrast, the database server applies localized collation (if any is dened) only to values from NCHAR and NVARCHAR database columns, but not to values from CHAR or VARCHAR columns (which it sorts in code-set order). The 4GL application and the database server can use a different collation sequence, or a 4GL application can connect to two or more database servers that use different collation sequences in SQL operations. The collation sequence can affect the value of Boolean expressions that use relational operators as well as the sorted order of rows in queries and in reports.
E-14
Locale Restrictions
The compiler requires the en_us.0333 locale. It accepts as input any source le containing data values in the format of the client locale. The compiler can generate binaries or p-code les with client-locale text strings. The runtime locale of a 4GL program must be the same as its compile-time locale.
Menu items, identiers, and text labels in the native language Features to avoid the creation of partial characters Non-English data within 4GL applications Cultural conventions, including the representation of date, time, currency, and numeric values, and localized collation Kinsoku processing for Japanese language text with WORDWRAP Icon modication without changing the 4GL application binary Text geometry that adjusts automatically to meet localization needs Application comparisons that adopt the comparison rules and collating sequence that the locale denes implicitly (SQL comparison and collation depend on the database server.)
s s s s
This version of 4GL does not support composite characters, such as are required in some code sets that support the Thai language.
Developing Applications with Global Language Support E-15
4GL comments and character string values can include multibyte characters
Character expressions and multiple-value character expressions Literal values within quoted strings Variables, formal arguments, and returned values of CHAR, VARCHAR, and TEXT data types
Multibyte characters can also appear in 4GL source code (or in user-dened query criteria) that species the SQL identier of any of the database objects listed in the table on SQL and 4GL Identiers on page E-13. 4GL does not, however, support multibyte characters as currency symbols or as separators in display formats that DBDATE or DBFORMAT species.
Logical Characters
Within a single-byte locale, every character of data within character-string values requires only a single byte of memory storage, and a single character position for display by a character-mode device. This simple one-to-one relationship in character-string operations between data characters, display width, and storage requirements does not exist in East Asian locales that support multibyte characters. In such locales, a single logical character might correspond to a single byte or to two or more bytes. In such locales, it becomes necessary to distinguish among the logical characters within a string, the display width that the corresponding glyph occupies in a display or in report output, and the number of bytes of memory storage that must be allocated to hold the string. In locales that support multibyte characters, some built-in functions and operators that process string values operate on logical characters, rather than on bytes. For code sets that use multibyte characters, this modies the bytebased behavior of several features in 4GL 6.x (and earlier versions). A single logical character can occupy one or more character positions in a screen display or in output of a report, and requires at least one byte of storage, and possibly more than one. Declaring the CHAR or VARCHAR data types of variables, formal arguments, and returned values is byte based. Runtime processing of some character strings, however, is done on a logical character basis in multibyte locales.
E-16
Partial Characters
The most important motivation for distinguishing between logical characters and their component bytes is the need to avoid partial characters. These are fragments of multibyte characters. Entering partial characters into the database implies corruption of the database, and risks malfunction of the database server. Partial characters are created when a multibyte character is truncated or split up in such a manner that the original sequence of bytes is not retained. Partial characters can be created during operations like the following ones:
s s s s
Substring operations
INSERT and UPDATE operations of SQL
4GL does not allow partial characters and handles them as follows:
s s
Replaces truncated multibyte characters by single-byte white spaces Wraps words in a way that ensures that no partial characters are created in reports and screen displays Performs code-set conversion in a way that ensures that no partial characters are created
retrieved three data values from col1 (where col1 is a CHAR, NCHAR, NVARCHAR, or VARCHAR column); here the rst line is not a data value but indicates the alignment of bytes within the substrings:
AA2BB2AA ABA2C2AA A2B2CABC
General Guidelines
Here the notation s1 denotes a single-byte white space. Any uppercase letter followed by a superscript ( 2 ) means an East Asian character with multibyte storage width; for simplicity, this example assumes a 2-byte storage requirement for the multibyte characters. In the rst example, the A2 would become a partial character in the substring, so it is replaced by a single-byte white space. In the same substring, the B2 would lose its trailing byte, so a similar replacement takes place.
General Guidelines
This section lists the issues that you need to consider when writing and translating applications.
Internationalization Guidelines
To make a 4GL application world-ready, keep the following guidelines in mind:
s
Do not assume that application users are English speaking or will accept any pre-set business rules or formats. Use code libraries wherever possible. This centralizes common code and makes changes and maintenance easier when developing for international markets. Specic programming areas that might require special attention (and that are treated in detail in the chapter on GLS fundamentals in the Informix Guide to GLS Functionality) include:
Character-string display, entry, storage, retrieval, and processing Formats for literal date, time, currency, and numeric values Code-set conversion between client and server
In all windows that will appear in more than one language, consider differences in word length among languages when you are designing the window and its graphical objects. Allow space for the expansion of user message strings. Brief English strings such as Popup can double in size as a result of translation. On average, you can expect a 30% increase in the size of messages.
E-18
Internationalization Guidelines
When designing windows, remember that names, addresses, dates, times, and telephone numbers have different formats in different countries. When possible, use picture buttons instead of buttons with titles. Consider that measurement systems can also differ. Most countries outside the U.S. express quantities using the metric system. For example, liters, centimeters, and kilometers instead of quarts, inches, and miles. Make sure that all screens, menus, user messages, reports, help facilities, and application parameters (such as holidays, bank years, formulas) that were developed with Informix tools for the application are either table-driven or are controlled by text les or environment variables that are easy to modify. This issue is discussed later in this appendix. Avoid embedding any messages, prompts, or elements of the user interface into the source code of the program. Ideally, all user interface elements can be switched dynamically by referencing a different set of translated les. Consider different keyboard layouts. A character (such as /) that is easily accessible on an ASCII keyboard might require several keystrokes in the standard keyboard of some other country. Consider creating a conguration utility to deal with different font types. Some applications that will be deployed in several different countries might need to load different fonts to accommodate specic national characters. Because these fonts are often supplied by third parties, you might not be able to predict the font names when you develop the application. In this case, you can use the default font names and provide a conguration utility that allows the user to specify the font name before running the application.
s s
Consider differences in paper size when designing reports. Most countries outside the U.S. use the ISO Standard A4 paper size, which is 21 by 29.7 centimeters, slightly longer and narrower than the American standard 8.5 by 11 inches.
Localization Guidelines
Avoid fragmentation of messages or potentially ambiguous key or command words. Avoid determining variable portions of a message at runtime; for example, the differing syntax of other languages can make the order in which your functions return parameters an obstacle to correct translation. Wherever possible, avoid abbreviations, acronyms, contractions, and slang. Place comments around any string pertaining to the user interface to facilitate localization. Use localized error messages and help les. The message compiler utility that is provided with 4GL enables you to create customized help les as well as a localized version of the 4GL runtime message le (the 4gluser.msg le in the msg directory). Internationalizing messages is further discussed in Localizing Prompts and Messages on page E-32. You can handle reports (which are 4GL programs) in the same way that you internationalize the rest of your 4GL source code.
Localization Guidelines
As noted previously, localization refers to the actual process of adapting the application to the cultural environment of end users. This process often involves translation of the user interface and user documentation and can be time consuming and costly. Here are some guidelines to follow:
s
Consult the native operating system internationalization guide. Most platforms provide documentation on internationalization. This material might help you to determine which date, time, and money formats are appropriate for the target language and culture. For more information about internationalizing Informix products, see the Informix Guide to SQL: Reference. For information about the terms and constructs of Informix global language support (GLS) technology, see the Informix Guide to GLS Functionality.
Make sure the targeted hardware, operating system environments, and Informix product versions of your applications can support the desired language and culture.
E-20
Localization Guidelines
Find out if the runtime environment of 4GL and of the database server is currently available in the target language. For example, the 4GL runtime environment (and the Informix Dynamic Server administrators environment) is usually translated into several languages, including French, German, Spanish, Russian, and Japanese.
Keep a glossary of all strings and keywords in a database or text le. This glossary will make it easier to see which messages are duplicated throughout the source code. The glossary will also increase the consistency of terms and language in the user interface throughout the application. Once the glossary is created for one language, it can be used for product updates and additional localizations.
Create a mechanism that allows a glossary to drive the denition of the user interface. This can be particularly useful if you expect to localize the application often. A translator can edit the glossary without having to understand the source code of the application. Your tool can then create the user interface from the translated glossary, and the translator can focus on making cosmetic enhancements to the translation (such as positioning the messages appropriately) and correcting minor errors.
Consider creating a checklist of those user interface elements in your application that should be externalized into text les from the source code, and therefore from the compiled portion of the program. These text les can then be modied even after the program is compiled. Externalize the following elements:
Menus Forms Messages Labels Help (.msg) text Numeric, date, time, and money formats Report names
Consider retaining a professional translator for some or all of this process. A faulty translation is very costly. You can spend a great deal of time and money correcting errors in your localized product. And if you do not correct the problems, your users will be dissatised with your application.
E-22
Informix Translation
Informix provides error message translation for a variety of languages. You can use the DBLANG environment variable to point to a message directory containing translated messages. Contact your local Informix sales ofce for a list of available language translations.
Code-Set Conversion
For details, see Handling Code-Set Conversion on page E-34.
The English database servers create English databases with ASCII data. For these, the 4GL program must access the database servers with DB_LOCALE set to en_us.8859-1. The 5.x ALS versions of Informix database servers can use variables such as DBCODESET and DBCSOVERRIDE as substitutes for DB_LOCALE and DBCONNECT, respectively. These environment variables need to be set by using Setnet32. The 5.x ALS versions use DBASCIIBC to emulate the 4.x ASCII database servers. This environment variable should be set in the registry if such behavior is desired. The SERVER_LOCALE environment variable is set on the database server, not on the 4GL client. This variable species the locale that the database server uses to read or write operating system les. If it is not set, the default is U.S. English (en_us.8859-1).
If no setting is specied, the 4GL application uses an English locale. But the registry sets everything to the local language, code set, or locale, so the practical default is for applications to use the local locale. The non-internationalized portions of the product are initialized with the default (U.S. English) locale. That is, both CLIENT_LOCALE (en_us.1252) and DB_LOCALE (en_us.8859-1) are set to English. This initialization is necessary because many common functions are shared between the internationalized and non-internationalized components. Important: Except for DBFORMAT, all of the environment variables that are described in the sections that follow apply to Informix database servers.
E-24
The application cannot support connections to different databases with different locales concurrently; for example, in extended joins. The environment variables discussed here deal with the environment DB_LOCALE that is passed to the database server.
CLIENT_LOCALE cannot be changed dynamically during execution.
s s
The previous point has one exception: the CLIENT_LOCALE can always be set to English (because English is a subset of all locales).
The DB_LOCALE code set should match the DB_LOCALE code set of the database. Otherwise, data corruption can occur because no validation of code-set compatibility is performed by the database server.
DBDATE denes date display formats. DBMONEY denes monetary display formats. DBFORMAT denes numeric and monetary display formats and has more options than DBMONEY.
DB_APICODE species a code set that has a mapping le. DB_LOCALE is the locale of the database to which the application
is connected.
s
application.
s s s s
DBLANG points to the directory for Informix error messages. DBNLS supports localized collation and other GLS features. GL_DATE denes date displays, including East Asian formats. GL_DATETIME denes date and time displays, including East Asian
formats.
s
4GL does not use DB_LOCALE directly; this variable, as well as DBLANG, is used by ESQL/C. See the Informix Guide to GLS Functionality for details of DBLANG, DB_LOCALE, GL_DATE, GL_DATETIME, and other GLS
DBAPICODE
This environment variable species the name of a mapping le for peripheral devices (for example, a keyboard, a display terminal, or a printer) whose character set is different from that of the database server.
DB_LOCALE
This environment variable species the locale of the database to which the 4GL component or application is connected. The only Informix databases that currently support non-English languages exist in UNIX. Therefore, when the locales are non-English, the localized 4GL application can only connect to these databases. The format for setting DB_LOCALE is DB_LOCALE=<locale>. The following points should be noted regarding DB_LOCALE:
s
If the application uses this value to access a database, the locale of that database must match the value specied in DB_LOCALE. If it does not match, the database connection might be refused (unless DBCSOVERRIDE is set to 1), depending on the database server version. If a database is created, this new database has the value specied by DB_LOCALE. If DB_LOCALE is invalid, either because of wrong formatting or specifying a locale that does not exist, an error is issued. If the code set implied by DB_LOCALE cannot be converted to what CLIENT_LOCALE implies, or vice versa, an error is issued. If DB_LOCALE is not specied, there is no default value; in this case, ESQL/C behaves as if code-set conversion were not needed.
E-26
Values in Product CL Value en_us.8859 ja_jp.ujis ja_jp.ujis en_us.8859 DL Value en_us.8859 ja_jp.ujis ja_jp.ujis ja_jp.ujis
ja_jp.ujis ja_jp.ujis --
If you do not set the DBLANG environment variable, it is set to the value of CLIENT_LOCALE.
CLIENT_LOCALE
This environment variable species the locale of the (input) source code and the compiled code (to be generated). This is also the locale of the error les (if any) and the intermediate les. The format of CLIENT_LOCALE is the same as that of DB_LOCALE:
s
The characters that reach the user interface (the non-ASCII characters) must be in the CLIENT_LOCALE. If DB_LOCALE is invalid, either because of wrong formatting or specifying a locale that does not exist, an error is issued. The DB_LOCALE and CLIENT_LOCALE settings need to be compatible, meaning there should be proper code-set conversion tables between them. Otherwise, an error is issued. If CLIENT_LOCALE is not set, Windows code page 1252 is the default.
The CLIENT_LOCALE must match the environment of the user interface (meaning that it should be compatible with the local version of Windows). Otherwise, an error is issued. By default, collation by the 4GL application follows the code-set order of CLIENT_LOCALE, except in SQL statements (where the database server uses its own collation sequence). Any LC_COLLATE specication is ignored. If DBNLS is set to 1, however, and the COLLATION category of the locale le denes a nondefault order for sorting strings, 4GL uses the order that COLLATION species.
DBLANG
The value of DBLANG is used to complete the pathname to the directories that contain the required message, help, and demo les. The format of DBLANG is the same as that of DB_LOCALE:
s s
If DBLANG is not set, the value defaults to that of CLIENT_LOCALE. If DBLANG is invalid, en_us.1252 is the default value. This case occurs if DBLANG is improperly formatted, or if it points to a locale that does not exist, or points to a locale that is incompatible with the version of Windows on which the 4GL application is running.
See also the description of DBLANG in the Informix Guide to GLS Functionality.
DBDATE
The DBDATE environment variable has been modied to support era-based dates (Japanese and Taiwanese). The days of the week and months of the year (in local form) are stored in the locale les. If this environment variable is set, it might override other means of specifying date formats.
DBNLS
The DBNLS environment variable must be set to 1 if the 4GL application needs to pass values between CHAR or VARCHAR program variables and database columns of the NCHAR or NVARCHAR data type. The same setting is also required if you want character strings to be sorted in a nondefault collation sequence rather than in code-set order. (In this case, your locale les must also include a COLLATION category to dene the nondefault sorting.)
E-28
DBMONEY
This environment variable has been modied to accept multibyte currency symbols. 4GL components that read the value of DBMONEY (or DBFORMAT) must be able to correctly process multibyte characters as currency symbols. If DBMONEY is set, its value might override other means of specifying currency formats.
DBFORMAT
This environment variable has been modied to accept multibyte currency symbols. Unlike the version of DBFORMAT for English products, display of the decimal point is optional, rather than mandatory, in 4GL. (Use of a comma as the DBFORMAT decimal separator can produce errors or unpredictable results in SQL statements in which 4GL variables are expanded to number values that are formatted with comma as the decimal separator.) If DBFORMAT is set, its value can override other means of specifying number or monetary formats. See also the descriptions of DBDATE, DBFORMAT, and DBMONEY in Appendix D. The glles utility is described in the Informix Guide to GLS Functionality and is packaged with INFORMIX-4GL and INFORMIX-SQL products. This utility allows you to generate lists of the following les:
s s s
File-Based Localization
You can store the translations of localized information in disk les and access them at runtime as needed. You can use subdirectories to store language-sensitive les, so they can easily be switched to create a new runtime environment. In the following example, the lename is composed by reading the value of an environment variable (created by the programmer) that species a language subdirectory:
LET file001 = FGL_GETENV("LANGUAGE"), "/", # Evaluates to "eng/trans.4gl" if LANGUAGE # Program reads the eng directory for copy # # Evaluates to "ger/trans.4gl" if LANGUAGE # Program reads the ger directory for copy # LET tranfile = file001 "trans.4gl" is "eng" of translation is "ger" of translation
E-30
Table-Based Localization
Table-Based Localization
As noted earlier, localization information can also be stored in database tables. This information can be used when you initialize or run the application to change the value of variables that dene titles, menus, and other language or culturally sensitive elements of the user interface. An advantage of the table-based approach is that it is highly portable between systems.
Setting Up a Table
The following example shows one way that you might set up a table to store menu options:
CREATE TABLE menu_elements( option_language CHAR(3), option_number SMALLINT, option_text CHAR(80), option_maxlen SMALLINT ) #language ID code # identifying number # text # maximum length of string
Example data:
ENG150Cold Beer FRE150Bire froide GER150Kaltes Bier SPA150Cerveza fra ENG151Iced Tea ...
With a text editor that can create at les, create a source (.msg) le with the following format:
.message-number message-text .message-number message-text
For example:
.1000 Part not found. .1001 Price must be a positive number. .1002 Invalid format for phone number.
To translate the messages into another language, simply provide translated versions for the message text, using the same format.
2.
At the system prompt, invoke the message compiler utility (mkmesssage) by using a command of the following form:
mkmsg filename
The message compiler processes lename.msg and produces a compiled message le that has the name lename.iem. If you want the compiled message le to have a different name from the source le, specify that lename as a nal argument:
mkmsg source output
E-32
Function getMsg( ) reads the compiled message le and nds the message that corresponds to the integer value of the variable noPart. To supply new versions of the messages, you need only provide a new source le and compile it with the message compiler. The function calls in your application remain the same.
INFORMIX-4GL
INFORMIX-ESQL/C
Database
The code sets in the CLIENT_LOCALE can differ from those in DB_LOCALE. In the CLIENT_LOCALE, the code sets (which are specied in locales) use code points that are pre-dened by Microsoft standards. Code sets that are used in the DB_LOCALE tend to use characters that are based on UNIX conventions, if the application is designed to access legacy data. Code-set conversion is done by way of a code-set conversion le. Files for code-set conversion between CLIENT_LOCALE and DB_LOCALE need to be present on the client. For conversion to take place, conversion les need to be present in the %informixdir%\gls\cv directory. For details of converting between client and server code sets, see the sections that follow. See also GLS fundamentals in the Informix Guide to GLS Functionality.
E-34
in Windows code page 1252 as hexadecimal 0xE2. in IBM CCSID 437 as hexadecimal 0x83.
If the encoding for a-circumex on the Windows system is sent unchanged to the IBM system, it will be printed as the Greek character gamma. This happens because, on the IBM system, gamma is encoded as 0xE2. This means character data strings that are passed between two computers using different character set encodings must be converted between the two different encodings. Otherwise, character data originating from one computer will not be correctly displayed or processed on the other computer. This appendix uses the term code set in the same way that the Windows documentation uses the terms character set and code page. Converting character data from one encoding schema to another is called code-set conversion. If a code-set conversion is required from computer A to computer B, it is also required from computer B to computer A. You must explicitly enable code-set conversion; no conversion is done by default.
The client and the server are on the same computer. The code set of your client and of all the databases to which you are connecting are the same. The subset of characters that you will be sending between the client and the server are encoded identically. For example, if you are sending only English characters between a client and a server, and each English character has the same encoding on both computers, no code-set conversion is required. In this case, the non-English characters can have different encodings. The character-string data values are passed from the client to the server for storage only and are neither processed nor printed by the server. For example, no code-set conversion is required if a client:
Passes character-string data to the server Does not process or print the data on the server computer Retrieves the same data for processing or printing on computers that use the same code set as the client that populated the database
Sorting data by using the ORDER BY statement or retrieving data by using a LIKE or MATCHES clause, however, will probably produce erroneous results if the data strings are not converted before they are stored.
E-36
Mismatch Processing
Mismatch Processing
If both code sets encode exactly the same characters, mismatch handling is unnecessary. If the source code set contains any characters that are not contained in the target code set, however, the conversion must dene how the mismatched characters are to be mapped to the target code set. Four ways that code-set conversions handle mismatch processing are as follows:
s
Round-trip conversion. This method maps each mismatched character in the source code set to a unique character in the target code set. On the return, the original character is mapped back to itself. This guarantees that a two-way conversion will result in no loss of information; however, data converted in only one direction might confuse the processing or printing on the target computer. Substitution conversion. This method maps all mismatched characters in the source code set to a single specic character in the target code set that serves to highlight mismatched characters. This guarantees that a one-way conversion will clearly show the mismatched characters; however, a two-way conversion will result in information loss if mismatched characters are transferred. Graphical replacement conversion. This method maps each mismatched character in the source code set to a character in the target code set that resembles the source character (this includes mapping one-character ligatures to their two-character equivalents). This might confuse printing on the target computer. Round-trip conversions should contain as many graphical replacement conversions as possible. Substitution plus graphical replacement. This method maps as many mismatched characters as possible to their graphical replacements, and maps the remaining mismatched characters to the substitution character.
Informix-supplied code-set conversion source les have header comments that indicate which method was used.
Determine the code set used by the client. Determine the code set used by all the databases to which this client will be connecting in a single connection. Specify the conversion lenames. Start the application.
E-38
Appendix
color or intensity attributes in screen displays. These and other keyboard and screen options are terminal-dependent. To determine terminal-dependent characteristics, 4GL uses the information in the termcap le or in the terminfo directory. 4GL uses the INFORMIXTERM environment variable to determine whether to use termcap or terminfo. For more information about INFORMIXTERM, see Appendix D, Environment Variables. With 4GL, Informix distributes termcap les that contain additional capabilities for many common terminals (such as the Wyse 50 and the Televideo 950). These capabilities include intensity-change or color-change descriptions or both. This appendix describes these capabilities, as well as the general format of termcap and terminfo entries. Because terminfo does not support color, you can only use 4GL color functionality with termcap. To use color in 4GL, you must set the INFORMIXTERM environment variable to termcap. You can use the information in this appendix, combined with the information in your terminal manual, to modify the contents of your termcap le or terminfo le. This appendix is divided into two main sections, termcap and terminfo. Depending on which you are using, read the appropriate section.
termcap
termcap
When 4GL is installed on your system, a termcap le is placed in $INFORMIXDIR/etc. This le is a superset of an operating system termcap le. The Informix termcap le contains additional capabilities for many terminals. You might want to modify this le further in the following instances:
s s s s
To include color-change and intensity-change capabilities To extend function key denitions To specify or alter the graphics characters used for window borders To customize your terminal entry in other ways
Some terminals cannot support color or graphics characters. Read this appendix and the user guide for your terminal to determine whether or not the changes described in this appendix are applicable to your terminal.
F-2
The ESCAPE character is specied as a backslash ( \ ) followed by the letter E, and CONTROL is specied as a caret (^) symbol. Do not attempt to use the ESCAPE or CONTROL keys to indicate escape sequences or control characters in a termcap entry. Each capability, including the last one in the entry, is followed by a colon ( : ). Entries must be dened on a single logical line; a backslash appears at the end of each line that wraps to the next line.
The following example shows a basic termcap entry for the Wyse 50 terminal:
# Entry for Wyse 50: w5|wy50|wyse50: :if=/usr/lib/tabset/std:\ :al=\EE:am:bs:ce=\Et:cm=\E=%+ %+ :cl=\E*:co#80:\ :dc=\EW:dl=\ER:ho=^^:ei=:kh=^^:im=:ic=\EQ:in:li#24:\ :nd=^L:pt:se=\EG0:so=\EG4:sg#1:ug#1:\ :up=^K:ku=^K:kd=^J:kl=^H:kr=^L:kb=:\ :k0=^A@^M:k1=^AA^M:k2=^AB^M:k3=^AC^M:k4=^AD^M:\ :k5=^AE^M:k6=^AF^M:k7=^AG^M:\ :HI=^|:Po=^R:Pe=^T:
Terminal Names
A termcap entry starts with one or more names for the terminal, each separated by a pipe symbol ( | ). For example, the termcap entry for Wyse 50 terminals starts with the following line:
w5|wy50|wyse50:\
The termcap entry can be accessed by using any one of these names.
Boolean Capabilities
A Boolean capability is a two-character code that indicates whether or not a terminal has a specic feature. If the Boolean capability is present in the termcap entry, the terminal has that particular feature. The following example shows some of the Boolean capabilities for the Wyse 50 terminal:
:bs:am: # # bs am backspace with CTRL-H automatic margins
Numeric Capabilities
A numeric capability is a two-character code followed by a pound sign ( # ) and a value. The following example shows the numeric capabilities for the number of columns and the number of lines on a Wyse 50 terminal:
:co#80:li#24: # # co li number of columns in a line number of lines on the screen
Similarly, sg is a numeric capability that indicates the number of character positions required on the screen for reverse video. The entry:sg#1: indicates that a terminal requires one additional character position when reverse video is turned ON or OFF. If you do not include a given numeric capability, 4GL assumes that the value is zero.
String Capabilities
A string capability species a sequence that can be used to perform a terminal operation. A string capability is a two-character code followed by an equal sign ( = ) and a string ending at the next colon ( : ) delimiter symbol.
F-4
Most termcap entries include string capabilities for clearing the screen, moving the cursor, and using arrow keys, underscore, function keys, and so on. The following example shows many of the string capabilities for the Wyse 50 terminal:
:ce=\Et:cl=\E*:\ :nd=^L:up=^K:\ :so=\EG4:se=\EG0:\ :ku=^K:kd=^J:kr=^L:kl=^H:\ :k0=^A@^M:k1=^AA^M:k2=^AB^M:k3=^AC^M:
# # # # # # # # # # # # # # # # #
ce=\Et cl=\E* nd=^L up=^K so=\EG4 se=\EG0 ku=^K kd=^J kr=^L kl=^H k0=^A@^M k1=^AA^M k2=^AB^M k3=^AC^M
clear to end of line clear the screen non-destructive cursor right up one line start stand-out end stand-out up arrow key down arrow key right arrow key left arrow key function function function function key key key key F1 F2 F3 F4
termcap Entry
k0=^A@^M k1=^AA^M k2=^AB^M k3=^AC^M k4=^AD^M k5=^AE^M k6=^AF^M k7=^AG^M
You can also dene keys that correspond to the following capabilities:
s s s s
Insert line (ki) Delete line (kj) Next page (kf) Previous page (kg)
If these keys are dened in your termcap le, 4GL uses them. Otherwise, 4GL uses CONTROL-J, CONTROL-K, CONTROL-M, and CONTROL-N, respectively. You can also use the OPTIONS statement to name other function keys or CONTROL keys for these operations.
F-6
horizontal lines, the pipe symbol ( | ) for vertical lines, and the plus sign ( + ) for corners. The termcap le provided with 4GL contains border character denitions for many common terminals. You can look at the termcap le to see if the entry for your terminal has been modied to include these denitions. If your terminal entry does not contain border character denitions, or to specify alternative border characters, you or your system administrator can modify the termcap le.
Determine the escape sequences for turning graphics mode on and off. This information is located in the manual that comes with your terminal. For example, on Wyse 50 terminals, the escape sequence for entering graphics mode is ESC H^B and the escape sequence for leaving graphics mode is ESC H^C. Terminals without a graphics mode do not have this escape sequence. The procedure for specifying alternative border characters on a non-graphics terminal is discussed at the end of this section.
2.
Identify the ASCII equivalents for the six graphics characters that 4GL requires to draw the border. The ASCII equivalent of a graphics character is the key that you press in graphics mode to obtain the indicated character. The following table shows the graphics characters and the ASCII equivalents for a Wyse 50 terminal.
Window Border Position Upper-left corner Lower-left corner Upper-right corner Lower-right corner Horizontal Vertical Graphics Character ASCII Equivalent 2 1 3 5 z 6
This information should be located in the manual that comes with your terminal.
3.
You might want to make a copy of your termcap le before you edit it. You can use the TERMCAP environment variable to point to whichever copy of the termcap le you want to access.
F-8
Use the following format to enter values for the following termcap capabilities:
termcap-capability=value
ge gb
Follow these guidelines when you insert information in the termcap entry:
1. 2. 3.
Delimit entries with a colon ( : ). End each continuing line with a backslash ( \ ). End the last line in the entry with a colon.
For example, if you are using a Wyse 50 terminal, add the following information in the termcap entry for the Wyse 50:
:gs=\EH^B:\ :ge=\EH^C:\ :gb=2135z6:\ # # # # # # sets gs to ESC H CTRL B sets ge to ESC H CTRL C sets gb to the ASCII equivalents of graphics characters for upper left, lower left, upper right, lower right, horizontal, # and vertical
4GL uses the graphics characters in the termcap le when you specify a window border in an OPEN WINDOW statement.
F-10
s s
Signies that if the keyword BOLD is indicated as the attribute, the eld will be RED on a color terminal. If the keyword DIM is indicated as the attribute, the eld will be BLUE on a color terminal.
The background for colors is BLACK in all cases. In either color or monochrome mode, you can add the REVERSE, BLINK, or UNDERLINE attribute if your terminal supports them.
ZA uses the values of these four parameters and a stack machine to determine which characters to send to the terminal. The ZA function is called and these
parameters are evaluated when a color or intensity attribute is encountered in a 4GL program. You can use the information in your terminal manual to set the ZA parameters to the correct values for your terminal. To dene the ZA string for your terminal, you use stack operators to push and pop values onto and off the stack. The next section describes several stack operators. Use these descriptions and the subsequent examples to understand how to dene the string for your terminal.
Stack Operations
The ZA string uses stack operations to either push values onto the stack or pop values off the stack. Typically, the instructions in the ZA string push a parameter onto the stack, compare it to one or more constants, and then send an appropriate sequence of characters to the terminal. More complex operations are often necessary, and by storing the display attributes in static stack machine registers (named a through z), you can achieve terminal-specic optimizations. A summary follows of the different stack operators you can use to write the descriptions. For a complete discussion of stack operators, consult your operating system documentation.
F-12
pops a numeric value from the stack and sends a maximum of three digits to the terminal. For example, if the value 145 is at the top of the stack, %d pops the value off the stack and sends the ASCII representations of 1, 4, and 5 to the terminal. If the value 2005 is at the top of the stack, %d pops the value off the stack and sends the ASCII representation of 5 to the terminal. pops a numeric value from the stack and sends a maximum of two digits to the terminal, padding to two places. For example, if the value 145 is at the top of the stack, %2d pops the value off the stack and sends the ASCII representations of 4 and 5 to the terminal. If the value 5 is at the top of the stack, %2d pops the value off the stack and sends the ASCII representations of 0 and 5 to the terminal. pops a numeric value from the stack and sends a maximum of three digits to the terminal, padding to three places. For example, if the value 7 is at the top of the stack, %3d pops the value off the stack and sends the ASCII representations of 0, 0, and 7 to the terminal. pops a single character from the stack and sends it to the terminal.
%2d
%3d
%c
pushes the value of the specied parameter on the stack. The notation for parameters is p1, p2, p9. For example, if the value of p1 is 3, %p1 pushes 3 on the stack. pops a value from the stack and stores it in the specied variable. The notation for variables is Pa, Pb, Pz. For example, if the value 45 is on the top of the stack, %Pb pops 45 from the stack and stores it in the variable Pb. gets the value stored in the corresponding variable (P[a-z]) and pushes it on the stack. For example, if the value 45 is stored in the variable Pb, %gb gets 45 from Pb and pushes it on the stack.
%P[a-z]
%g[a-z]
%c
pushes a single character on the stack. For example, %'k' pushes k on the stack. pushes an integer constant on the stack. The integer can be any length and can be either positive or negative. For example, %{0} pushes the value 0 on the stack. pops a value from the stack and stores it in the specied static variable. (Static storage is nonvolatile since the stored value remains from one attribute evaluation to the next.) The notation for static variables is Sa, Sb, Sz. For example, if the value 45 is on the top of the stack, %Sb pops 45 from the stack and stores it in the static variable Sb. This value is accessible for the duration of the 4GL program. gets the value stored in the corresponding static variable (S[az]) and pushes it on the stack. For example, if the value 45 is stored in the variable Sb, %Gb gets 45 from Sb and pushes it on the stack.
%{n}
%S[a-z]
%G[a-z]
Arithmetic Operators
Each of these arithmetic operators pops the top two values from the stack, performs an operation, and pushes the result on the stack:
%+ %%* %/
Addition. For example, %{2}%{3}%+ is equivalent to 2+3. Subtraction. For example, %{7}%{3}%- is equivalent to 7-3. Multiplication. For example, %{6}%{3}%* is equivalent to 6*3. Integer division. For example, %{7}%{3}%/ is equivalent to 7/3 and produces a result of 2. Modulus (or remainder). For example, %{7}%{3}%m is equivalent to (7 mod 3) and produces a result of 1.
%m
F-14
Bit Operators
The following bit operators pop the top two values from the stack, perform an operation, and push the result on the stack:
%&
Bit-and. For example, %{12}%{21}%& is equivalent to (12 and 21) and produces a result of 4.
Binary 0 1 1 0 1 1 0 0 0 1 = = Decimal 12 21 and = 4
------------------------0 0 1 0 0
%|
Bit-or. For example, %{12}%{21}%| is equivalent to (12 or 21) and produces a result of 29.
Binary 0 1 1 0 1 1 0 0 0 1 = = Decimal 12 21 or = 29
------------------------1 1 1 0 1
%^
Exclusive-or. For example, %{12}%{21}%^ is equivalent to (12 exclusiveor 21) and produces a result of 25.
Binary 0 1 1 0 1 1 0 0 0 1 = = Decimal 12 21 exclusive or = 25
------------------------1 1 0 0 1
The following unary operator pops the top value from the stack, performs an operation, and pushes the result on the stack:
%~
Bitwise complement. For example, %{25}%~ results in a value of -26, as shown in the following display.
Binary 0 0 0 1 1 0 0 1 Decimal = 25
---------------------------1 1 1 0 0 1 1 0
Complement = -26
Logical Operators
The following logical operators pop the top two values from the stack, perform an operation, and push the logical result (either 0 for FALSE or 1 for TRUE) on the stack:
%=
Equal to. For example, if the parameter p1 has the value 3, the expression %p1%{2}%= is equivalent to 3=2 and produces a result of 0 (FALSE). Greater than. For example, if the parameter p1 has the value 3, the expression %p1%{0}%> is equivalent to 3>0 and produces a result of 1 (TRUE). Less than. For example, if the parameter p1 has the value 3, the expression %p1%{4}%< is equivalent to 3<4 and produces a result of 1 (TRUE).
%>
%<
The following unary operator pops the top value from the stack, performs an operation, and pushes the logical result (either 0 or 1) on the stack.
%!
Logical negation. This operator produces a value of zero for all nonzero numbers and a value of 1 for zero. For example, %{2}%! results in a value of 0, and %{0}%! results in a value of 1.
F-16
Conditional Statements
The condition statement IF-THEN-ELSE has the following format:
%? expr %t thenpart %e elsepart %;
The %e elsepart is optional. You can nest conditional statements in the thenpart or the elsepart. When 4GL evaluates a conditional statement, it pops the top value from the stack and evaluates it as either true or false. If the value is true, 4GL performs the operations after the %t; otherwise it performs the operations after the %e (if any). For example, the expression:
%?%p1%{3}%=%t;31%;
is equivalent to:
if p1 = 3 then print ";31"
Assuming that p1 has the value 3, 4GL performs the following actions:
s
%p1 pushes the value of p1 on the stack. %{3} pushes the value 3 on the stack. %= pops the value of p1 and the value 3 from the stack, evaluates the Boolean expression p1=3, and pushes the resulting value 1 (TRUE) on the stack. %t pops the value from the stack, evaluates 1 as TRUE, and executes the operations after %t. (Because ";31" is not a stack machine operation, 4GL prints ";31" to the terminal.) %; terminates the conditional statement.
Summary of Operators
The following table summarizes the allowed operations.
Operation
%d %2d %3d %c %p[1-9] %P[a-z] %g[a-z] %'c' %{n} %S[a-z] %G[a-z] %+
Description Writes pop() in decimal format Writes pop() in two-place decimal format Writes pop() in three-place decimal format Writes pop() as a single character Pushes ith parameter Pops and stores a variable Gets a variable and pushes it on the stack Pushes a CHAR constant Pushes an integer constant Pops and stores a static variable Gets a static variable and pushes Addition. Pops two values off the stack, adds them together, and pushes the result onto the stack Subtraction. Pops two values off the stack, subtracts one from the other, and pushes the result onto the stack Multiplication. Pops two values off the stack, multiplies them by each other, and pushes the result onto the stack Integer division. Pops two values off the stack, divides one by the other, and pushes the result onto the stack Modulus. Pops two values off the stack and pushes the remainder when one number is divided by the other Bitwise AND Bitwise OR Bitwise exclusive OR (1 of 2)
%-
%*
%/
%m
%& %| %^
F-18
Operation
%~ %=
Description Bitwise complement Equal to. Pops two values off the stack, nds out whether the values are equal, and pushes 1 onto the stack if the values are equal or 0 if they are not equal Greater than. Pushes two values off the stack, nds out whether the rst value is greater than the second, and pushes the result onto the stack Less than. Pushes two values off the stack, nds out whether the rst value is less than the second, and pushes the result onto the stack Logical negation. Pops one value off the stack, logically inverts or negates it (converts zero to 1 and nonzero to 0), and pushes the negated value back onto the stack expr %t thenpart %e elsepart %; IF expr THEN thenpart ELSE elsepart; the %e elsepart is optional. ELSE-IFs are possible (cs are conditions): %? c1 %t%e c2 %t%e c3 %t%e%; Nested IFs allowed
%>
%<
%!
%?
Examples
To illustrate, consider the monochrome Wyse terminal. The following table shows the escape sequences for some display characteristics.
Escape Sequence
ESC G 0 ESC G 1 ESC G 2
Escape Sequence
ESC G 4 ESC G 5 ESC G 6 ESC G 8 ESC G 9 ESC G :
Results Reverse Reverse and blank Reverse and blink Underscore Underscore and blank Underscore and blink Underscore and reverse Underscore, reverse, and blank Underscore, reverse, and blink (2 of 2)
ESC G <
ESC G = ESC G >
The characters after G form an ASCII sequence from the character 0 (zero) through ?. You can generate the character by starting with 0 and adding 1 for blank, 2 for blink, 4 for reverse, and 8 for underline. You can construct the termcap entry in stages, as outlined in the following display. %pi refers to pushing the ith parameter on the stack. The designation for is \E. The termcap entry for the Wyse terminal must contain the following ZA entry for 4GL monochrome attributes such as REVERSE and BOLD to work correctly:
ZA = EG %0 %?%p1%{7}%=%t%{1}%| %e%p1%{3}%> %p1%{7}%<%&%t%{64}%| %;%; %?%p2%t%{4}%|%; %?%p3%t%{2}%|%; %?%p4%t%{8}%|%; %c: #print EG #push 0 (normal) on the stack #if p1 = 7 (invisible), set #the 1 bit (blank); #if p1 > 3 and < 7, set the 64 flag (dim); # # #if p2 is set, set the 4 bit (reverse) #if p3 is set, set the 2 bit (blink) #if p4 is set, set the 8 bit (underline) #print whatever character #is on top of the stack
F-20
You then concatenate these lines as a single string that ends with a colon and has no embedded NEWLINE characters. The actual ZA entry for the Wyse 50 terminal follows:
ZA = \EG%0%?%p1%{7}%=%t%{1}%|%e%p1%{3}%>%p1%{7}%<%&%t%{64} %|%;%;%?%p2%t%{4}%|%;%?%p3%t%{2}%|%;%?%p4%t%{8}%|%;%c:
The next example is for the ID Systems Corporation ID231, a color terminal. On this terminal, to set color and other characteristics, you must enclose a character sequence between a lead-in sequence (ESC [ 0) and a terminating character (m). The rst in the sequence is a two-digit number that determines whether the assigned color is in the background (30) or in the foreground (40). The next is another two-digit number that is the other of 30 or 40, incremented by the color number. These characters are followed by 5 if there is blinking and by 4 for underlining. The code in the following example sets up the entire escape sequence:
ZA = \E[0; %?%p1%{0}%=%t%{7} %e%p1%{1}%=%t%{3} %e%p1%{2}%=%t%{5} %e%p1%{3}%=%t%{1} %e%p1%{4}%=%t%{6} %e%p1%{5}%=%t%{2} %e%p1%{6}%=%t%{4} %e%p1%{7}%=%t%{0}%; %?%p2%t30;%{40}%+%2d %e40;%{30}%+%2d%; %?%p3%t;5%; %?%p4%t;4%; m #print lead-in #encode color number (translate # from to the number # for the ID231) # # # # # #if p2 is set, print 30 and # 40 + color number (reverse) # else print 40 and # 30 + color number (normal) #if p3 is set, print 5 (blink) #if p4 is set, print 4 (underline) #print m to end character # sequence
In addition to the ZA capability, you can use other termcap capabilities. ZG is the number of character positions on the screen occupied by the attributes of ZA. Like the sg numeric capability, ZG is not required if no extra character positions are needed for display attributes. The value for the ZG entry is usually the same value as for the sg entry.
Modifying termcap and terminfo F-21
terminfo
terminfo
If you have set the INFORMIXTERM environment variable to terminfo, 4GL uses the terminfo directory indicated by the TERMINFO environment variable (or /usr/lib/terminfo if TERMINFO is not set). 4GL uses the information in terminfo to draw window borders, dene function keys, and display certain intensity attributes. You might want to modify a le in the terminfo directory in the following instances:
s s
To extend function key denitions To specify or change the graphics characters used for window borders To customize your terminal entry in other ways
If you use terminfo (instead of termcap), you cannot use color attributes with 4GL. To use color attributes with 4GL, you must use termcap. Some terminals cannot support graphics characters. Read this appendix and the user guide that comes with your terminal to determine whether or not the changes described in this appendix are applicable to your terminal. To modify a terminfo le, you need to be familiar with the following information:
s s s
The format of terminfo entries The infocmp program The tic program
This information is summarized in this appendix; however, refer to your operating system documentation for a complete discussion.
F-22
ESCAPE is specied as a backslash ( \ ) followed by the letter E, and CONTROL is specied as a caret ( ^ ). Do not attempt to use the ESCAPE or CONTROL key to indicate escape sequences or control characters in
a terminfo entry.
s
Each capability, including the last one in the entry, is followed by a comma as a delimiter.
The following example shows a basic terminfo entry for the Wyse 50 terminal:
. Entry for Wyse 50: w5|wy50|wyse50, am, cols#80, lines#24, cuul=^K, clear=^Z, home=^^, cuf1=^L, cup=\E=%p1%\s%+%c%p2%\s%+%c, bw, ul, bel=^G, cr=\r, cud1=\n, cub1=\b, kpb=\b, kcudl=\n, kdub1=\b, nel=\r\n, ind=\n, xmc#1, cbt=\EI,
Terminal Names
A terminfo entry starts with one or more names for the terminal, each separated by a pipe symbol ( | ). For example, the terminfo entry for the Wyse 50 terminal starts with the following line:
w5|wy50|wyse50,
The terminfo entry can be accessed by using any one of these names.
Boolean Capabilities
A Boolean capability is a two- to ve-character code that indicates whether or not a terminal has a specic feature. If the Boolean capability is present in the terminfo entry, the terminal has that particular feature. The next example shows some of the Boolean capabilities for the Wyse 50:
bw,am, . . bw am backward wrap automatic margins
Numeric Capabilities
A numeric capability is a 2- to 5-character code followed by a pound sign ( # ) and a value. The following example shows the numeric capabilities for the number of columns and the number of lines on a Wyse 50 terminal:
cols#80,lines#24, . . cols lines number of columns in a line number of lines on the screen
F-24
String Capabilities
A string capability species a sequence that can be used to perform a terminal operation. A string capability is a two- to ve-character code followed by an equal ( = ) sign and a string ending at the next comma ( , ) delimiter. Most terminfo entries include string capabilities for clearing the screen, cursor movement, arrow keys, underscore, function keys, and so on. The following example shows many of the string capabilities for the Wyse 50 terminal:
el=\ET,clear=E*, cuf1=^L,cuu1=^K, smso=\EG4,rmso=\EG0, kcuu1=^K,kcud1=^J,kcuf1=^L,kcub1=^H, kf0=^A@^M,kf1=^AA^M,kf2=^AB^M,kf3=^AC^M, . . . . . . . . . . . . . . . . . el=\Et clear=\E* cufl=^L cuul=^K smso=\EG4 rmso=\EG0 kcuul=^K kcudl=^J kcufl=^L kcubl=^H kf0=^A@^M kf1=^AA^M kf2=^AB^M kf3=^AC^M clear to end of line clear the screen non-destructive cursor right up one line start stand-out end stand-out up arrow key down arrow key right arrow key left arrow key function function function function key key key key F1 F2 F3 F4
terminfo Entry
kf0=^A@^M kf1=^AA^M kf2=^AB^M kf3=^AC^M kf4=^AD^M kf5=^AE^M kf6=^AF^M kf7=^AG^M
You can also dene keys that correspond to the following capabilities:
s s s s
Insert line (kill) Delete line (kdll) Next page (knp) Previous page (kpp)
If these keys are dened in your terminfo le, 4GL uses them. Otherwise, 4GL uses CONTROL-J, CONTROL-K, CONTROL-M, and CONTROL-N, respectively. You can also use the OPTIONS statement to assign other function keys or CONTROL keys for these operations.
F-26
hyphen ( - ) for horizontal lines, the pipe symbol ( | ) for vertical lines, and the plus sign ( + ) for corners. You can look at the terminfo source le (using infocmp) to see if the entry for your terminal includes these denitions. (Look for the acsc capability, described later in this section.) If the le for your terminal does not contain border character denitions, or to specify alternative border characters, you or your system administrator can modify the terminfo source le. You can refer to your operating system documentation for a complete description of how to decompile terminfo entries by using the infocmp program.
Determine the escape sequences for turning graphics mode on and off. This information is located in the manual that comes with your terminal. For example, on Wyse 50 terminals, the escape sequence for entering graphics mode is ESC H^B and the escape sequence for leaving graphics mode is ESC H^C. Terminals without a graphics mode do not have this escape sequence. The procedure for specifying alternative border characters on a non-graphics terminal is discussed at the end of this section.
2.
Identify the ASCII equivalents for the six graphics characters that 4GL requires to draw the border. The ASCII equivalent of a graphics character is the key that the user presses in graphics mode to obtain the indicated character. The following table shows the graphics characters and the ASCII equivalents for a Wyse 50 terminal.
Window Border Position Lower-left corner Upper-right corner Lower-right corner Horizontal Vertical Graphics Character ASCII Equivalent 1 3 5 z 6
This information should be located in the manual that comes with your terminal.
F-28
3.
You can decompile it by using infocmp redirected to a le. You might want to make a copy of your terminfo directory before you edit les. You can use the TERMINFO environment variable to point to whichever copy of the terminfo directory you want to access.
c.
rmacs
acsc
defnew
Description is the default character for a particular border character and is the equivalent on that terminal for the same border character.
For example, on the Wyse 50 terminal, given the ASCII equivalents for window border position and the system default characters for border position, the acsc capability is set as shown:
acsc=l2m1k3j5qzx6
4.
Use tic to recompile the modied terminfo le. See your operating system documentation for a description of the tic program. The following example shows the full setting for specifying alternative border characters on the Wyse 50:
smacs=\EH^B, rmacs=\EH^C, acsc=l2m1k3j5qzx6, . . . . . sets smacs to ESC H CTRL B sets rmacs to ESC H CTRL C sets acsc to the ASCII equivalents of graphics characters for upper left (l), lower left (m), upper rig
F-30
4GL uses the graphics characters in the terminfo le when you specify a window border in an OPEN WINDOW statement.
If you specify these attributes in your 4GL code, they are ignored. If the terminfo entry for your terminal contains the ul and so attributes, you can use the UNDERLINE and REVERSE intensity attributes. You can see if your terminfo entry includes these capabilities by using the infocmp program. Refer to your operating system documentation for information about infocmp. To use color and intensity in your 4GL programs, you must use termcap (by setting the INFORMIXTERM environment variable to termcap, and by setting the TERMCAP environment variable to $INFORMIXDIR/etc/termcap). For more information, see Appendix D, Environment Variables.
Appendix
Reserved Words
that obeys the rules for identiers but that always produces a compilation error. This appendix, however, lists keywords that you should not use as programmer-dened identiers in a 4GL application. If you do, the program might fail with a compilation or runtime error, or produce unexpected results. (If you receive an error message that seems to be unrelated to the statement that produced the error, review this appendix to see if the error was caused by a reserved word used as an identier.) In general, you cannot use as an identier the name of a built-in constant or variable or the name of an operator that can begin an expression. Chapter 5, Built-In Functions and Operators, describes restricted functionality that results if you declare a 4GL identier with the same name as a built-in function or operator. You are not prevented from declaring most other keywords of 4GL as identiers, but you might not be able to reference such identiers in contexts where the same keyword makes sense. For example, if you open a 4GL window named screen, you will not be able to reference it in statements like CURRENT WINDOW, where the SCREEN keyword species the 4GL screen. Similarly, if ASCII is declared as the name of a variable, you cannot use it in contexts where an expression is valid, because the ASCII operator has different semantics but takes precedence over a variable. Do not declare function names that occur in ESQL/C or in the standard C or POSIX libraries, in the fglusr.h or fglsys.h header les, or that start with fgl. If you avoid these names, you will not run into problems.
In addition to these words, do not declare the names of operating system calls or C or C++ language keywords as identiers in 4GL programs. For a list of these words, see the documentation for your C or C++ compiler and the documentation for your implementation of UNIX or LINUX. Apart from the risk of unexpected behavior or errors, your 4GL code is likely to be difcult to read and to maintain if you use keywords as identiers.
ANSI
The DBANSIWARN environment variable is set. You specify the -ansi command-line ag.
The ANSI SQL-92 reserved words are listed in the following table.
AGGREGATE ALL ALL_ROWS AND ANY AS ASC AVG ALL_ROWS AND ANY CACHE CASE CHAR CHARACTER CHECK CLOSE COBOL COMMIT CONTINUE CRCOLS COUNT CRCOLS CREATE CURRENT CURSOR DEC DECIMAL DECLARE DECODE DELETE DESC DISTINCT DOUBLE END ESCAPE EXEC EXISTS FETCH FIRST_ROWS FLOAT FOR FORTRAN FOUND FROM DELETE DESC GO GOTO GRANT GROUP HAVING IN INDICATOR INNER INSERT INT INTEGER INTO IS ITEM JOIN LANGUAGE LEFT LIKE LOCKS MAX MEMORY_RESIDENT MIN MODULE NON_RESIDENT NOT NULL NUMERIC NVL OF ON OPEN OPTION OR ORDER OUT PASCAL PLI PRECISION PRIVILEGES PROCEDURE PUBLIC REAL REPLICATION RETAIN ROLLBACK SCHEMA SECTION SELCONST SELECT SET SMALLINT SOME SQL SQLCODE SQLERROR SUBSTR SUBSTRING SUM TABLE TO UNION UNIQUE UPDATE USER VALUES VIEW WHENEVER WHERE WITH WORK
If you compare this list with the shorter one for 4GL on the previous page, you can see that some words (for example, AND, AVG, COUNT, and CURRENT) are reserved both by 4GL and by the ANSI/ISO Entry Level standard for SQL. The draft ANSI SQL3 standard lists additional reserved words, such as TYPE, which Informix database servers later than Version 7.3 recognize as reserved words. See the Informix Guide to SQL: Tutorial for more information about using the keywords of SQL as identiers in SQL statements.
Appendix
custform.per
custform.per
DATABASE stores7 SCREEN {
Customer Form Number Owner Name Company Address City Telephone } TABLES customer ATTRIBUTES f000 = customer.customer_num, NOENTRY; f001 = customer.fname; f002 = customer.lname; f003 = customer.company; f004 = customer.address1; f005 = customer.address2; f006 = customer.city; a0 = customer.state, UPSHIFT; f007 = customer.zipcode; f008 = customer.phone, PICTURE = "###-###-#### XXXXX"; :[f000 :[f001 :[f003 :[f04 [f005 :[f006 :[f008 ] ][f002 ] ] ] ] ] State:[a0] Zipcode:[f007 ] ]
orderform.per
orderform.per
DATABASE stores7 SCREEN { -------------------------------------------------------------------------ORDER FORM -------------------------------------------------------------------------Customer Number:[f000 ] Contact Name:[f001 ][f002 ] Company Name:[f003 ] Address:[f004 ][f005 ] City:[f006 ] State:[a0] Zip Code:[f007 ] Telephone:[f008 ] -------------------------------------------------------------------------Order No:[f009 ] Order Date:[f010 ] PO Number:[f011 Shipping Instructions:[f012 ] -------------------------------------------------------------------------Item No. Stock No. Code Description Quantity Price Total [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] [f013 ] [f014 ] [a1 ] [f015 ] [f016 ] [f017 ] [f018 ] Running Total including Tax and Shipping Charges:[f019 ] ========================================================================== } TABLES customer orders items stock ATTRIBUTES f000 = customer.customer_num; f001 = customer.fname; f002 = customer.lname; f003 = customer.company; f004 = customer.address1; f005 = customer.address2; f006 = customer.city; a0 = customer.state, UPSHIFT; f007 = customer.zipcode; f008 = customer.phone, PICTURE = "###-###-#### XXXXX"; f009 f010 f011 f012 f013 f014 a1 = f015 f016 f017 f018 f019 = = = = orders.order_num; orders.order_date, DEFAULT = TODAY; orders.po_num; orders.ship_instruct;
= items.item_num, NOENTRY; = items.stock_num; items.manu_code, UPSHIFT; = stock.description, NOENTRY; = items.quantity; = stock.unit_price, NOENTRY; = items.total_price, NOENTRY; = formonly.t_price TYPE MONEY;
INSTRUCTIONS SCREEN RECORD s_items[4](items.item_num, items.stock_num, items.manu_code, stock.description, items.quantity, stock.unit_price, items.total_price)
H-3
state_list.per
state_list.per
DATABASE stores7 SCREEN { State Selection [a0] [a0] [a0] [a0] [a0] [a0] [a0] } [f000 [f000 [f000 [f000 [f000 [f000 [f000 ] ] ] ] ] ] ]
TABLES state ATTRIBUTES a0 = state.code; f000 = state.sname; INSTRUCTIONS DELIMITERS " " SCREEN RECORD s_state[7](state.*)
stock_sel.per
stock_sel.per
DATABASE stores7 SCREEN { [f018][f019][f020 [f018][f019][f020 [f018][f019][f020 } TABLES stock ATTRIBUTES f018 = FORMONLY.stock_num; f019 = FORMONLY.manu_code; f020 = FORMONLY.manu_name; f021 = FORMONLY.description; f022 = FORMONLY.unit_price; f023 = FORMONLY.unit_descr; INSTRUCTIONS DELIMITERS " " SCREEN RECORD s_stock[3] (FORMONLY.stock_num THRU FORMONLY.unit_descr)
] ] ]
H-5
d4_globals.4gl
d4_globals.4gl
DATABASE stores7 GLOBALS DEFINE p_customer RECORD LIKE customer.*, p_orders RECORD order_num LIKE orders.order_num, order_date LIKE orders.order_date, po_num LIKE orders.po_num, ship_instruct LIKE orders.ship_instruct END RECORD, p_items ARRAY[10] OF RECORD item_num LIKE items.item_num, stock_num LIKE items.stock_num, manu_code LIKE items.manu_code, description LIKE stock.description, quantity LIKE items.quantity, unit_price LIKE stock.unit_price, total_price LIKE items.total_price END RECORD, p_stock ARRAY[30] OF RECORD stock_num LIKE stock.stock_num, manu_code LIKE manufact.manu_code, manu_name LIKE manufact.manu_name, description LIKE stock.description, unit_price LIKE stock.unit_price, unit_descr LIKE stock.unit_descr END RECORD, p_state ARRAY[50] OF RECORD LIKE state.*, state_cnt, stock_cnt INTEGER, print_option CHAR(1) END GLOBALS
d4_main.4gl
d4_main.4gl
GLOBALS "d4_globals.4gl"
MAIN DEFER INTERRUPT OPTIONS HELP FILE "helpdemo" LET print_option = "s" CALL get_states() CALL get_stocks() CALL ring_menu() MENU "MAIN" COMMAND "Customer" "Enter and maintain customer data" HELP 101 CALL customer() CALL ring_menu() COMMAND "Orders" "Enter and maintain orders" HELP 102 CALL orders() CALL ring_menu() COMMAND "Stock" "Enter and maintain stock list" HELP 103 CALL stock() CALL ring_menu() COMMAND "Reports" "Print reports and mailing labels" HELP 104 CALL reports() CALL ring_menu() COMMAND key("!") CALL bang() CALL ring_menu() NEXT OPTION "Customer" COMMAND key("X") CALL demo() CALL ring_menu() NEXT OPTION "Customer" COMMAND "Exit" "Exit program and return to operating system" HELP 105 CLEAR SCREEN EXIT PROGRAM END MENU END MAIN
FUNCTION bang() DEFINE cmd CHAR(80), x CHAR(1) CALL clear_menu() LET x = "!" WHILE x = "!" PROMPT "!" FOR cmd RUN cmd PROMPT "Type RETURN to continue." FOR CHAR x END WHILE END FUNCTION
H-7
d4_main.4gl
FUNCTION mess(str, mrow) DEFINE str CHAR(80), mrow SMALLINT DISPLAY " ", str CLIPPED AT mrow,1 SLEEP 3 DISPLAY "" AT mrow,1 END FUNCTION
FUNCTION ring_menu() DISPLAY "----------------------------------------- ", "Type Control-W for MENU HELP -------" AT 4,2 ATTRIBUTE(MAGENTA) END FUNCTION
FUNCTION clear_menu() DISPLAY "" AT 1,1 DISPLAY "" AT 2,1 END FUNCTION
FUNCTION get_states() DECLARE c_state CURSOR FOR SELECT * FROM state ORDER BY sname LET state_cnt = 1 FOREACH c_state INTO p_state[state_cnt].* LET state_cnt = state_cnt + 1 IF state_cnt > 50 THEN EXIT FOREACH END IF END FOREACH LET state_cnt = state_cnt - 1 END FUNCTION
FUNCTION get_stocks() DECLARE stock_list CURSOR FOR SELECT stock_num, manufact.manu_code, manu_name, description, unit_price, unit_descr FROM stock, manufact WHERE stock.manu_code = manufact.manu_code ORDER BY stock_num LET stock_cnt = 1 FOREACH stock_list INTO p_stock[stock_cnt].* LET stock_cnt = stock_cnt + 1 IF stock_cnt > 30 THEN EXIT FOREACH END IF END FOREACH LET stock_cnt = stock_cnt - 1 END FUNCTION
d4_cust.4gl
d4_cust.4gl
GLOBALS "d4_globals.4gl" FUNCTION customer() OPTIONS FORM LINE 7 OPEN FORM customer FROM "custform" DISPLAY FORM customer ATTRIBUTE(MAGENTA) CALL ring_menu() CALL fgl_drawbox(3,30,3,43) CALL fgl_drawbox(3,61,8,7) CALL fgl_drawbox(11,61,8,7) LET p_customer.customer_num = NULL MENU "CUSTOMER" COMMAND "One-add" "Add a new customer to the database" HELP 201 CALL add_customer(FALSE) COMMAND "Many-add" "Add several new customer to database" HELP 202 CALL add_customer(TRUE) COMMAND "Find-cust" "Look up specific customer" HELP 203 CALL query_customer(23) IF p_customer.customer_num IS NOT NULL THEN NEXT OPTION "Update-cust" END IF COMMAND "Update-cust" "Modify current customer information" HELP 204 CALL update_customer() NEXT OPTION "Find-cust" COMMAND "Delete-cust" "Remove a customer from database" HELP 205 CALL delete_customer() NEXT OPTION "Find-cust" COMMAND "Exit" "Return to MAIN Menu" HELP 206 CLEAR SCREEN EXIT MENU END MENU OPTIONS FORM LINE 3 END FUNCTION
FUNCTION add_customer(repeat) DEFINE repeat INTEGER CALL clear_menu() MESSAGE "Press F1 or CTRL-F for field help; ", "F2 or CTRL-Z to return to menu" IF repeat THEN WHILE input_cust() ERROR "Customer data entered" ATTRIBUTE (GREEN) END WHILE CALL mess("Multiple insert completed current screen values ignored", 23) ELSE IF input_cust() THEN ERROR "Customer data entered" ATTRIBUTE (GREEN) ELSE CLEAR FORM LET p_customer.customer_num = NULL
H-9
d4_cust.4gl
ERROR "Customer addition aborted" ATTRIBUTE (RED, REVERSE) END IF END IF END FUNCTION FUNCTION input_cust() DISPLAY "Press ESC to enter new customer data" AT 1,1 INPUT BY NAME p_customer.* AFTER FIELD state CALL statehelp() DISPLAY "Press ESC to enter new customer data", "" AT 1,1 ON KEY (F1, CONTROL-F) CALL customer_help() ON KEY (F2, CONTROL-Z) LET int_flag = TRUE EXIT INPUT END INPUT IF int_flag THEN LET int_flag = FALSE RETURN(FALSE) END IF LET p_customer.customer_num = 0 INSERT INTO customer VALUES (p_customer.*) LET p_customer.customer_num = SQLCA.SQLERRD[2] DISPLAY BY NAME p_customer.customer_num ATTRIBUTE(MAGENTA) RETURN(TRUE) END FUNCTION
FUNCTION query_customer(mrow) DEFINE where_part CHAR(200), query_text CHAR(250), answer CHAR(1), mrow, chosen, exist SMALLINT CLEAR FORM CALL clear_menu() MESSAGE "Enter criteria for selection" CONSTRUCT where_part ON customer.* FROM customer.* MESSAGE "" IF int_flag THEN LET int_flag = FALSE CLEAR FORM ERROR "Customer query aborted" ATTRIBUTE(RED, REVERSE) LET p_customer.customer_num = NULL RETURN (p_customer.customer_num) END IF LET query_text = "select * from customer where ", where_part CLIPPED, " order by lname" PREPARE statement_1 FROM query_text DECLARE customer_set SCROLL CURSOR FOR statement_1 OPEN customer_set FETCH FIRST customer_set INTO p_customer.* IF status = NOTFOUND THEN LET exist = FALSE ELSE LET exist = TRUE DISPLAY BY NAME p_customer.* MENU "BROWSE" COMMAND "Next" "View the next customer in the list"
d4_cust.4gl
FETCH NEXT customer_set INTO p_customer.* IF status = NOTFOUND THEN ERROR "No more customers in this direction" ATTRIBUTE(RED, REVERSE) FETCH LAST customer_set INTO p_customer.* END IF DISPLAY BY NAME p_customer.* ATTRIBUTE(CYAN) COMMAND "Previous" "View the previous customer in the list" FETCH PREVIOUS customer_set INTO p_customer.* IF status = NOTFOUND THEN ERROR "No more customers in this direction" ATTRIBUTE(RED, REVERSE) FETCH FIRST customer_set INTO p_customer.* END IF DISPLAY BY NAME p_customer.* ATTRIBUTE(CYAN) COMMAND "First" "View the first customer in the list" FETCH FIRST customer_set INTO p_customer.* DISPLAY BY NAME p_customer.* ATTRIBUTE(CYAN) COMMAND "Last" "View the last customer in the list" FETCH LAST customer_set INTO p_customer.* DISPLAY BY NAME p_customer.* ATTRIBUTE(CYAN) COMMAND "Select" "Exit BROWSE selecting the current customer" LET chosen = TRUE EXIT MENU COMMAND "Quit" "Quit BROWSE without selecting a customer" LET chosen = FALSE EXIT MENU END MENU END IF CLOSE customer_set IF NOT exist THEN CLEAR FORM CALL mess("No customer satisfies query", mrow) LET p_customer.customer_num = NULL RETURN (FALSE) END IF IF NOT chosen THEN CLEAR FORM LET p_customer.customer_num = NULL CALL mess("No selection made", mrow) RETURN (FALSE) END IF RETURN (TRUE) END FUNCTION FUNCTION update_customer() CALL clear_menu() IF p_customer.customer_num IS NULL THEN CALL mess("No customer has been selected; use the Find-cust option",23) RETURN END IF MESSAGE "Press F1 or CTRL-F for field-level help" DISPLAY "Press ESC to update customer data; DEL to abort" AT 1,1 INPUT BY NAME p_customer.* WITHOUT DEFAULTS AFTER FIELD state CALL statehelp() DISPLAY "Press ESC to update customer data; DEL to abort", "" AT 1,1 ON KEY (F1, CONTROL-F)
H-11
d4_cust.4gl
CALL customer_help() END INPUT IF NOT int_flag THEN UPDATE customer SET customer.* = p_customer.* WHERE customer_num = p_customer.customer_num CALL mess("Customer data modified", 23) ELSE LET int_flag = FALSE SELECT * INTO p_customer.* FROM customer WHERE customer_num = p_customer.customer_num DISPLAY BY NAME p_customer.* ERROR "Customer update aborted" ATTRIBUTE (RED, REVERSE) END IF END FUNCTION
FUNCTION delete_customer() DEFINE answer CHAR(1), num_orders INTEGER CALL clear_menu() IF p_customer.customer_num IS NULL THEN ERROR "No customer has been selected; use the Find-customer option" ATTRIBUTE (RED, REVERSE) RETURN END IF SELECT COUNT(*) INTO num_orders FROM orders WHERE customer_num = p_customer.customer_num IF num_orders THEN ERROR "This customer has active orders and can not be removed" ATTRIBUTE (RED, REVERSE) RETURN END IF PROMPT " Are you sure you want to delete this customer row? " FOR CHAR answer IF answer MATCHES "[yY]" THEN DELETE FROM customer WHERE customer_num = p_customer.customer_num CLEAR FORM CALL mess("Customer entry deleted", 23) LET p_customer.customer_num = NULL ELSE ERROR "Deletion aborted" ATTRIBUTE (RED, REVERSE) END IF END FUNCTION
FUNCTION customer_help() CASE WHEN infield(customer_num) CALL showhelp(1001) WHEN infield(fname) CALL showhelp(1002) WHEN infield(lname) CALL showhelp(1003) WHEN infield(company) CALL showhelp(1004) WHEN infield(address1) CALL showhelp(1005) WHEN infield(address2) CALL showhelp(1006) WHEN infield(city) CALL showhelp(1007) WHEN infield(state) CALL showhelp(1008)
d4_cust.4gl
WHEN infield(zipcode) CALL showhelp(1009) WHEN infield(phone) CALL showhelp(1010) END CASE END FUNCTION
FUNCTION statehelp() DEFINE idx INTEGER SELECT COUNT(*) INTO idx FROM state WHERE code = p_customer.state IF idx = 1 THEN RETURN END IF DISPLAY "Move cursor using F3, F4, and arrow keys; press ESC to select state" AT 1,1 OPEN WINDOW w_state AT 8,37 WITH FORM "state_list" ATTRIBUTE (BORDER, RED, FORM LINE 2) CALL set_count(state_cnt) DISPLAY ARRAY p_state TO s_state.* LET idx = arr_curr() CLOSE WINDOW w_state LET p_customer.state = p_state[idx].code DISPLAY BY NAME p_customer.state ATTRIBUTE (MAGENTA) RETURN END FUNCTION
H-13
d4_orders.4gl
d4_orders.4gl
GLOBALS "d4_globals.4gl" FUNCTION orders() OPEN FORM order_form FROM "orderform" DISPLAY FORM order_form ATTRIBUTE(MAGENTA) MENU "ORDERS" COMMAND "Add-order" "Enter new order to database and print invoice" HELP 301 CALL add_order() COMMAND "Update-order" "Enter shipping or payment data" HELP 302 CALL update_order() COMMAND "Find-order" "Look up and display orders" HELP 303 CALL get_order() COMMAND "Delete-order" "Remove an order from the database" HELP 304 CALL delete_order() COMMAND "Exit" "Return to MAIN Menu" HELP 305 CLEAR SCREEN EXIT MENU END MENU END FUNCTION FUNCTION add_order() DEFINE pa_curr, s_curr, num_stocks INTEGER, file_name CHAR(20), query_stat INTEGER CALL clear_menu() LET query_stat = query_customer(2) IF query_stat IS NULL THEN RETURN END IF IF NOT query_stat THEN OPEN WINDOW cust_w AT 3,5 WITH 19 ROWS, 72 COLUMNS ATTRIBUTE(BORDER, YELLOW) OPEN FORM o_cust FROM "custform" DISPLAY FORM o_cust ATTRIBUTE(MAGENTA) CALL fgl_drawbox(3,61,4,7) CALL fgl_drawbox(11,61,4,7) CALL add_customer(FALSE) CLOSE FORM o_cust CLOSE WINDOW cust_w IF p_customer.customer_num IS NULL THEN RETURN ELSE DISPLAY by name p_customer.* END IF END IF MESSAGE "Enter the order date, PO number and shipping instructions." INPUT BY NAME p_orders.order_date, p_orders.po_num, p_orders.ship_instruct IF int_flag THEN LET int_flag = FALSE
d4_orders.4gl
CLEAR FORM ERROR "Order input aborted" ATTRIBUTE (RED, REVERSE) RETURN END IF INPUT ARRAY p_items FROM s_items.* HELP 311 BEFORE FIELD stock_num MESSAGE "Press ESC to write order" DISPLAY "Enter a stock number or press CTRL-B to scan stock list" AT 1,1 BEFORE FIELD manu_code MESSAGE "Enter the code for a manufacturer" BEFORE FIELD quantity DISPLAY "" AT 1,1 MESSAGE "Enter the item quantity" ON KEY (CONTROL-B) IF INFIELD(stock_num) OR INFIELD(manu_code) THEN LET pa_curr = arr_curr() LET s_curr = scr_line() CALL get_stock() RETURNING p_items[pa_curr].stock_num, p_items[pa_curr].manu_code, p_items[pa_curr].description, p_items[pa_curr].unit_price DISPLAY p_items[pa_curr].stock_num TO s_items[s_curr].stock_num DISPLAY p_items[pa_curr].manu_code TO s_items[s_curr].manu_code DISPLAY p_items[pa_curr].description TO s_items[s_curr]. description DISPLAY p_items[pa_curr].unit_price TO s_items[s_curr]. unit_price NEXT FIELD quantity END IF AFTER FIELD stock_num, manu_code LET pa_curr = arr_curr() IF p_items[pa_curr].stock_num IS NOT NULL AND p_items[pa_curr].manu_code IS NOT NULL THEN CALL get_item() END IF AFTER FIELD quantity MESSAGE "" LET pa_curr = arr_curr() IF p_items[pa_curr].unit_price IS NOT NULL AND p_items[pa_curr].quantity IS NOT NULL THEN CALL item_total() ELSE ERROR "A valid stock code, manufacturer, and quantity must all be entered" ATTRIBUTE (RED, REVERSE) NEXT FIELD stock_num END IF AFTER INSERT, DELETE CALL renum_items() CALL order_total() AFTER ROW CALL order_total() END INPUT
H-15
d4_orders.4gl
IF int_flag THEN LET int_flag = FALSE CLEAR FORM ERROR "Order input aborted" ATTRIBUTE (RED, REVERSE) RETURN END IF WHENEVER ERROR CONTINUE BEGIN WORK INSERT INTO orders (order_num, order_date, customer_num, ship_instruct, po_num) VALUES (0, p_orders.order_date, p_customer.customer_num, p_orders.ship_instruct, p_orders.po_num) IF status < 0 THEN ROLLBACK WORK ERROR "Unable to complete update of orders table" ATTRIBUTE(RED, REVERSE, BLINK) RETURN END IF LET p_orders.order_num = SQLCA.SQLERRD[2] DISPLAY BY NAME p_orders.order_num IF NOT insert_items() THEN ROLLBACK WORK ERROR "Unable to insert items" ATTRIBUTE(RED, REVERSE, BLINK) RETURN END IF COMMIT WORK WHENEVER ERROR STOP CALL mess("Order added", 23) LET file_name = "inv", p_orders.order_num USING "<<<<&",".out" CALL invoice(file_name) CLEAR FORM END FUNCTION
FUNCTION update_order() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION delete_order() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION order_total() DEFINE order_total MONEY(8), i INTEGER LET order_total = 0.00 FOR i = 1 TO ARR_COUNT() IF p_items[i].total_price IS NOT NULL THEN LET order_total = order_total + p_items[i].total_price
d4_orders.4gl
END IF END FOR LET order_total = 1.1 * order_total DISPLAY order_total TO t_price ATTRIBUTE(GREEN) END FUNCTION FUNCTION item_total() DEFINE pa_curr, sc_curr INTEGER LET pa_curr = arr_curr() LET sc_curr = scr_line() LET p_items[pa_curr].total_price = p_items[pa_curr].quantity * p_items[pa_curr].unit_price DISPLAY p_items[pa_curr].total_price TO s_items[sc_curr].total_price END FUNCTION
FUNCTION renum_items() DEFINE pa_curr, pa_total, sc_curr, sc_total, k INTEGER pa_curr = arr_curr() pa_total = arr_count() sc_curr = scr_line() sc_total = 4 k = pa_curr TO pa_total LET p_items[k].item_num = k IF sc_curr <= sc_total THEN DISPLAY k TO s_items[sc_curr].item_num LET sc_curr = sc_curr + 1 END IF END FOR END FUNCTION LET LET LET LET FOR
FUNCTION insert_items() DEFINE idx INTEGER FOR idx = 1 TO arr_count() IF p_items[idx].quantity != 0 THEN INSERT INTO items VALUES (p_items[idx].item_num, p_orders.order_num, p_items[idx].stock_num, p_items[idx].manu_code, p_items[idx].quantity, p_items[idx].total_price) IF status < 0 THEN RETURN (FALSE) END IF END IF END FOR RETURN (TRUE) END FUNCTION
FUNCTION get_stock() DEFINE idx integer OPEN WINDOW stock_w AT 7, 3 WITH FORM "stock_sel" ATTRIBUTE(BORDER, YELLOW) CALL set_count(stock_cnt) DISPLAY
H-17
d4_orders.4gl
"Use cursor using F3, F4, and arrow keys; press ESC to select a stock item" AT 1,1 DISPLAY ARRAY p_stock TO s_stock.* LET idx = arr_curr() CLOSE WINDOW stock_w RETURN p_stock[idx].stock_num, p_stock[idx].manu_code, p_stock[idx].description, p_stock[idx].unit_price END FUNCTION
FUNCTION get_order() DEFINE idx, exist, chosen INTEGER, answer CHAR(1) CALL clear_menu() CLEAR FORM IF NOT query_customer(2) THEN RETURN END IF DECLARE order_list CURSOR FOR SELECT order_num, order_date, po_num, ship_instruct FROM orders WHERE customer_num = p_customer.customer_num LET exist = FALSE LET chosen = FALSE FOREACH order_list INTO p_orders.* LET exist = TRUE CLEAR orders.* FOR idx = 1 TO 4 CLEAR s_items[idx].* END FOR DISPLAY p_orders.* TO orders.* DECLARE item_list CURSOR FOR SELECT item_num, items.stock_num, items.manu_code, description, quantity, unit_price, total_price FROM items, stock WHERE order_num = p_orders.order_num AND items.stock_num = stock.stock_num AND items.manu_code = stock.manu_code ORDER BY item_num LET idx = 1 FOREACH item_list INTO p_items[idx].* LET idx = idx + 1 IF idx > 10 THEN ERROR "More than 10 items; only 10 items displayed" ATTRIBUTE (RED, REVERSE) EXIT FOREACH END IF END FOREACH CALL set_count(idx - 1) CALL order_total() MESSAGE "Press ESC when you finish viewing the items" DISPLAY ARRAY p_items TO s_items.* ATTRIBUTE(CYAN) MESSAGE "" IF int_flag THEN LET int_flag = FALSE EXIT FOREACH
d4_orders.4gl
END IF PROMPT " Enter y to select this order ", "or RETURN to view next order: " FOR CHAR answer IF answer MATCHES "[yY]" THEN LET chosen = TRUE EXIT FOREACH END IF END FOREACH IF NOT exist THEN ERROR "No orders found for this customer" ATTRIBUTE (RED) ELSE IF NOT chosen THEN CLEAR FORM ERROR "No order selected for this customer" ATTRIBUTE (RED) END IF END IF END FUNCTION
FUNCTION get_item() DEFINE pa_curr, sc_curr INTEGER LET pa_curr = arr_curr() LET sc_curr = scr_line() SELECT description, unit_price INTO p_items[pa_curr].description, p_items[pa_curr].unit_price FROM stock WHERE stock.stock_num = p_items[pa_curr].stock_num AND stock.manu_code = p_items[pa_curr].manu_code IF status THEN LET p_items[pa_curr].description = NULL LET p_items[pa_curr].unit_price = NULL END IF DISPLAY p_items[pa_curr].description, p_items[pa_curr].unit_price TO s_items[sc_curr].description, s_items[sc_curr].unit_price IF p_items[pa_curr].quantity IS NOT NULL THEN CALL item_total() END IF END FUNCTION
FUNCTION invoice(file_name) DEFINE x_invoice RECORD order_num order_date ship_instruct backlog po_num ship_date ship_weight ship_charge item_num stock_num manu_code quantity total_price description unit_price unit
LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE
orders.order_num, orders.order_date, orders.ship_instruct, orders.backlog, orders.po_num, orders.ship_date, orders.ship_weight, orders.ship_charge, items.item_num, items.stock_num, items.manu_code, items.quantity, items.total_price, stock.description, stock.unit_price, stock.unit,
H-19
d4_orders.4gl
DECLARE invoice_data CURSOR FOR SELECT o.order_num,order_date,ship_instruct,backlog,po_num,ship_date, ship_weight,ship_charge, item_num,i.stock_num,i.manu_code,quantity,total_price, s.description,unit_price,unit,unit_descr, manu_name FROM orders o,items i,stock s,manufact m WHERE ((o.order_num=p_orders.order_num) AND (i.order_num=p_orders.order_num) AND (i.stock_num=s.stock_num AND i.manu_code=s.manu_code) AND (i.manu_code=m.manu_code)) ORDER BY 9 CASE (print_option) WHEN "f" START REPORT r_invoice TO file_name CALL clear_menu() MESSAGE "Writing invoice -- please wait" WHEN "p" START REPORT r_invoice TO PRINTER CALL clear_menu() MESSAGE "Writing invoice -- please wait" WHEN "s" START REPORT r_invoice END CASE FOREACH invoice_data INTO x_invoice.* OUTPUT TO REPORT r_invoice (p_customer.*, x_invoice.*) END FOREACH FINISH REPORT r_invoice IF print_option = "f" THEN LET msg = "Invoice written to file ", file_name CLIPPED CALL mess(msg, 23) END IF END FUNCTION
REPORT r_invoice (c, x) DEFINE c RECORD LIKE x RECORD order_num order_date ship_instruct backlog po_num ship_date ship_weight ship_charge item_num stock_num manu_code quantity total_price description unit_price
customer.*, LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE LIKE orders.order_num, orders.order_date, orders.ship_instruct, orders.backlog, orders.po_num, orders.ship_date, orders.ship_weight, orders.ship_charge, items.item_num, items.stock_num, items.manu_code, items.quantity, items.total_price, stock.description, stock.unit_price,
d4_orders.4gl
unit LIKE stock.unit, unit_descr LIKE stock.unit_descr, manu_name LIKE manufact.manu_name END RECORD, sales_tax, calc_total MONEY(8,2) OUTPUT LEFT MARGIN 0 RIGHT MARGIN 0 TOP MARGIN 1 BOTTOM MARGIN 1 PAGE LENGTH 48 FORMAT BEFORE GROUP OF x.order_num SKIP TO TOP OF PAGE SKIP 1 LINE PRINT 10 SPACES, " W E S T C O A S T W H O L E S A L E R S , I N C ." PRINT 30 SPACES," 1400 Hanbonon Drive" PRINT 30 SPACES,"Menlo Park, CA 94025" SKIP 1 LINES PRINT "Bill To:", COLUMN 10,c.fname CLIPPED, " ", c.lname CLIPPED; PRINT COLUMN 56,"Invoice No. ",x.order_num USING "&&&&&" PRINT COLUMN 10,c.company PRINT COLUMN 10,c.address1 CLIPPED; PRINT COLUMN 56,"Invoice Date: ", x.order_date PRINT COLUMN 10,c.address2 CLIPPED; PRINT COLUMN 56,"Customer No. ", c.customer_num USING "####&" PRINT COLUMN 10,c.city CLIPPED,", ",c.state CLIPPED," ", c.zipcode CLIPPED; PRINT COLUMN 56,"PO No. ",x.po_num PRINT COLUMN 10,c.phone CLIPPED; PRINT COLUMN 56,"Backlog Status: ",x.backlog SKIP 1 LINES PRINT COLUMN 10,"Shipping Instructions: ", x.ship_instruct PRINT COLUMN 10,"Ship Date: ",x.ship_date USING "ddd. mmm dd, yyyy"; PRINT " Weight: ", x.ship_weight USING "#####&.&&" SKIP 1 LINES PRINT "----------------------------------------"; PRINT "---------------------------------------" PRINT " Stock Unit "; PRINT " Item " PRINT " # Num Man Description Qty Cost Unit "; PRINT " Unit Description Total" SKIP 1 LINES LET calc_total = 0.00 ON EVERY ROW PRINT x.item_num USING "#&"," ", x.stock_num USING "&&", " ",x.manu_code; PRINT " ",x.description," ",x.quantity USING "###&", " PRINT x.unit_price USING "$$$&.&&"," ",x.unit, " ", x.unit_descr," "; PRINT x.total_price USING "$$$$$$$&.&&" LET calc_total = calc_total + x.total_price AFTER GROUP OF x.order_num SKIP 1 LINES PRINT "----------------------------------------"; PRINT "---------------------------------------"
";
H-21
d4_orders.4gl
PRINT COLUMN 50, " Sub-total: ",calc_total USING "$$$$$$$&.&&" LET sales_tax = 0.065 * calc_total LET x.ship_charge = 0.035 * calc_total PRINT COLUMN 45, "Shipping Charge (3.5%): ", x.ship_charge USING "$$$$$$$&.&&" PRINT COLUMN 50, " Sales Tax (6.5%): ",sales_tax USING "$$$$$$$&.&&" PRINT COLUMN 50, " -----------" LET calc_total = calc_total + x.ship_charge + sales_tax PRINT COLUMN 50, " Total: ",calc_total USING "$$$$$$$&.&&" IF print_option = "s" THEN PAUSE "Type RETURN to continue" END IF END REPORT
d4_stock.4gl
d4_stock.4gl
GLOBALS "d4_globals.4gl"
FUNCTION stock() MENU "STOCK" COMMAND "Add-stock" "Add new stock items to database" HELP 401 CALL add_stock() COMMAND "Find-stock" "Look up specific stock item" HELP 402 CALL query_stock() COMMAND "Update-stock" "Modify current stock information" HELP 403 CALL update_stock() COMMAND "Delete-stock" "Remove a stock item from database" HELP 404 CALL delete_stock() COMMAND "Exit" "Return to MAIN Menu" HELP 405 CLEAR SCREEN EXIT MENU END MENU END FUNCTION
FUNCTION add_stock() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION query_stock() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION update_stock() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION delete_stock() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
H-23
d4_report.4gl
d4_report.4gl
GLOBALS "d4_globals.4gl"
FUNCTION reports() CALL ring_menu() MENU "REPORTS" COMMAND "Labels" "Print mailing labels from customer list" HELP 501 CALL print_labels() CLEAR SCREEN CALL ring_menu() COMMAND "Accounts-receivable" "Print current unpaid orders" HELP 502 CALL print_ar() CLEAR SCREEN CALL ring_menu() COMMAND "Backlog" "Print backlogged orders" HELP 503 CALL print_backlog() CLEAR SCREEN CALL ring_menu() COMMAND "Stock-list" "Print stock available" HELP 504 CALL print_stock() CLEAR SCREEN CALL ring_menu() COMMAND "Options" "Change the report output options" HELP 505 CALL update_options() CALL ring_menu() COMMAND "Exit" "Return to MAIN Menu" HELP 506 CLEAR SCREEN EXIT MENU END MENU END FUNCTION FUNCTION print_labels() DEFINE where_part CHAR(200), query_text CHAR(250), msg CHAR(50), file_name CHAR(20) OPTIONS FORM LINE 7 OPEN FORM customer FROM "custform" DISPLAY FORM customer ATTRIBUTE(MAGENTA) CALL fgl_drawbox(3,30,3,43) CALL fgl_drawbox(3,61,8,7) CALL fgl_drawbox(11,61,8,7) CALL clear_menu() DISPLAY "CUSTOMER LABELS:" AT 1,1 MESSAGE "Use query-by-example to select customer list" CONSTRUCT BY NAME where_part ON customer.* IF int_flag THEN LET int_flag = FALSE ERROR "Label print request aborted" RETURN END IF MESSAGE "" LET query_text = "select * from customer where ", where_part CLIPPED, " order by zipcode"
d4_report.4gl
PREPARE label_st FROM query_text DECLARE label_list CURSOR FOR label_st CASE (print_option) WHEN "f" PROMPT " Enter file name for labels >" FOR file_name IF file_name IS NULL THEN LET file_name = "labels.out" END IF MESSAGE "Printing mailing labels to ", file_name CLIPPED, " -- Please wait" START REPORT labels_report TO file_name WHEN "p" MESSAGE "Printing mailing labels -- Please wait" START REPORT labels_report TO PRINTER WHEN "s" START REPORT labels_report CLEAR SCREEN END CASE FOREACH label_list INTO p_customer.* OUTPUT TO REPORT labels_report (p_customer.*) IF int_flag THEN LET int_flag = FALSE EXIT FOREACH END IF END FOREACH FINISH REPORT labels_report IF int_flag THEN LET int_flag = FALSE ERROR "Label printing aborted" ATTRIBUTE (RED, REVERSE) RETURN END IF IF print_option = "f" THEN LET msg = "Labels printed to ", file_name CLIPPED CALL mess(msg, 23) END IF CLOSE FORM customer OPTIONS FORM LINE 3 END FUNCTION
REPORT labels_report (rl) DEFINE rl RECORD LIKE customer.* OUTPUT TOP MARGIN 0 BOTTOM MARGIN 0 PAGE LENGTH 6 FORMAT ON EVERY ROW SKIP TO TOP OF PAGE PRINT rl.fname CLIPPED, 1 SPACE, rl.lname PRINT rl.company PRINT rl.address1 IF rl.address2 IS NOT NULL THEN PRINT rl.address2 END IF PRINT rl.city CLIPPED, ", ", rl.state, 2 SPACES, rl.zipcode IF print_option = "s" THEN PAUSE "Type RETURN to continue"
H-25
d4_report.4gl
FUNCTION print_ar() DEFINE r RECORD customer_num LIKE customer.customer_num, fname LIKE customer.fname, lname LIKE customer.lname, company LIKE customer.company, order_num LIKE orders.order_num, order_date LIKE orders.order_date, ship_date LIKE orders.ship_date, paid_date LIKE orders.paid_date, total_price LIKE items.total_price END RECORD, file_name CHAR(20), msg CHAR(50) DECLARE ar_list CURSOR FOR SELECT customer.customer_num,fname,lname,company, orders.order_num,order_date,ship_date,paid_date, total_price FROM customer,orders,items WHERE customer.customer_num=orders.customer_num AND paid_date IS NULL AND orders.order_num=items.order_num ORDER BY 1,5 CALL clear_menu() CASE (print_option) WHEN "f" PROMPT " Enter file name for AR Report >" FOR file_name IF file_name IS NULL THEN LET file_name = "ar.out" END IF MESSAGE "Printing AR REPORT to ", file_name CLIPPED, " -- Please wait" START REPORT ar_report TO file_name WHEN "p" MESSAGE "Printing AR REPORT -- Please wait" START REPORT ar_report TO PRINTER WHEN "s" START REPORT ar_report CLEAR SCREEN MESSAGE "Printing AR REPORT -- Please wait" END CASE FOREACH ar_list INTO r.* OUTPUT TO REPORT ar_report (r.*) IF int_flag THEN LET int_flag = FALSE EXIT FOREACH END IF END FOREACH FINISH REPORT ar_report IF int_flag THEN LET int_flag = FALSE ERROR "AR REPORT printing aborted" ATTRIBUTE (RED, REVERSE) RETURN END IF IF print_option = "f" THEN
d4_report.4gl
LET msg = "AR REPORT printed to ", file_name CLIPPED CALL mess(msg, 23) END IF END FUNCTION REPORT ar_report (r) DEFINE r RECORD customer_num LIKE customer.customer_num, fname LIKE customer.fname, lname LIKE customer.lname, company LIKE customer.company, order_num LIKE orders.order_num, order_date LIKE orders.order_date, ship_date LIKE orders.ship_date, paid_date LIKE orders.paid_date, total_price LIKE items.total_price END RECORD, name_text CHAR(80) OUTPUT PAGE LENGTH 22 LEFT MARGIN 0 FORMAT PAGE HEADER PRINT 15 SPACES,"West Coast Wholesalers, Inc." PRINT 6 SPACES, "Statement of ACCOUNTS RECEIVABLE - ", TODAY USING "mmm dd, yyyy" SKIP 1 LINES LET name_text = r.fname CLIPPED," ",r.lname CLIPPED,"/", r.company CLIPPED PRINT 29 - length(name_text)/2 SPACES, name_text SKIP 1 LINES PRINT " Order Date Order Number Ship Date Amount" PRINT "----------------------------------------------------------" BEFORE GROUP OF r.customer_num SKIP TO TOP OF PAGE AFTER GROUP OF r.order_num NEED 3 LINES PRINT " ",r.order_date,7 SPACES,r.order_num USING "###&",8 SPACES, r.ship_date," ", GROUP SUM(r.total_price) USING "$$$$,$$$,$$$.&&" AFTER GROUP OF r.customer_num PRINT 42 SPACES,"----------------" PRINT 42 SPACES,GROUP SUM(r.total_price) USING "$$$$,$$$,$$$.&&" PAGE TRAILER IF print_option = "s" THEN PAUSE "Type RETURN to continue" END IF END REPORT
H-27
d4_report.4gl
LET po = " ", print_option DISPLAY po AT 8,46 ATTRIBUTE(CYAN) MENU "REPORT OPTIONS" COMMAND "File" "Send all reports to a file" LET print_option = "f" EXIT MENU COMMAND "Printer" "Send all reports to the printer" LET print_option = "p" EXIT MENU COMMAND "Screen" "Send all reports to the terminal screen" LET print_option = "s" EXIT MENU COMMAND "Exit" EXIT MENU END MENU DISPLAY "" AT 8,1 END FUNCTION
FUNCTION print_backlog() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
FUNCTION print_stock() ERROR "This option has not been implemented" ATTRIBUTE (RED) END FUNCTION
d4_demo.4gl
d4_demo.4gl
FUNCTION demo() CALL ring_menu() MENU "DEMO" COMMAND "Menus" "Source code for MAIN Menu" CALL showhelp(2001) COMMAND "Windows" "Source code for STATE CODE Window" CALL showhelp(2007) COMMAND "Forms" "Source code for new CUSTOMER data entry" CALL showhelp(2006) COMMAND "Detail-Scrolling" "Source code for scrolling of new ORDER line-items" CALL showhelp(2003) COMMAND "ScrollCursor" "Source code for customer record BROWSE/SCROLL" CALL showhelp(2008) COMMAND "Query_language" "Source code for new order insertion using SQL" CALL showhelp(2004) COMMAND "Construct_query" "Source code for QUERY-BY-EXAMPLE selection and reporting" CALL showhelp(2002) COMMAND "Reports" "Source code for MAILING LABEL report" CALL showhelp(2005) COMMAND "Exit" "Return to MAIN MENU" CLEAR SCREEN EXIT MENU END MENU END FUNCTION
H-29
helpdemo.src
helpdemo.src
.101 The Customer option presents you with a menu that allows you to: o o o o Add new customers to the database Locate customers in the database Update customer files Remove customers from the database
.102 The Orders option presents you with a menu that allows you to: o o o o Enter a new order and print an invoice Update an existing order Look up and display orders Remove orders from the database
.103 The Stock option presents you with a menu that allows you to: o o o o Add new items to the list of stock Look up and display stock items Modify current stock descriptions and values Remove items from the list of stock
.104 The Reports option presents you with a menu that allows you to: o o o o o Select and print mailing labels sorted by zip code Print a report of current accounts receivable Print a report of backloged orders Print a list of current stock available Change the report output options
.105 The Exit option leaves the program and returns you to the operating system. .201 The One-add option enables you to enter data on new customers to the database. You may get assistance on what input is appropriate for each field by pressing the function key F1 when the cursor is in the field. When you have entered all the data you want for a given customer, press ESC to enter the data in the database. If you want to abort a given entry and not write it to the database, press the INTERRUPT key (usually DEL or CTRL-C).
helpdemo.src
.202 The Many-add option enables you to enter data on new customers to the database. You may get assistance on what input is appropriate for each field by pressing the function key F1 when the cursor is in the field. When you have entered all the data you want for a given customer, press ESC to enter the data in the database. If you want to abort a given entry and not write it to the database, press the INTERRUPT key (usually DEL or CTRL-C). After each entry, the cursor will move to the beginning of the form and await the entry of the next customer. If you have no more customers to add, press CTRL-Z to return to the CUSTOMER Menu. .203 The Find- cust option allows you to select one or more customers and to display their data on the screen by using query-by-example input. Use the RETURN or arrow keys to move through the form. Enter the criteria you want the program to use in searching for customers. Your options include: o o o o o Literal values A range of values (separated by ":") A list of values (separated by "|") Relational operators (for example ">105") Wildcards like ? and * to match single or any number of characters
.204 The Update-cust option enables you to alter data on old customers in the database. You must first select a current customer row to deal with by using the Find-cust option. You may get assistance on what input is appropriate for each field by pressing the function key F1 when the cursor is in the field. When you have altered all the data you want for a given customer, press ESC to enter the data in the database. If you want to abort the changes and not write them to the database, press the INTERRUPT key (usually DEL or CTRL-C). .205 The Delete-cust option enables you to remove customers from the database. You must first select a current customer row to deal with by using the Find-cust option. For your protection, you will be asked to confirm that the record should be deleted. Once deleted, it cannot be restored. Customers with active orders can not be deleted. .206 The Exit option of the CUSTOMER Menu takes you back to the MAIN Menu. .301 The Add-order option enables you to add a new order for an existing customer. You must first select the desired customer using query-byexample selection criteria. You will then enter the order date, PO number, and shipping instructions. The detail line items are then entered into a scrolling display array. Up to ten items may be entered using the four line screen array. After the new order is entered, an invoice is automatically generated and displayed on the screen. .302 The Update-order option is currently not implemented.
H-31
helpdemo.src
.303 The Find-order option enables you to browse through and select an existing order. You must first select the desired customer (or customers) whos orders you wish to scan. For each customer selected, each corresponding order will be displayed on the screen for examination. You may either select an invoice, skip to the next invoice, or cancel processing. .304 The Delete-order option is currently not implemented. .305 The Exit option of the ORDER Menu returns you to the MAIN Menu. .311 You may enter up to ten line items into the scrolling screen array. A num ber of standard functions are available for manipulating the cursor in a screen array. o o o o o o F1Insert new line in the screen array F2 Remove the current line from the screen array F3Page down one page in the screen array F4Page up one page in the screen array ESCExit input array CTRL-BWhen in the Stock Number or Manufacturer Code fields, a window will open in the middle of the screen and display a scrolled list of all items in stock, identified by the stock number and manufacturer. Using F3, F4, and the up and down arrow keys, move the cursor to the line that identifies the desired item and hit ESC. The window will disappear and the selected information will automatically appear in the proper line. o etc...The arrow-keys, and the standard field editing keys are available The item_total field will be displayed in reverse-video green for total amounts over $500. .401 The Add-stock option is currently not implemented. .402 The Find-stock option is currently not implemented. .403 The Update-stock option is currently not implemented. .404 The Delete-stock option is currently not implemented. .405 The Exit option of the STOCK Menu returns you to the MAIN Menu. .501 The Labels option enables you to create a list of mailing labels gener ated using a query-by-example specification. You will be prompted for the output file name. .502 The Accounts-receivable option enables you to create a report summarizing all unpaid orders in the database. You will be prompted for the output file name.
helpdemo.src
.503 The Backlog option is currently not implemented. .504 The Stock-list option is currently not implemented. .505 The Options option enables you to change the destination of any re port generated during the current session. The default option is to display all reports on the terminal screen. The other options are to print all reports to either the printer or an operating system file. .506 The Exit option of the REPORT Menu returns you to the MAIN Menu.
.1001 The Number field on the Customer Form contains the serial integer assigned to the customer row when the data for the customer is first entered into the database. It is a unique number for each customer. The lowest value of this field is 101. .1002 The first section following the Name label should contain the first name of the contact person at the customers company. .1003 The second section following the Name label should contain the last name of the contact person at the customers company. .1004 This field should contain the name of the customers company. .1005 The first line of the Address section of the form should contain the mailing address of the company. .1006 The second line of the Address section of the form should be used only when there is not sufficient room in the first line to contain the entire mailing address. .1007 The City field should contain the city name portion of the mailing of the customer.
address
.1008 Enter the two-character code for the desired state. If no code is entered, or the entered code is not in the programs list of valid entries, a window will appear on the screen with a scrolling list of all states and codes. Using the F3, F4, up and down arrow keys, move the cursor to the line containing the desired state. After typing ESC, the window will disappear and the selected state code will appear in the customer entry screen. .1009 Enter the five digit Zip Code in this field.
H-33
helpdemo.src
.1010 Enter the telephone number of the contact person at the customers company. Include the Area Code and extension using the format "###-###-#### #####". .2001 The following is the INFORMIX-4GL source for the main menu. Note that only the text is specified by the MENU statement; the structure and runtime menu functions are built-in. OPTIONS HELP FILE "helpdemo" OPEN FORM menu_form FROM "ring_menu" DISPLAY FORM menu_form MENU "MAIN" COMMAND "Customer" "Enter and maintain customer data" HELP 101 CALL customer() DISPLAY FORM menu_form COMMAND "Orders" "Enter and maintain orders" HELP 102 CALL orders() DISPLAY FORM menu_form COMMAND "Stock" "Enter and maintain stock list" HELP 103 CALL stock() DISPLAY FORM menu_form COMMAND "Reports" "Print reports and mailing labels" HELP 104 CALL reports() DISPLAY FORM menu_form COMMAND "Exit" "Exit program and return to operating system" HELP 105 CLEAR SCREEN EXIT PROGRAM END MENU .2002 The following is the INFORMIX-4GL source code for mailinglabel selection and printing. The CONSTRUCT statement manages the query-byexample input and builds the corresponding SQL where-clause. CONSTRUCT BY NAME where_part ON customer.* LET query_text = "select * from customer where ", where_part CLIPPED, " order by zipcode" PREPARE mail_query FROM query_text DECLARE label_list CURSOR FOR mail_query PROMPT "Enter file name for labels >" FOR file_name MESSAGE "Printing mailing labels to ", file_name CLIPPED," -Please wait" START REPORT labels_report TO file_name FOREACH label_list INTO p_customer.* OUTPUT TO REPORT labels_report (p_customer.*) END FOREACH FINISH REPORT labels_report See the source code option REPORT for the corresponding report routine.
helpdemo.src
.2003 The following is the INFORMIX-4GL source code for order entry using scrolled input fields. Only the INPUT ARRAY statement in needed to utilize the full scrolling features. Some additional code has been added merely to customize the array processing to this application. DISPLAY "Press ESC to write order" AT 1,1 INPUT ARRAY p_items FROM s_items.* HELP 311 BEFORE FIELD stock_num MESSAGE "Enter a stock number." BEFORE FIELD manu_code MESSAGE "Enter the code for a manufacturer." AFTER FIELD stock_num, manu_code LET pa = arr_curr() LET sc = scr_line() SELECT description, unit_price INTO p_items[pa].description, p_items[pa].unit_price FROM stock WHERE stock_num = p_items[pa].stock_num AND stock_manu = p_items[pa].menu_code DISPLAY p_items[pa].description, p_items[pa].unit_price TO stock[sc].* CALL item_total() AFTER FIELD quantity CALL item_total() AFTER INSERT, DELETE, ROW CALL order_total() END INPUT See the source code option QUERY-LANGUAGE for the SQL statements that insert the order information into the database. .2004 The following is the INFORMIX-4GL source code that uses SQL to insert the entered order information into the database. Note that the use of transactions ensures that database integrity is maintained, even if an intermediate operation fails. BEGIN WORK LET p_orders.order_num = 0 INSERT INTO orders VALUES (p_orders.*) IF status < 0 THEN ROLLBACK WORK MESSAGE "Unable to complete update of orders table" RETURN END IF LET p_orders.order_num = SQLCA.SQLERRD[2] DISPLAY BY NAME p_orders.order_num FOR i = 1 to arr_count() INSERT INTO items VALUES (p_items[counter].item_num, p_orders.order_num, p_items[counter].stock_num, p_items[counter].manu_code, p_items[counter].quantity, p_items[counter].total_price) IF status < 0 THEN ROLLBACK WORK Message "Unable to insert items" RETURN FALSE END IF END FOR COMMIT WORK
H-35
helpdemo.src
.2005 The following is the INFORMIX-4GL source code that generates the mailinglabel report. See the source code option CONSTRUCT for the report calling sequence. REPORT labels_report (rl) DEFINE rl RECORD LIKE customer.* OUTPUT TOP MARGIN 0 PAGE LENGTH 6 FORMAT ON EVERY ROW SKIP TO TOP OF PAGE PRINT rl.fname CLIPPED, 1 SPACE, rl.lname PRINT rl.company PRINT rl.address1 IF rl.address2 IS NOT NULL THEN PRINT rl.address2 END IF PRINT rl.city CLIPPED, ", ", rl.state, 2 SPACES, rl.zipcode END REPORT .2006 The following is the INFORMIX-4GL source code that manages a simple form for data entry. Note the use of special key definitions during data entry. OPEN FORM cust_form FROM "customer" DISPLAY FORM cust_form MESSAGE "Press F1 or CTRL-F for field help;", "F2 or CTRL-Z to return to CUSTOMER Menu" DISPLAY "Press ESC to enter new customer data or DEL to abort entry" INPUT BY NAME p_customer.* AFTER FIELD state CALL statehelp() ON KEY (F1, CONTROL-F) CALL customer_help() ON KEY (F2, CONTROL-Z) CLEAR FORM RETURN END INPUT .2007 The following is the INFORMIX-4GL source code that opens a window in the customer entry screen, displays the list of valid state names and codes, sa ves the index into the p_state array for the selected state, closes the window, and returns the index to the calling routine. OPEN WINDOW w_state AT 8,40 WITH FORM "state_list" ATTRIBUTE (BORDER, RED, FORM LINE 2) CALL set_count(state_cnt) DISPLAY ARRAY p_state TO s_state.* LET idx = arr_curr() CLOSE WINDOW w_state RETURN (idx)
helpdemo.src
.2008 The following is the INFORMIX-4GL source code that allows the user to browse through the rows returned by a "scroll" cursor. DECLARE customer_set SCROLL CURSOR FOR SELECT * FROM customer ORDER BY lname OPEN customer_set FETCH FIRST customer_set INTO p_customer.* IF status = NOTFOUND THEN LET exist = FALSE ELSE LET exist = TRUE DISPLAY BY NAME p_customer.* MENU "BROWSE" COMMAND "Next" "View the next customer in the list" FETCH NEXT customer_set INTO p_customer.* IF status = NOTFOUND THEN ERROR "No more customers in this direction" FETCH LAST customer_set INTO p_customer.* END IF DISPLAY BY NAME p_customer.* COMMAND "Previous" "View the previous customer in the list" FETCH PREVIOUS customer_set INTO p_customer.* IF status = NOTFOUND THEN ERROR "No more customers in this direction" FETCH FIRST customer_set INTO p_customer.* END IF DISPLAY BY NAME p_customer.* COMMAND "First" "View the first customer in the list" FETCH FIRST customer_set INTO p_customer.* DISPLAY BY NAME p_customer.* COMMAND "Last" "View the last customer in the list" FETCH LAST customer_set INTO p_customer.* DISPLAY BY NAME p_customer.* COMMAND "Select" "Exit BROWSE selecting the current customer" LET chosen = TRUE EXIT MENU COMMAND "Quit" "Quit BROWSE without selecting a customer" LET chosen = FALSE EXIT MENU END MENU END IF CLOSE customer_set
H-37
Appendix
It is preparable. It is supported by your Informix database server. It appears between SQL ... END SQL delimiters, as described in SQL on page 4-349.
Alternatively, if the rst two conditions are true, you can also use the PREPARE statement of SQL to do the following:
1. 2. 3. 4.
Store the SQL statement as a character string. Set up the statement for execution by means of the PREPARE statement (see page I-18). Process the statement by means of the EXECUTE or EXECUTE IMMEDIATE statement (see page I-12). If the statement does not need to be reused, release the resources that it occupies with the FREE statement.
,
ADD Clause p. I-2 DROP Clause p. I-3 MODIFY Clause p. I-3 ADD CONSTRAINT Clause p. I-3 DROP CONSTRAINT Clause p. I-3 MODIFY NEXT SIZE Clause p. I-4 LOCK MODE Clause p. I-4
, (
Add Column Clause p. I-3
I-2
Add Column Clause new column name SQL Data Type p. I-32 NOT NULL
,
Column-Level Constraint Denition p. I-7
, (
column name
, (
Modify Column Clause
Modify Column Clause column name SQL Data Type p. I-32 NOT NULL Column-Level Constraint Denition p. I-7 ADD CONSTRAINT Clause ADD CONSTRAINT Constraint Denition p. I-8
, (
Constraint Name p. I-31
MODIFY NEXT SIZE Clause MODIFY NEXT SIZE LOCK MODE Clause LOCK MODE kbytes
PAGE ROW
+ BEGIN WORK
CLOSE
+ CLOSE DATABASE
COMMIT WORK
CONNECT TO
E/C
AS AS
E/C
I-4
Database Environment
USING
validation_var
SE + CREATE AUDIT FOR Table Name p. I-31 Synonym Name p. I-31 View Name p. I-31 + CREATE DATABASE Database Name p. I-31 IN dbspace IN
"pathname "
OL Log Clause WITH BUFFERED LOG MODE ANSI + CREATE UNIQUE DISTINCT ON Clause ON Table Name p. I-31 Synonym Name p. I-31 + CREATE PROCEDURE FROM CLUSTER INDEX index name ON Clause LOG
, (
column name ASC DESC
+ CREATE SYNONYM Synonym Name p. I-31 FOR Table Name p. I-31 View Name p. I-31
I-6
,
CREATE TABLE Table Name p. I-31
, ,
Constraint Denition p. I-8
)
Storage Option p. I-9
,
+ TEMP TABLE temp table name
, ,
Temp Table Constraint Denition p. I-8
)
WITH NO LOG
Column Denition column SQL Data Type p. I-32 NOT NULL Column-Level Constraint Denition p. I-7
Temp Table Column Denition column SQL Data Type p. I-32 NOT NULL Temp Table Column Constraint p. I-8
Temp Table Column Constraint UNIQUE + DISTINCT PRIMARY KEY CHECK Clause p. I-8 Constraint Denition UNIQUE + DISTINCT
, (
column
)
+ CONSTRAINT Constraint Name p. I-31
Temp Table Constraint Denition UNIQUE + DISTINCT PRIMARY KEY CHECK Clause p. I-8
, (
column
Condition p. I-29
I-8
Storage Option
IN dbspace
EXTENT SIZE rst kpages LOCK MODE Clause LOCK MODE PAGE ROW View Name p. I-31
CREATE VIEW
AS
, (
column name
DECLARE
FOR
FOR UPDATE
,
column
DELETE FROM
Table Name p. I-31 WHERE View Name p. I-31 Synonym Name p. I-31 Condition p. I-29 Cursor Name p. I-31
CURRENT OF
DISCONNECT E/C
CURRENT
DEFAULT ALL
'connection'
connection_var
I-10
SE + DROP AUDIT FOR Table Name p. I-31 Synonym Name p. I-31 View Name p. I-31 + DROP DATABASE Database Name p. I-31
+ DROP TABLE Table Name p. I-31 Synonym Name p. I-31 + DROP VIEW View Name p. I-31 Synonym Name p. I-31
+ EXECUTE
+ EXECUTE IMMEDIATE Quoted String p. I-41 statement_var + FETCH + NEXT PREVIOUS PRIOR FIRST LAST CURRENT RELATIVE Cursor Name p. I-31 + INTO Variable List p. I-13
I-12
FOREACH
cursor
statement
END FOREACH
USING
Variable List
INTO
Variable List
WITH REOPTIMIZATION
,
Variable List Variable
.
record
.* . rst
THROUGH THRU record . last
Variable record
variable
. ,
array
3 integer expression
+ FREE TEXT or BYTE Variable p. I-13 Prepared Statement Name p. I-41 Cursor Name p. I-31
The 4GL compiler treats the name of the object to be freed in the order shown in the diagram. In other words, the compiler looks rst for a TEXT or BYTE variable having the given name; if one exists, that is the object that is freed. If no TEXT or BYTE variable having that name exists, the compiler then looks for a prepared statement or a cursor having that name and frees that. When a TEXT or BYTE variable has the same name as a prepared statement or cursor, you cannot free resources allocated to the prepared statement or to the cursor.
I-14
+ GRANT +
TO
PUBLIC
,
user
ON
TO
PUBLIC
,
user
AS grantor
,
1 1 1 INSERT DELETE SELECT +
, (
column name
1 +
UPDATE
, (
column name
INDEX ALTER
INSERT INTO
, (
column name
)
SELECT Statement (Subset) p. I-20
I-16
,
Variable p. I-13 NULL Constant Expression p. I-36 Record Reference p. I-42 Record Reference p. I-42
.*
. member
Record Reference p. I-42
THRU
. member
+ LOAD FROM
"delimiter "
Variable p. I-13
INSERT INTO
, (
column
Variable p. I-13
+ LOCK TABLE Table Name p. I-31 Synonym Name p. I-31 + OPEN Cursor Name p. I-31 USING IN SHARE EXCLUSIVE MODE
,
Variable p. I-13
FROM
,
FROM Variable p. I-13
I-18
. old column
TO
new column
+ RENAME TABLE owner + REVOKE Table-Level Privileges p. I-19 ON Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31 Database-Level Privileges p. I-20 Table-Level Privileges ALL PRIVILEGES FROM PUBLIC old name TO new name
user
,
INSERT DELETE SELECT UPDATE INDEX ALTER
UNION UNION ALL SELECT Select Clause INTO Clause p. I-21 FROM Clause p. I-22
I-20
SELECT Clause
,
Select Item p. I-21
display label + AS
*
Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31
. ,
Variable p. I-13
FROM Clause FROM Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31 table alias + AS
Additional Tables
,
Table Name p. I-31 + View Name p. I-31 Synonym Name p. I-31 OUTER Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31 Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31 table alias AS table alias AS table alias + AS
OUTER (
) ,
Additional Tables
I-22
Join column name Table Name p. I-31 table alias View Name p. I-31 Synonym Name p. I-31 GROUP BY Clause GROUP BY Table Name p. I-31 table alias View Name p. I-31 Synonym Name p. I-31 + Relational Operator p. I-42 column name Table Name p. I-31 table alias View Name p. I-31 Synonym Name p. I-31
. . . .
. . . .
,
column name
. . . .
select number
ORDER BY Clause ORDER BY Table Name p. I-31 table alias View Name p. I-31 Synonym Name p. I-31
,
column name
. . . .
ASC DESC
select number display label rowid INTO TEMP Clause INTO TEMP temp table name WITH NO LOG SET CONNECTION + +
I-24
+ SET EXPLAIN OFF ON + SET ISOLATION TO DIRTY READ COMMITTED READ CURSOR STABILITY REPEATABLE READ + SET LOCK MODE TO WAIT seconds NOT WAIT + SET BUFFERED SE + START DATABASE Database Name p. I-31 WITH LOG IN "pathname " MODE ANSI LOG
+ UNLOAD TO
"
+ UNLOCK TABLE Table Name p. I-31 Synonym Name p. I-31 Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31 Referenced Values Record Reference p. I-42
UPDATE
SET
CURRENT OF
.*
member
member THRU
member
I-26
,
SQL Expression (Subset) p. I-35 SELECT Statement (Subset) p. I-20 Record Reference p. I-42
. ,
member
, (
column name
*
Table Name p. I-31 View Name p. I-31 Synonym Name p. I-31
.* .* .*
SELECT Statement (Subset) p. I-20 Referenced Values p. I-26 Referenced Values p. I-26
WHENEVER
NOT FOUND
CONTINUE
: label
label
I-28
Comparison Condition
,
+ SQL Expression p. I-35 NOT Column Expression p. I-35 IN
IS NOT
NULL
ESCAPE "character"
EXISTS Subquery EXISTS ( NOT ALL/ANY/SOME Subquery SQL Expression p. I-35 Relational Operator p. I-42 SELECT (Subset) p. I-20
(
ALL ANY SOME
I-30
Cursor Name Identier p. I-38 Constraint Name Index Name Synonym Name Table Name View Name Identier p. I-38
' owner.'
database @dbservername
For SE engines, database identiers can have up to ten characters in UNIX. When the identier for a database is also the name of a 4GL variable, the compiler uses the variable. To override this compiler action, quote the database identier.
SQL Data Type Character Data Type p. I-32 Number Data Type p. I-33 Time Data Type p. I-33 Large Object Data Type p. I-34 Character Data Type CHAR CHARACTER
size
(1)
+ VARCHAR
maximum
) , reserve ,0
I-32
(1) (start)
SMALLINT FLOAT DOUBLE PRECISION + SMALLFLOAT REAL DECIMAL DEC NUMERIC + MONEY
( oat precision )
precision 16
) , scale
precision 16
) ,2 , scale
DATETIME
INTERVAL
Large Object Data Type + TEXT BYTE IN TABLE blobspace DATETIME Field Qualier YEAR MONTH DAY HOUR MINUTE SECOND FRACTION TO YEAR TO MONTH TO DAY TO HOUR TO MINUTE TO SECOND TO FRACTION
(3) ( digit )
I-34
+ * /
SQL Expression Column Expression p. I-35 Constant Expression p. I-36 Function Expression p. I-37 Aggregate Expression p. I-38 Variable p. I-13
SQL Expression
Table Name p. I-31 table alias View Name p. I-31 Synonym Name p. I-31
.
+
[first, last ]
ROWID
. .
Constant Expression Quoted String p. I-41 USER Literal Number p. I-41 TODAY CURRENT DATETIME Field Qualier p. I-34 Literal DATETIME p. I-39 Literal INTERVAL p. I-39 SITENAME Algebraic Functions ROUND
TRUNC
I-36
( (
) ) , ,
DATETIME Field Qualier p. I-34 year integer expression
MDY
( (
) )
LENGTH
Quoted String p. I-41 variable name column name Table Name p. I-31
HEX
(
DISTINCT UNIQUE Table Name p. I-31
column name
DISTINCT UNIQUE
(
ALL
I-38
(y-precision) (4)
MONTH
TO YEAR
(precision) (2)
DAY
TO MONTH
(precision) (2)
HOUR
TO DAY
(precision) (2)
MINUTE
TO HOUR
(precision) (2)
SECOND
TO MINUTE
(precision) (2)
FRACTION
TO SECOND
TO FRACTION
(f-precision) (3 )
Literal DATETIME DATETIME
Numeric Datetime
Numeric Interval
mo
dd space hh
:
mi
:
ss
.
f Numeric Interval yyyy
mo dd space hh
:
mi
:
ss
.
f
I-40
Literal Number
+ -
digit
. .
e digit E
+
digit
,
integer expression
"
character
"
"" '
character
'
' '
,
3 Relational Operator array
integer expression
I-42
Appendix
Notices
IBM may not offer the products, services, or features discussed in this document in all countries. Consult your local IBM representative for information on the products and services currently available in your area. Any reference to an IBM product, program, or service is not intended to state or imply that only that IBM product, program, or service may be used. Any functionally equivalent product, program, or service that does not infringe any IBM intellectual property right may be used instead. However, it is the users responsibility to evaluate and verify the operation of any non-IBM product, program, or service. IBM may have patents or pending patent applications covering subject matter described in this document. The furnishing of this document does not give you any license to these patents. You can send license inquiries, in writing, to: IBM Director of Licensing IBM Corporation North Castle Drive Armonk, NY 10504-1785 U.S.A. For license inquiries regarding double-byte (DBCS) information, contact the IBM Intellectual Property Department in your country or send inquiries, in writing, to: IBM World Trade Asia Corporation Licensing 2-31 Roppongi 3-chome, Minato-ku Tokyo 106-0032, Japan
The following paragraph does not apply to the United Kingdom or any other country where such provisions are inconsistent with local law:
INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS PUBLICATION AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or
implied warranties in certain transactions, therefore, this statement may not apply to you. This information could include technical inaccuracies or typographical errors. Changes are periodically made to the information herein; these changes will be incorporated in new editions of the publication. IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this publication at any time without notice. Any references in this information to non-IBM Web sites are provided for convenience only and do not in any manner serve as an endorsement of those Web sites. The materials at those Web sites are not part of the materials for this IBM product and use of those Web sites is at your own risk. IBM may use or distribute any of the information you supply in any way it believes appropriate without incurring any obligation to you. Licensees of this program who wish to have information about it for the purpose of enabling: (i) the exchange of information between independently created programs and other programs (including this one) and (ii) the mutual use of the information which has been exchanged, should contact: IBM Corporation J74/G4 555 Bailey Ave P.O. Box 49023 San Jose, CA 95161-9023 U.S.A. Such information may be available, subject to appropriate terms and conditions, including in some cases, payment of a fee. The licensed program described in this information and all licensed material available for it are provided by IBM under terms of the IBM Customer Agreement, IBM International Program License Agreement, or any equivalent agreement between us.
J-2 IBM Informix 4GL Reference Manual
Trademarks
Information concerning non-IBM products was obtained from the suppliers of those products, their published announcements or other publicly available sources. IBM has not tested those products and cannot conrm the accuracy of performance, compatibility or any other claims related to non-IBM products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of those products. This information contains examples of data and reports used in daily business operations. To illustrate them as completely as possible, the examples include the names of individuals, companies, brands, and products. All of these names are ctitious and any similarity to the names and addresses used by an actual business enterprise is entirely coincidental. If you are viewing this information softcopy, the photographs and color illustrations may not appear.
Trademarks
AIX; DB2; DB2 Universal Database; Distributed Relational Database Architecture; NUMA-Q; OS/2, OS/390, and OS/400; IBM Informix; C-ISAM; Foundation.2000TM; IBM Informix 4GL; IBM Informix DataBlade Module; Client SDKTM; CloudscapeTM; CloudsyncTM; IBM Informix Connect; IBM Informix Driver for JDBC; Dynamic ConnectTM; IBM Informix Dynamic Scalable ArchitectureTM (DSA); IBM Informix Dynamic ServerTM; IBM Informix Enterprise Gateway Manager (Enterprise Gateway Manager); IBM Informix Extended Parallel ServerTM; i.Financial ServicesTM; J/FoundationTM; MaxConnectTM; Object TranslatorTM; Red Brick Decision ServerTM; IBM Informix SE; IBM Informix SQL; InformiXMLTM; RedBack; SystemBuilderTM; U2TM; UniData; UniVerse; wintegrate are trademarks or registered trademarks of International Business Machines Corporation. Java and all Java-based trademarks and logos are trademarks or registered trademarks of Sun Microsystems, Inc. in the United States and other countries. Windows, Windows NT, and Excel are either registered trademarks or trademarks of Microsoft Corporation in the United States and/or other countries.
Notices
J-3
Trademarks
UNIX is a registered trademark in the United States and other countries licensed exclusively through X/Open Company Limited. Other company, product, and service names used in this publication may be trademarks or service marks of others.
Glossary
Glossary
4GL function
A 4GL program block dened with the FUNCTION statement. The function header follows the FUNCTION keyword and denes the name and formal argument list for the function. The function body (all statements between the function header and the END FUNCTION keywords) denes the actions of the function. The function header and the function body together are often called the function denition. To return values, use the RETURN statement within the function body. Frequently, a 4GL function is simply referred to as a function. See also argument, function, programmer-dened function, program block, return value. 1) In the INFORMIX-4GL Interactive Debugger, the 4GL screen is where the Debugger displays the 4GL application. 2) When running a 4GL application, the 4GL screen is the display area of the screen. This area displays the application forms, 4GL windows, and text. See also 4GL window, screen.
4GL screen
4GL window
A rectangular region in the 4GL screen, possibly one of many, managed by a 4GL application. The default 4GL window is the 4GL screen. The OPEN WINDOW statement creates a new 4GL window. 4GL manages its windows with a stack. Each window is pushed onto this stack when it is opened. A 4GL program performs its input and output in the current window. See also 4GL screen, current, popup window, reserved lines, screen, stack.
abnormal termination
The termination of the 4GL application through any mechanism other than terminating the MAIN program block at the END MAIN keywords or with a RETURN statement. Whenever a runtime error occurs, or the user presses an Interrupt or Quit key, or the EXIT PROGRAM statement is executed, an abnormal termination occurs. In the INFORMIX-4GL Interactive Debugger, you can inspect the application state after an abnormal termination. You cannot, however, resume execution. See also debug, exception handling, MAIN program block, normal termination, program execution. The logical key that the user can press within a 4GL application to indicate acceptance of the entered data or query criteria. Pressing it requests normal completion of a user interaction statement. By default, the physical key for Accept is ESCAPE. See also data entry, Interrupt key, logical key, query criteria, Quit key, user interaction statement. The status of an open le that determines read and write access to that le. A logical key that the developer denes to provide the user with some programmer-dened feature. The developer can dene an activation key in the ON KEY clause of the CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, or PROMPT statement, or in the KEY clause of the MENU statement. When the user presses the activation key, 4GL executes the control block associated with that key. See also control block, key, logical key, menu option. A screen form for which the current user interaction statement is executing. An application can have several active forms if it has several 4GL windows, each continuing a screen form with a user interaction statement executing. With multiple active forms, only one form is current. See also 4GL window, current, screen form, user interaction statement. A 4GL program block (MAIN, FUNCTION, or REPORT) that has started execution but not completed execution. The active functions consist of all functions on the call stack, which are the current function and all functions that are waiting for a function call to return. The MAIN block is always active for the 4GL session. The INFORMIX-4GL Interactive Debugger can inspect the active functions that are not reports. See also active variable, abnormal termination, call stack, debug, normal termination, program block, program execution. The collection of database rows that satises a query associated with a database cursor. An active set is stored in memory at runtime. It contains only a copy of the rows that match the query criteria. See also cursor, query, row.
Accept key
active form
active function
active set
active variable
A 4GL variable for which storage exists. The active variables consist of the local variables of all active functions, the module variables of all modules that contain the active functions, and all global variables. You can evaluate or assign values to active variables within the INFORMIX-4GL Interactive Debugger. See also active function, abnormal termination, global variable, local variable, module variable, normal termination, program execution, scope. The window that contains the current keyboard focus. See also keyboard focus. In a function call, the value that is passed by the calling routine as an argument to the programmer-dened function. This value must be of a compatible data type with the corresponding formal argument in the function denition. There are two methods for an actual argument to be passed to a function: pass-by-reference and pass-by-value. See also argument, calling routine, data type conversion, formal argument, function call, pass-by-reference, passby-value, programmer-dened function. 1) A function built into the SQL language that returns a single value based on the values of a column in several rows of a table. These functions are called SQL aggregate functions. Examples of SQL aggregate functions are SUM( ), COUNT( ), MIN( ), and MAX( ). These functions are valid only within SQL statements. See also column, row, SQL, table. 2) A function built into the 4GL language that returns a single value based on the values of input records. These functions are called report aggregate functions. Examples of report aggregate functions are SUM( ), GROUP SUM( ), PERCENT(*), MIN( ), and MAX( ). Report aggregate functions are valid only within a REPORT program block. See also built-in function, input record, program block, report.
aggregate function
alias
In the database, an alias is a synonym for a table name. It immediately follows the name of the table in an SQL statement. It can be used wherever the name of a table can be used. Aliases are often used to create short, readable names for long or external table names. See also table. A database that conforms to certain ANSI (American National Standards Institute) performance standards. Informix databases can be created either as ANS compliant or as not ANSI compliant. An ANSI-compliant database enforces ANSI requirements such as implicit transactions, required owner-naming, and no buffered logging. The term MODE ANSI is sometimes used to refer to an ANSI-compliant database. See also database, implicit transaction.
ANSI compliant
Glossary 3
Software, such as INFORMIX-SQL, INFORMIX-4GL, and INFORMIX-ESQL/C, which a developer can use to create and maintain a database. Such software allows a user to send instructions and data to and receive information from a database server. See also database server. 1) A computer program developed and implemented for dealing with some business activity. (A computer program is a group of instructions that cause a computer to perform a sequence of operations.) An application program is synthesized from some combination of application development tools. See also application development tool, database, developer, user. 2) In 4GL, an application program is the 4GL program, with one MAIN program block, its supporting 4GL source modules, its form specication les, and its help message le. See also form specication le, help le, MAIN program block, source module.
application program
A rigorous denition of the method by which a program can access the services provided by another program. Developers of an API often provide libraries of callable functions that implement the API. For example, the 4GL API enables a C program to call a 4GL routine; Motif enables a C program to call X Windows; INFORMIX-ESQL/C, which is an SQL API, enables a C program to access a database. There can be many different APIs that provide access to the same set of services, though possibly at different points of entry. In some cases, the same API can be used to access different services. (For example, NetBIOS is a network API that is protocol independent and is often used to access a variety of different protocols such as OSI, AND TCP/.) See also application development tool. A value passed from a calling routine to a function. In the calling routine, the value passed is called an actual argument. Within the function denition, the name of the argument is called a formal argument. When the function is called, the value of the actual argument is assigned to the corresponding formal argument variable. See also actual argument, calling routine, formal argument, pass-by-reference, pass-by-value, programmer-dened function, report. Operators that perform arithmetic operations on operands of number (and some time) data types. The following are 4GL binary arithmetic operators: addition ( + ), subtraction ( - ), multiplication ( * ), division ( / ), exponentiation ( ** ), and modulus (MOD). 4GL unary arithmetic operators are unary minus ( - ) and unary plus ( + ). Arithmetic operators return a numeric value (or else NULL) . See also associativity, binary operator, operand, operator, precedence, unary operator.
argument
arithmetic operators
array
1) A data structure that has a xed number of components. Each component is called an element. All elements in an array have the same data type. See also array element, screen array. 2) In uppercase, ARRAY is the keyword for dening a program array in 4GL. The ARRAY data type is a structured data type of up to three dimensions. It cannot have another array as an element. You can reference an array element by listing the array name followed by one or more comma-separated subscripts within brackets. See also program array, structured data type, subscript.
array element
A component of a program array, of any 4GL data type except ARRAY. To reference any element within an array, use one or more integer subscripts (sometimes called an array index). See also array, program array, subscript. 1) Acronym for American Standards Code for Information Interchange. In the default locale, the ordered set of internal codes that a computer uses to represent characters. This set includes both printable and non-printable characters. Appendix A, The ASCII Character Set, lists the ASCII characters and their codes. See also control character, escape character, printable character. 2) As opposed to binary information, an ASCII le is readable in a text editor. 4GL source modules and form specication les are examples of ASCII les. This manual sometimes uses the term ASCII le in reference to les that contain only printable characters (which might include non-ASCII characters) of the client locale. See also form specication le, source module, text editor.
ASCII
assign
To store a value in a variable. In 4GL, the LET statement performs assignment. 4GL evaluates the expression on the right-hand side of the equal sign ( = ) and assigns it to the variable on the left-hand side. You can also assign values to a variable with the CALL...RETURNING, CONSTRUCT, FOREACH...INTO, INITIALIZE, INPUT, INPUT ARRAY, and PROMPT statements, and with the INTO clause of SELECT and EXECUTE statements of SQL. See also expression, operator, precedence, variable.
associativity
The principle that determines the order in which operands at the same level of precedence in an expression are evaluated. For example, to evaluate the expression a - b + c, 4GL rst evaluates a - b and then adds c to the result because binary arithmetic operators associate to the left. You can use parentheses ( ( ) ) symbols, as in algebra, to override the default associativity of 4GL operators. See also binary operator, expression, precedence.
Glossary 5
asterisk notation
The symbols .* appended to the name of a database table (table.*) or of a 4GL record variable (record.*), which expands to the names of all the columns in the table or of all members in the record. In other contexts, asterisk can be a wildcard for matching strings, or can indicate overow in a display or other features of 4GL. See also program record, table. 1) A characteristic or aspect of some entity that the developer can set. 4GL provides attributes for form elds (eld attributes), screen forms (form attributes), database columns (column attributes), and for output text (display attributes). Set eld attributes on a eld-by-eld basis in the form specication le. Set form attributes with the ATTRIBUTE clause of the DISPLAY FORM statement and of the 4GL user interaction statements. You can also set display attributes with the ATTRIBUTE clause. You can set default column attributes on a column-by-column basis with the upscol utility. See also column, eld, form, form specication le, user interaction statement. 2) In some database terminologies, attribute is a term used for a column. See also column.
attribute
A history of all changes to a table in an INFORMIX-SE database. A method of organizing an index for efcient retrieval of records. All Informix database servers use this access method. In a multiprocessing environment, a process that is not performing input or output. It can continue to run without needing access to a window or the screen. See also foreground process, process, screen. A mode of execution in which a program runs without input from a user. 4GL programs that do not use user interactive statements are batch programs. If a batch program produces output, it should direct the output to a le or the printer, not the screen. Often reports are run in a batch mode. See also interactive, program execution, report, user interaction statement. An operator that requires two operands. The binary operator appears between the two operands. In 4GL, examples of binary operators include addition ( + ), multiplication ( * ), and logical AND. 4GL associates most binary operators from left-to-right. See also arithmetic operators, associativity, Boolean operators, operand, operator, precedence, relational operators, unary operator.
binary operator
binding
A one-to-one correspondence between entities in two domains. The association between an identier and its resource (a location in memory) is called a binding. In 4GL, the correspondence between form elds and program variables during data entry is also called a binding. Several 4GL screen interaction statements include a binding clause that lists the program variables and their corresponding form elds (or database columns). These statements include CONSTRUCT, INPUT, INPUT ARRAY, and PROMPT. See also data entry, identier, program array, program record, screen array, screen record, user interaction statement. The character with the value of ASCII 32. A string of blank spaces is not the same as a null string (which has nothing in it). 4GL pads string values with blank spaces up to the declared size of the CHAR variable (but not VARCHAR variables). Blank spaces are also used to separate elements of a menu or form. More generally, characters in any locale that can separate terms within 4GL statements, but that display as blank spaces, are often referred to as white space characters. See also ASCII, clipped, null value, printable character, string. A legacy acronym for binary large object that is now known as and includes
BYTE and TEXT data types. Blobs are data objects that effectively have no
blank space
blob
maximum size (theoretically as large as 231 bytes). See also byte, data type, text. The unit of disk allocation within a blobspace in the database. The System Administrator determines the size of a blobpage; the size can vary. A logical collection of blobpages to store TEXT and BYTE data in the database.
4GL includes two Boolean constants: FALSE (= 0) and TRUE (=1). If an operand evaluates to null, Boolean operators can return an unknown result that 4GL treats as FALSE in some contexts. Because 4GL does not have a Boolean data
type, Boolean values are typically stored as integer data types. See also Boolean operators, constant, integer, relational operators. Boolean operator An operator (for example, AND, OR, NOT, or any of the relational operators) that returns a Boolean value. In some contexts, 4GL interprets null values as FALSE and any nonzero value as TRUE. Boolean expressions can also include relational operators. See also associativity, binary operator, Boolean, operand, operator, precedence, relational operators, unary operator.
Glossary 7
built-in function
A function that is part of the 4GL language and can therefore be called without needing to be dened by the developer. Calls to built-in functions have the same syntax as those for programmer-dened functions. Examples of built-in functions are ARG_VAL( ), ARR_CURR( ), FGL_KEYVAL( ), and SCR_LINE( ). See also 4GL function, aggregate function, built-in operator, calling routine, function call, programmer-dened function. An operator that is part of the 4GL language. Built-in operators are keywords or symbols that perform special tasks. They differ from built-in functions in that they cannot be invoked with the CALL statement and they cannot be called from a C function. Examples of built-in operators are ASCII, CURRENT, DATE, and TODAY. (Here built-in is redundant; the programmer cannot dene new 4GL operators.) See also built-in function, keyword, operator. 1) A unit of storage that corresponds to 8 binary bits. A kilobyte is 1,024 bytes. A megabyte is 1,048,576 bytes. See also character. 2) In uppercase letters, BYTE is the 4GL and SQL data type that can store up to 231 bytes of binary data. See also blob.
built-in operator
byte
C Compiler
The version of 4GL that precompiles 4GL code into Informix ESQL/C code and then translates the ESQL/C into object code that is executable directly from the command line. See also compile, Rapid Development System. A stack (also called the function stack) used by 4GL at runtime to keep track of active functions. An active function is one that has been called but that has not yet returned. Each time the program calls a function, the state of the function is pushed onto the call stack. When a function terminates, the state is popped off the call stack. The MAIN program block is always at the bottom of this stack. You can examine the call stack with the INFORMIX-4GL Interactive Debugger. See also active function, MAIN program block, stack. See pass-by-reference. See pass-by-value. The program block that invokes a function (or report). In 4GL, the calling routine can be either a MAIN, FUNCTION, or REPORT program block. A call can be explicit, by using the CALL statement, or implicit, by embedding the function name (and any arguments) within an expression. The calling routine can pass values to the function and can receive returned values. See also argument, expression, function call, program block, return value.
call stack
case sensitivity
The ability to distinguish between uppercase and lowercase letters. 4GL is not case sensitive, except within quoted strings; thus, variables a and A refer to the same address in memory. Certain command-line syntax elements (such as command names and options) are case sensitive. Unless the locale les dene the correspondence between uppercase and lowercase characters, case sensitivity is not supported. See also identier, keyword, naming conventions. 1) Any letter, digit, symbol, or control sequence that can be represented by the character set of the client locale. In some East Asian locales, one logical character can require more than one byte of storage. See also ASCII, blank space, control character, escape character, printable character. 2) The character data types are CHAR and VARCHAR (and in some contexts, a TEXT variable). See also blob, data type, string, string operators, subscript. 3) What a single keystroke, control character, or escape sequence produces that the program, operating system, or output device treats as a single unit. See also activation key, logical key, operating system.
character
character set
In the default locale, the ASCII characters, each corresponding to an integer value from 0 to 255 (8-bit) or 0 to 127 (7-bit). In other locales, the character set is specied by a code set in the locale les. In some East Asian locales, a single logical character can require more than one byte of storage, and the number of logical characters in the code set can be a 4-digit number. Every locale must support the ASCII characters. See also ASCII, Global Language Support. The CLIPPED operator of 4GL removes trailing white space from string values. It is often used in DISPLAY and PRINT statements. (SQL statements use TRIM.) See also blank space, built-in operator, string operators. To cease to use an open entity. In programming, closing something releases control of it and deallocates any resources that it used. For example, when you close a database cursor, you release any memory or disk space that was used to hold the active set for that cursor. When you close a le, you tell the system that you no longer require the le and others can use it. When you close a form, you release any memory or disk used to store it. When you close a 4GL window, you deallocate memory for the image of the window and pop it from the window stack. Typically things cannot be closed until they have been opened. See also 4GL window, close, cursor, le, open, screen form. To drop the association between the active set of rows that result from a query and a cursor.
clipped
close
close a cursor
Glossary 9
column
1) In a database, a column is a data category that contains a specic type of information common to every row of the table. In other database terminologies, a column is sometimes called a eld or an attribute. See also attribute, database, row, table. 2) In a screen or in page of output from a report, a column is the x-coordinate of a given position (on the horizontal axis). The y-coordinate (on the vertical axis) is called a row (or a line). Several 4GL statements use columns (and rows or lines) in this sense to identify locations in displays. See also row, screen.
command line
A line of text typed by the user at the operating system prompt to run a program. In a character-based environment, all programs are invoked by a command line with optional command-line arguments and options. See also operating system. Text in a source le that the compiler ignores. These comments can explain the contents of the le or disable a statement. In 4GL source modules, comments can be introduced by a left brace ( { ) in the rst position of the line and terminated by a right brace ( } ) anywhere on a line to close the comment. Comments in the same line as code can begin with a double-hyphen ( -- ) or pound ( # ) sign. In 4GL form specications, left braces or the double-hyphen can begin comments; the # symbol is not valid. Conditional comments have comment indicators that Dynamic 4GL (for --#) or INFORMIX-4GL (for --@) interpret as white space. See also form specication le, header, source module. To successfully end a transaction by accepting all changes to the database since the beginning of the transaction. When the transaction is committed, all open database cursors (except hold cursors) are closed and all locks are released. The COMMIT WORK statement commits the current transaction. See also cursor, log, roll back, transaction. 1) To translate a program from source code written by the developer to a form executable by the computer (machine code). This translation is done by a system program called a compiler. Results of the translation are called object code, or a compilation. See also debug, execute, interpret, link, source module. 2) In 4GL, you can compile 4GL source code into either p-code or C language code. For the p-code, the compiler translates the 4GL code into an intermediate form (p-code) that must be executed by the P-Code Runner. For C code, the compiler rst calls a preprocessor to translate 4GL code into INFORMIX-ESQL/C code. It then translates the ESQL/C into object code, executable directly from a command line. See also C Compiler, command line, compiler directive, p-code, preprocessor, Rapid Development System.
comment
commit
compile
10
compiler directive
An instruction within a source module to a compiler, as opposed to an executable statement. In the C language, directives can address the preprocessor portion of the compilation, requesting, for example, conditional compilation or inclusion of a named le. In 4GL, the WHENEVER and DEFER statements are compiler directive. The effect of WHENEVER lasts until the end of the source le (or until overridden by another WHENEVER). See also compile, exception handling, preprocessor, source module, statement. An index constructed on two or more columns of a table. The ordering imposed by the composite index varies least frequently on the rst named column and most frequently on the last named column. A join between two tables based on the relationship among two or more columns in each table. To form a character string by appending a second character string to the end of the rst character string. In 4GL and SQL, the concatenation operator is a double pipe ( || ) symbol. See also character, string, string operators. The process of verifying that the character set, collation order, and other client settings for a user session match the settings in the database locale. A named value that, unlike a variable, cannot change during execution of a program. Constants of 4GL include NOTFOUND, FALSE, and TRUE. These values cannot be redened by the developer. The documentation of Informix database servers sometimes applies this term to literals. See also Boolean, literal, variable. See UNIQUE CONSTRAINT. A statement block that executes when a certain condition (the activation clause) becomes true. In 4GL, control blocks like BEFORE FIELD, AFTER INPUT, AFTER CONSTRUCT, and ON KEY occur in the user interaction statements; in this context, they are often called form management blocks. Control blocks also occur in the FORMAT section of a report, including PAGE HEADER, AFTER GROUP OF, and ON EVERY ROW. See also activation key, report, statement block, user interaction statements.
composite index
Glossary 11
control character
A character whose occurrence in a specic context initiates, modies, or stops a control function (an operation to control a device, for example, in moving a cursor or in reading data). Control characters have values below ASCII 32 in the ASCII character set. In a 4GL program, some control characters have predened functions (pressing CONTROL-W obtains on-line help). The developer can also dene actions that use CONTROL keys with another key to execute some programming action. See also activation key, ASCII, character, logical key, modier key. The one item, among many similar items, that is about to be or was most recently used. The current directory is the host system directory that was selected most recently (it is where les are rst looked for). The current row is the row that was last fetched through a database cursor (it can be deleted or updated using the cursor). The current window is the window most recently activated (it receives the users keystrokes). The current statement is the program statement being executed. (This statement is displayed in an error message if the program terminates.) See also cursor, directory, row, statement. 1) A focal point at which action can be applied. A text cursor is a mark showing the focal point for keyboard input. See also keyboard focus, text cursor. 2) A database cursor is an identier associated with an active set. It points to the current row in the active set. This row can be fetched, deleted, or updated. 4GL supports the following types of database cursors: sequential, scroll, hold, update, and insert. See also active set, close, current, identier, open, prepared statement, query, row, scrolling.
current
cursor
See data type conversion. 1) The action of providing, usually at the keyboard, data values to a computer program. Data entry is performed by the user of an application at runtime. In a database application, these values are usually stored in a database. See also application program, key, user interaction statements. 2) A set of data values to be stored in program variables and, often, in a database table. The INPUT, INPUT ARRAY, and PROMPT statements accept data entry. See also query criteria, table, user interaction statement.
data le
A le that contains the input used by a program. Data les are not executable; they contain data that is to be read or acted on by other programs. See also le.
12
data type
An interpretation to use on a stored value. In 4GL, database columns, program variables, form elds, and formal arguments of a function (or report) all have data types associated with them. The 4GL data types include: integer (SMALLINT, INTEGER); xed-point (DECIMAL(p,s), MONEY); oating-point (DECIMAL(p), FLOAT, SMALLFLOAT); character (CHAR, VARCHAR); large (BYTE, TEXT); time (DATE, DATETIME, INTERVAL); and structured (ARRAY, RECORD). Informix databases can support additional data types. See also blob, character, data type conversion, declare, xed-point number, oating-point number, integer, interval, operator, simple data type, structured data type, variable. The process of interpreting and storing a value of one data type as some other data type; sometimes called simply data conversion. The pairs of data types for which data conversion is possible without error are called compatible data types. This process can be automatic or explicit. 4GL performs some automatic data conversion in expressions and assignment. It also provides facilities to perform some explicit data conversion (for example the EXTEND( ) function). In addition, the LIKE keyword, when used in a variable denition, provides indirect data typing. See also column, data type, dene, indirect typing. A collection of related data organized in a way to optimize access to this data. A relational database organizes data into tables, rows, and columns. Informix databases are relational databases. At runtime, a separate database server process is the portion of the database management system that actually manipulates the data in the database les. To access a database, a 4GL application must specify it with the DATABASE statement and must use SQL statements. See also column, database server, process, row, SQL, system catalog, table. See cursor. Locale of the user at the time of database creation, permanently saved in database system tables and consulted when the database is accessed. See also Global Language Support, user locale. The part of a database management system that manipulates data les. This process receives SQL statements from the database application, parses them, optimizes the approach to the data, retrieves the data from the database, and returns the data to the application. The database server is also called the back end. See also application development tool, database, process.
database
database server
Glossary 13
debug
1) To nd and remove runtime errors in a computer program. This analysis is often done by special software products called debuggers. You can analyze a program to detect and locate errors in its logic, change the source code appropriately, and then compile and run the program again. See also compile, execute, link. 2) If you are using the Rapid Development System, you can use the INFORMIX-4GL Interactive Debugger to debug 4GL programs. The Debugger helps you to control and monitor program execution and inspect the application state. The Debugger is purchased separately from 4GL. See also program execution, Rapid Development System.
debugger
A software product to analyze programs and to detect and locate errors in program logic. The INFORMIX-4GL Interactive Debugger is a 4GL source language debugger that supports a wide variety of programming tools, such as tracing program logic and stopping execution at preset points. See breakpoint and tracepoint. To make the name and data type of a variable known to a compiler. In 4GL, the DEFINE statement declares variables so the 4GL compiler can verify references to the variables in the succeeding code. The GLOBALS statement declares global variables. See also compile, data type, dene, global variable, variable. The value that will be used, or the action that will be taken, unless you specify otherwise. In many SQL and 4GL statements, there is a default action that will be used if you do not specify another; for example, the FETCH statement retrieves the NEXT row unless you specify a different keyword such as PRIOR. Screen forms can specify a default value for input from each eld, in case the user fails to enter one. See also screen form, variable. To allocate memory for storage of a variable. At runtime, the DEFINE statement indicates how much storage should be allocated for a variable. The GLOBALS statement denes global variables. To dene a function (or report) is to specify the actions performed by the function. See also data type, declare, execute, function, global variable, report, variable. The logical key that the user can press within a 4GL application to delete the current line of a screen array (the current screen record) during the INPUT ARRAY statement. 4GL automatically deletes the associated line of the program array. By default, the physical key for Delete is F2. See also Insert key, logical key, program array, screen array, screen record.
declare
default
dene
Delete key
14
delimiter
A character that separates one unit of text from another. The eye can easily see boundaries based on context, but programs need unambiguous marker characters to detect the end of one item and the start of the next. In data produced by the UNLOAD statement, the data from each column ends with a delimiter ( | by default) so that the LOAD command can recognize the end. In the form specication le, brackets ( [ ] ) mark or delimit the elds of the form. See also form specication le. An individual who develops computer programs, taking them from design, coding, and debugging to general release. 4GL provides the developer with a means of developing database applications. Also referred to as the programmer. See also application program, user. The special set of tools that a developer can use to develop computer programs. This environment might include text editors, language compilers, function libraries, program linkers, program debuggers, and other program utilities. Some of these tools might be accessed by wrapper programs, which decide which tools need to be run. The Programmers Environment is an integrated development environment that combines many of these tools into a single, cooperative environment. See also compile, debug, execute, link, Programmers Environment, text editor. A directory is a le folder; it contains other les. Directories can also contain other directories; directory structures are used to organize related les into categories. The user can construct a hierarchy of subdirectories and les that resembles an inverted tree in structure. Each user has a home directory that represents the top level of the users personal hierarchy of other directories and les. The current directory is a single directory (selectable by the user) that enables the user to be in one directory at a time and to refer to its les unambiguously. To refer to les in other directories, the user must supply a path, that is, a list of the subdirectories that describe the location of those les. See also current, le, operating system. A level of process isolation that does not account for locks and does allow viewing of any existing rows, even rows that might be currently altered from inside an uncommitted transaction. DIRTY READ is the lowest level of isolation (no isolation at all). It is the level at which INFORMIX-SE operates, and it is an optional level under Informix Dynamic Server. See process isolation. Field used in a screen form to indicate where data is to be displayed on the screen. A display eld is usually associated with a column in a table. See array element.
Glossary 15
developer
development environment
directory
DIRTY READ
environment variable
A special variable with a value that is maintained by the operating system and made available to all programs. Environment variables are usually stored in a special system area and contain system specics such as the path (the directories in which the operating system looks for user-invoked commands). See also operating system, shell. An exception that indicates failure of a requested action or an illegal specication. Errors can occur during compilationduring preprocessing of program statements or during the linking stageor during execution of the program. At runtime, some errors are fatal in that the program cannot continue execution (runtime errors); others are recoverable in that the program can take corrective action and continue execution. Rounding errors can occur during truncation in rounding; overow errors can occur during arithmetic operations in which the size of the result is larger than the size of the space in which the result is to be stored. See also compile, error handling, exception, execute, link, status variable, truncation. Program code that checks for a runtime error. By default, 4GL terminates a program when it encounters a runtime error. The 4GL WHENEVER ERROR statement can change this default error-handling behavior. With the WHENEVER ERROR CONTINUE statement, 4GL sets the built-in status variable to a negative value and continues execution when it encounters a runtime error. The program must explicitly check the value of status and determine appropriate action. See also error, error log, error text, exception handling, program execution, status variable. A le that receives error information for a program at runtime. 4GL contains some built-in functions that allow you to make entries in the error log: ERR_GET( ), ERR_PRINT( ), ERR_QUIT( ), ERRORLOG( ), and STARTLOG( ). See also built-in function, error, error handling, status variable. Text that describes a 4GL error. Each error is identied by an integer, usually negative, called an error code. Each code corresponds to a specic error message. Such messages can be retrieved by running the nderr utility or within a program by making a call to the ERR_GET( ), ERR_PRINT( ), or ERR_QUIT( ) built-in functions. By default, 4GL automatically displays some runtime error messages on the screen. See also error handling, error log, status variable. Code within a program that anticipates and reacts to runtime errors.
error
error handling
error log
error message
error trapping
16
escape character
A character that indicates that the following character, normally interpreted by a program, is to be printed as a literal character instead. Usually programs that handle user input (such as text editors and shells) have some characters that have special interpreted meanings. The escape character is used with the interpreted character to escape or ignore the interpreted meaning. The ASCII escape character is a nonprinting character with value of ASCII 27. In 4GL, the backlash ( \ ) can be used as an escape character: the string "\\" would indicate that the backslash character is to be sent. See also ASCII, character, printable character, shell, text editor. The physical key usually marked ESC on the keyboard. It sends the ASCII code for the escape character. This key is the default Accept key in user interaction statements like CONSTRUCT, DISPLAY ARRAY, INPUT, or INPUT ARRAY. See also Accept key, escape character, key, user interaction statement. A runtime event for which the program might want to take some action. Exceptions in 4GL include: runtime errors (an error returned by a database server, a state initiated by a stored procedure statement, or an error detected by the application program), a database query that returns no rows (status variable is set to NOTFOUND), warnings (SQL conditions), and the pressing of the Interrupt or Quit key by the user. See also error, exception handling, Interrupt key, Quit key, status variable, warning. Program code that checks for exceptions and performs recovery actions in the event they occur. By default, 4GL performs the following exception handling: runtime errorsterminate the program; SQL NOTFOUNDset status to NOTFOUND and continue execution; warningscontinue execution; and Interrupt (or Quit) keyterminate program. The developer can change the default exception handling for these rst three types of exceptions with the WHENEVER statement: runtime errors (WHENEVER ERROR, WHENEVER ANY ERROR); NOTFOUND (WHENEVER NOT FOUND); and warnings (WHENEVER WARNING). The DEFER statement changes handling of the Interrupt and Quit keys. See also error handling, Interrupt key, program execution, Quit key, status, warning.
Escape key
exception
exception handling
Glossary 17
executable le
1) A le that contains machine code (in binary form) that has been linked and is ready to be run on a computer. Can also refer to a collection of instructions that can be executed by a command interpreter or processor, for example a batch le. See also compile, execute, le, interpret, link. 2) In 4GL, an executable le can be either interpretive p-code (with a .4gi or .4go extension) or compiled C code (with an .exe extension), depending on the version of 4GL that you are using. See also command line, p-code.
executable statement
A statement that requires processing action at runtime. Executable statements are distinguished from declarative statements (that provide information about the nature of the data without themselves causing any processing) and compiler directives that are instructions to the compiler. All 4GL statements are executable except MAIN, DEFINE, DEFER, FUNCTION, GLOBALS, REPORT, and WHENEVER. See also compiler directive, declare, dene, statement. 1) To run a compiled or interpreted program by carrying out the instructions in an executable le. To execute or run a program, the operating system must create a process for the program and then allocate the CPU (and any other resources needed by the program) to this process. The state of the program in execution is often called runtime. See also compile, debug, executable le, interpret, link, operating system, process, resources. 2) A 4GL executable le contains either interpreted p-code or compiled C code, depending on the version of 4GL that you are using. See also C Compiler, command line, Rapid Development System.
execute
See call stack. An additional page lled with data from a single row. Informix Dynamic Server uses expansion pages when the data for a row cannot t in the initial page. Expansion pages are added and lled as needed. The original page entry contains pointers to the expansion pages. A transaction that the developer must explicitly begin and end. The BEGIN WORK statement indicates the beginning of the transaction. The developer must explicitly indicate the end of the transaction with the COMMIT WORK and ROLLBACK WORK statement. A database that is not ANSI compliant but that has a transaction log uses explicit transactions. See also ANSI compliant, commit, roll back, transaction.
explicit transaction
18
exponent
1) In the representation of a FLOAT or SMALLFLOAT value, a signed integer that indicates the power to which the mantissa is to be raised. See also oating-point number, mantissa. 2) The right-hand unsigned integer operand of the exponentiation ( ** ) operator in 4GL expressions. See also arithmetic operators.
expression
A sequence of operators, operands, and parentheses that can be evaluated to a single value, usually at runtime. In 4GL, an expression should evaluate to a simple 4GL data type: number (Boolean, integer, oating-point, and xedpoint), character, or time (DATE, DATETIME, and INTERVAL). See also Boolean, character, data type, xed-point, oating-point, integer, interval, operand, operator, precedence, regular expression. A continuous segment of disk space allocated to a tblspace in the database. The programmer can specify both the initial extent size for a table and the size of all subsequent extents assigned to the table. The notication of an operating system event that is delivered to a process. 4GL programs can handle two external signals: Interrupt and Quit. See also Interrupt key, operating system, process, Quit key. 1) An area for holding a data value. Usually refers to a delimited, unprotected area on a screen form used for entry and display of a data value. Such elds can have eld attributes associated with them that control, for example, the case of letters, default values, and so on. When a form is active, the location of the cursor designates what is called the current eld, the eld in which the user can enter data. A eld on a screen form corresponds to a column in a database, unless it has been dened as a form-only eld. See also attribute, current, form, form specication le, form-only eld, multiple-segment eld, screen array, screen form. 2) In some database terminologies, a column. See also column. A portion of computer memory associated with and holding the current contents of a screen eld. In 4GL, the GET_FLDBUF( ) built-in function allows the developer to examine the eld buffer. See also built-in function, eld. A unique name that identies a eld in the SCREEN section of a form specication le. It is also used in the ATTRIBUTES section to assign a set of eld attributes to the eld. Unlike a label, a eld tag does not appear when the form is displayed. See also attribute, eld, form specication le, label.
extent
external signal
eld
eld buffer
eld tag
Glossary 19
le
1) A named collection of information stored together, usually on disk. A le can contain the words in a letter or report, a computer program, or a listing of data. Files are usually stored in directories and are managed by the operating system. See also data le, directory, executable le, form specication le, help le, log, operating system, output le, source module. 2) In some database terminologies, the term used for a table. See also table. The part of the lename following the period ( . ). It usually identies the purpose of the le. For example, form specication les have a .per extension while compiled form les have a .frm extension. 4GL source modules have a .4gl extension. INFORMIX-ESQL/C les have a .ec extension. See also executable le, le, form specication le, help le, source le. Specic ASCII characters that are used to provide formatting instructions in a format string. In 4GL reports, the ampersand ( & ) instructs the PRINT statement to insert leading zeros when a number does not completely ll the format string. Fill characters are used in reports and forms. See also ASCII, character, form specication le, format string, report. A real number with a xed scale. In 4GL, the xed-point number data types are DECIMAL(p,s) and MONEY. These data types store values that include a fractional part as xed-point numbers. See also data type, oating-point number, scale, simple data type. 1) A value used to indicate or ag some condition. You can dene a program variable as a ag (usually assigning it the values TRUE and FALSE). See also Boolean, variable. 2) A command-line option to an operating system program is sometimes called a ag as well. See also command line, operating system.
lename extension
ll character
xed-point number
ag
oating-point number
A real number with a xed precision and undened scale. The decimal point oats as needed to represent an assigned value. In 4GL, the oating-point number data types are FLOAT, SMALLFLOAT, and DECIMAL(p). See also data type, exponent, xed-point number, mantissa, precision, scale, simple data type. An option that forces UNIX to keep Informix Dynamic Server shared memory segments always resident in memory, preventing UNIX from swapping out these segments to disk on a busy system. (This option is not available in all UNIX systems.) A process that currently has access to a window or the screen. It requires this access because it needs to perform input or output. See also background process, process, screen.
forced residency
foreground process
20
See screen form. A eld on a screen form. See eld. An ASCII source le that describes the logical format of the screen form and provides instructions about how to display data values in the form at runtime. You dene a screen form in its source le (with a .per extension) and create a compiled version (with a .frm extension) for use at runtime. form4gl creates the compiled version. Sometimes this le is referred to as simply the form specication. See also eld, eld tag, le, screen array, screen form. A eld on a screen form that is not associated with any database column. Usually, a form-only eld is used for display purposes only. See also column, eld, form specication le, screen form. In a function denition, the variable in the argument list that serves as a placeholder for an actual argument. The argument list determines the number and data types of the functions arguments. In the function call, the actual argument sends the value to the function. See also actual argument, calling routine, formal argument, function call. A quoted string whose characters specify how to display data values. The USING operator, the FORMAT and PICTURE eld attributes, and certain environment variables can use format strings. See also attribute, environment variable, ll character, quoted string, string. An output mode of a 4GL program in which screen addressing is used. 4GL enters this mode when it executes any 4GL user interaction or output statement (ERROR, MESSAGE, DISPLAY AT, and so on) except a simple DISPLAY statement (one without an AT, BY NAME, or TO clause). Output in formatted mode displays in the 4GL screen. It should not be mixed with line mode. See also line mode.
form-only eld
formal argument
format string
formatted mode
Glossary 21
fourthgeneration language
A programming language, approximating a natural language, designed and developed for a given class of applications. Because they focus on a specic type of application, such languages can anticipate the actions programs need to perform. As a result, many typical operations can be encapsulated into a generalized but powerful statement. Sometimes abbreviated as 4GL.
4GL is a fourth-generation language for the creation of database applications. It includes the ability to embed SQL statements in a program as well as pro-
viding additional statements, operators, and functions to assist in the creation of database applications. See also application program, built-in function, built-in operator, database, operator, SQL, statement. function 1) A named collection of statements dened to perform an application task, often one that needs to be repeated. Functions can be dened to accept arguments and to return values. See also argument, built-in function, programmerdened function, return value, SQL, statement. 2) A 4GL function (a program block dened with the FUNCTION statement) is often referred to simply as a function. See also 4GL function. function call The invocation, by a calling routine, of a programmer-dened or built-in function. This syntax includes the function name followed by the actual argument values, in parentheses. Calls can be explicit (with the CALL statement) or implicit (embedding the call in a 4GL expression). See also actual argument, calling routine, programmer-dened function, pass-by-reference, pass-by-value. See 4GL function. Most keyboards have functions keys F1 through F12. In 4GL, you can dene actions to perform when the user presses a certain function key. To dene these actions, use the ON KEY clause of the CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, or PROMPT statement, or in the KEY clause of the MENU statement. Here and in the OPTIONS statement, you can use the notation F1 through F64 to denote the individual function keys (but not all keyboards support that many function keys). See also control block, key, logical key.
22
global variable
A variable dened outside all program blocks and accessible within all program blocks of the program. The scope of a global variable is all statements that follow the global variable declaration and all source modules which reference the global variable declaration. In 4GL, global variables are declared in the GLOBALSEND GLOBALS statement, either at the top of a source module (outside all program blocks), or in a separate source le. See also declare, dene, program block, scope of reference, source module, variable. Acronym for Global Language Support. The ability to support the character sets and the cultural conventions for data display of most European and Asian languages. (This version of 4GL does not support right-to-left or bidirectional Middle Eastern languages.) A comment block at the top of an ASCII le that identies the le contents. Contents can include the purpose, author, modication information, and other relevant information. Headers are often used in 4GL source modules and form specication les. See also comment, form specication le, source module. A le that contains help messages for a 4GL application. Text associated with each message must be uniquely identied within a given help le. You dene a help message in its source le (by default having a .msg extension) and create a compiled version (default .iem extension) for use at runtime. The mkmessage utility creates the compiled version. Sometimes this le is referred to as a help message le. See also le, help message. The logical key that the user can press in a 4GL application to display a help message for the current form, eld, or menu option. By default, the physical key for help is CONTROL-W. See also logical key, help le, help message. Text that provides information and guidelines on a specic topic or for a given context. In 4GL, each message is identied by a positive, nonzero integer, called a help number. Each number corresponds to one and only one help message text resident in the currently designated help le. Help messages can be displayed automatically or at the request of the user (the Help key). See also Help key, help le. A number represented in base 16. The right-most digit is multiplied by 16 to the power of zero. The digit immediately to the left is multiplied by 16 to the rst power. The digit immediately to the left of that is multiplied by 16 to the second power, and so on. The characters that represent a hexadecimal number are 0-9 and A-F (for 10-15).
GLS
header
help le
Help key
help message
hexadecimal number
Glossary 23
highlight
An inverse-video rectangular area that marks the users place on the screen. A highlight often indicates the current option on a menu or the current character in an editing session. If a terminal cannot display highlighting, the current option often appears in angle brackets while the current character is underlined. A sequence of letters, digits, and symbols that the compiler recognizes as a programmer-dened name of some entity. In 4GL, an identier can include letters, digits, and underscores ( _ ). It must have either a letter or an underscore as the rst character. It can be up to 50 characters in length but the rst 7 must be unique among similar program entities that have the same scope of reference. 4GL does not distinguish between uppercase and lowercase letters. Types of identiers include variable names, cursor names, function names, report names, table names, window names, form names, prepared statement names, and report names. See also 4GL function, 4GL window, case sensitivity, cursor, keyword, name space, prepared statement, report, reserved word, scope of reference, screen form, table, variable. A transaction that automatically begins when an SQL statement that alters the database executes. The developer must explicitly indicate the end of the transaction with the COMMIT WORK and ROLLBACK WORK statements. An ANSI-compliant database uses implicit transactions. See also ANSI compliant, commit, roll back, transaction. 1) A database le that contains a list of unique data values, with pointers to the database rows that contain those values. Indexes are used to reduce the time required to order rows and to optimize the performance of database queries. See also database, query, row. 2) A subscript value into an array. See also array, subscript. The process of assigning a data type to a variable by referencing a database table or column. In 4GL, indirect typing is carried out by the keyword LIKE in a variable denition. See also column, data type conversion, dene, table, variable. A group of related values that are passed to a 4GL report for formatting. The report formats data one input record at a time. The OUTPUT TO REPORT statement sends an input record to a report. See also report.
identier
implicit transaction
index
indirect typing
input record
24
Insert key
The logical key that the user can press in a 4GL application to insert a new line at the current position of the screen array during the INPUT ARRAY statement. 4GL automatically inserts a line at the associated position of the program array. By default, the physical key for Insert is F1. See also Delete key, logical key, program array, screen array. See Interrupt key. 1) A real number with no fractional part. In 4GL, the INTEGER and SMALLINT data types can store integer values within the limits of their ranges. Boolean values are also stored as integers. See also Boolean, data type, simple data type. 2) In uppercase, INTEGER is a data type for storing integers whose absolute value is no greater than 2,147,483,647.
interactive
A mode of execution in which a program accepts input from a user and processes that input, or a program that sends output to the screen, or a program that does both. 4GL programs that use user interactive statements are interactive. See also batch, program execution, user interaction statement. 1) To run a program that has been compiled to intermediate code. The executable le contains instructions in intermediate code. This translation is done by a system program called an interpreter, sometimes called a runner. See also compile, debug, execute, link. 2) The Rapid Development System can interpret 4GL source code by executing the intermediate code (the p-code) produced by the 4GL compiler. See also p-code, Rapid Development System.
interpret
Interrupt key
The logical key that the user can press within a 4GL application to indicate cancellation of the user interaction statement. If the 4GL program does not include the DEFER INTERRUPT statement, pressing this key terminates program execution. With DEFER INTERRUPT, pressing the Interrupt key sets the built-in int_ag variable to TRUE and cancels the current interaction statement, resuming execution at the next 4GL statement. Further response to the Interrupt signal can be deferred, however, until the next pause for user input. The physical key for Interrupt is CONTROL-C. See also Accept key, exception handling, interrupt signal, logical key, Quit key, user interaction statement. A high-priority kind of signal sent to a running program either by the operating system directly or by the user. An Interrupt signal is usually a command to interrupt a running program. In a 4GL application, the user can invoke an Interrupt signal by pressing the Interrupt key. See also Interrupt key, program execution.
Glossary 25
Interrupt signal
interval
1) A span of time. In 4GL, there are two types of intervals, namely year-month (those measured in years and months), and day-time (those measured in smaller time units: days, hours, minutes, seconds, and fraction of seconds). See also data type, simple data type. 2) In uppercase, INTERVAL is a data type for intervals of time. Acronym for Indexed Sequential Access Method. An access method is a way of retrieving pieces of information (rows) from a larger set of information (table). An ISAM allows you to nd information in a specic order or to nd specic pieces of information quickly through an index. The process of combining information from two or more tables based on some common domain of information. Rows from one table are paired with rows from another table when information in the corresponding rows match on the joining criterion. For example, if a customer_number column exists in both the customer table and the orders table, you can construct a query that pairs each customer row with all the associated orders rows based on the common customer_number. 1) In database terminology, a key value is that part of a row that makes the row unique from all other rows; for example, a SERIAL number. At least one such value must exist in any row; the most important is designated as the primary key. See also column, rowid, table. 2) In application terminology, when speaking of the keyboard, a key is what the user presses to enter text or commands in the application. The actual keys of the keyboard (A, ESCAPE, RETURN) are often called physical keys to distinguish them from logical keys (which might be made up of a sequence of keys). See also accelerator key, activation key, control character, function key, keyboard, logical key, mnemonic key, modier key, RETURN key.
ISAM
join
key
keyboard focus
The area on the screen that currently gets input from the keyboard; for example, a text eld. The keyboard focus is usually indicated by highlighting or the presence of a text cursor. See also active window, key, screen, text cursor. A sequence of letters recognized by a compiler as having a reserved meaning within a language. In 4GL, examples of keywords are INPUT, INSERT, TO, and LIKE. In 4GL documentation, keywords are usually shown in uppercase to assist readability, but 4GL keywords are not case sensitive. See also case sensitivity, identier, reserved word.
keyword
26
label
A character string used as a point of reference. For example, a label on a screen form helps to identify a form eld. In a LABEL statement, the label is the identier that indicates the position in a 4GL program to which GOTO statements can transfer control. See also screen form, string. A product obtained from an Informix sales ofce that provides settings for an additional national language. See also locale le, Global Language Support. An output mode of a 4GL program in which screen addressing is not used. 4GL enters this mode and displays the line mode overlay when it executes a simple DISPLAY statement (one without an AT, BY NAME, or TO clause).4GL remains in line mode as long as it encounters additional simple DISPLAY statements or the PROMPT statement. When it encounters any other output statement (ERROR, DISPLAY AT, and so on) or a user interaction statement, 4GL returns to formatted mode. Because this mode results in a simple stream of characters to standard output, it should not be mixed with formatted mode. The OPTIONS, RUN, START REPORT, and REPORT statements can explicitly specify IN FORM MODE or IN LINE MODE to set the screen mode to formatted mode or line mode for PIPE output or for processes that RUN executes. See also formatted mode, line mode overlay. A window that overlays the entire 4GL screen when 4GL enters line mode. The line mode overlay remains as long as the program remains in line mode. It is only updated, however, when 4GL executes either a PROMPT or a SLEEP statement. See also 4GL window, formatted mode, line mode. 1) To combine one or more compiled source modules into a single executable le or program. This merging is done by a system program called a linker or a link editor. The linker veries it can locate all functions called and all variables used. See also compile, debug, execute, executable le, source module. 2) The 4GL Programmers Environment can link compiled 4GL source modules into a single executable le. The Programmers Environment can handle the entire process of compilation, linking, and running of a multimodule 4GL program. If you do not use the Programmers Environment, you must explicitly link compiled 4GL source modules into a single executable le. See also p-code, Programmers Environment.
link
Glossary 27
literal
Characters specifying some xed value, such as a pathname, number, or date. In the format string of a PICTURE eld attribute, for example, any characters except A, #, and X are literals, because they are displayed unchanged in the formatted display. In 4GL statements, literal character values must appear between single ( ' ' ) or double ( " " ) quotation marks. The documentation of Informix database servers sometimes uses the term constant in references to literals. See also attribute, constant, form specication le, quoted string, string. A variable declared in a program block. The scope of a local variable is limited to statements within the same program block. In 4GL, the DEFINE statement declares local variables within MAIN, FUNCTION, or REPORT program blocks. See also declare, dene, program block, scope of reference, variable. A le installed on the system and that denes conventions for some specic language or culture, such as formatting time or money, and classifying, converting, and collating (sorting) characters. See also language supplement. A variable that has meaning only in the program block in which it is dened. See variable and scope of reference. 1) With an Informix Dynamic Server database server, a physical log contains images of entire pages before they were changed. Physical logs are used during fast recovery when Dynamic Server is coming up. See also error log, le. 2) A logical log, sometimes called a transaction log, records changes performed on a database during the period the log was active. A logical log includes, as needed, images of the row before it was changed and images of the row after it was changed. Logical logs are used to roll back transactions, recover from system failures, and restore databases from archives. See also commit, roll back, transaction. 3) The STARTLOG( ) function of 4GL can specify an error log le in which to record runtime errors.
local variable
locale le
logical key
A key that the user can press to perform certain tasks predened by 4GL or the operating system. These include the following keys: Accept key, Delete key, Help key, Insert key, Interrupt key, Quit key. Each key is associated with some default physical key. The OPTIONS statement can assign most logical keys to different physical keys. Certain 4GL statements can reference logical keys with keywords like ACCEPT, DELETE, INSERT, and so forth. See also Accept key, Delete key, Help key, Insert key, Interrupt key, key, Quit key. The procedure that identies a user to a computer. If the login is successful, the user is granted access to the system. See also user name.
login
28
main menu
MAIN
The top menu in a hierarchy of nested menus. See also menu, ring menu. The program block that 4GL begins executing when it starts a 4GL program. This program block is dened with the MAIN statement and includes all statements between the MAIN and the END MAIN keywords. When it reaches the END MAIN keywords, 4GL ends the program. See also 4GL function, function, normal execution, program block, report. 1) In the representation of a FLOAT or SMALLFLOAT value, a signed integer that indicates the number that is to be raised to the power indicated by the exponent. See also exponent, oating-point number. 2) The left-hand unsigned integer operand of the exponentiation ( ** ) operator in 4GL expressions. See also arithmetic operators.
program block
mantissa
member menu
See record member. A graphical object from which the user can choose one of several options, called menu items. Menus often control a program by providing menu items for actions that can be performed. See also main menu, ring menu. A choice the user can make from a ring menu. A menu option can be visible, in which case it appears in the ring menu. It can also be invisible, in which case the user must know the correct activation key for choosing the option. A hidden menu option cannot be activated by the user unless the program uses SHOW MENU within the MENU statement. See also activation key, ring menu. A shorthand name for a key, menu option, or command. See also activation key, alias, key. See ANSI compliant. A key that is held while pressing another key to modify its meaning. See also control character, key. A group of related functions. If these related functions share variables, these variables can be dened as module variables. During program execution, the current module is the source le that contains the program block currently being executed. See also current, module variable, source module. A variable dened outside all program blocks. The scope of reference of a module variable is all statements that follow its denition. In 4GL, module variables are dened with the DEFINE statement at the top of a source module, outside all program blocks. See also declare, dene, program block, scope of reference, source module, variable.
Glossary 29
menu option
module variable
multiplesegment eld
In a screen form, a eld consisting of several, separately delimited parts, each sharing a common eld tag. Such a eld allows long character strings to be displayed or entered on successive lines of the form. A multiple-segment eld requires the WORDWRAP eld attribute in the form specication le. See also eld, eld tag, form specication le, screen form. The set of identiers of different types whose names must be unique within the same scope. For example, the following types of identiers have the same name space: cursor names, window names, form names, function names, global variable names, and report names. Because they share the same name space, none of them can have the same name. For example, a cursor cannot have the same name as a window or a global variable. A cursor can have the same name as a local variable, however, if the cursor does not have the same scope as the variable. See also identier, naming conventions, scope of reference, variable. Guidelines for the creation of identier names that assist the programmer in recognizing the purpose of the identier from its name. For example, prexes can be used to identify names of cursors ( c_ ), windows ( w_ ), program records ( p_ ), program arrays ( pa_ ), global variables ( g_ ), screen arrays ( sa_ ). These guidelines are distinct from naming rules, which the 4GL compiler and runtime enforce with error messages (and failure of your program logic) if a violation occurs. See also identier, name space, scope of reference, variable. Traversing elds, menus, or other controls within a 4GL window. The user can navigate by using the TAB, arrow, and other keys. See also key. The termination of the 4GL application by exiting from the MAIN program block at the END MAIN keywords. In the INFORMIX-4GL Interactive Debugger, you can no longer inspect the application state after normal termination because there are no active functions. (Some earlier versions of 4GL treated the RETURN statement in the MAIN program block as a means of normal termination, but this is now treated as an error.) See also abnormal termination, active function, debug, MAIN program block, program execution.
name space
naming conventions
30
null value
1) A value meaning not known or not applicable. Every data type can represent a null value, which is distinct from a string of blanks or from a value of zero. Database columns and program variables can have null values. In 4GL, this is represented by the keyword NULL. To test for a null value, use the IS NULL and IS NOT NULL operators. See also Boolean operators. 2) In some contexts, null is casually used to mean empty; for example, a character string with zero length is sometimes called the null string. This can lead to confusion, because an empty string (the string ) has a specic non-null value, distinct from a null string. An empty string has a denite length (zero) while a NULL character value has an unknown length and value. In several contexts, however, 4GL represents a NULL character value as the empty string or as a single blank. See also blank space, string.
open
To prepare something for use. In programming, opening something often entails allocating memory and other resources to it, and sometimes means getting exclusive access. Typically, things cannot be used until they have been opened; they remain usable until they are closed. To open a cursor means to have the database server process the query up to the point of locating the rst selected row; this can entail signicant processing and space in memory and on disk. To open a le is to locate the le and bring it into memory. To open a form is to nd the compiled form le, bring it into memory, and prepare to display it. To open a 4GL window is to allocate memory for the image of the window, push it onto the window stack, and to display it on the screen. See also 4GL window, close, cursor, le, query, resources, screen form. A value on which an operation is performed by an operator. An operand can be a variable, a constant, a literal value, a function that returns a single value, or another expression. See also constant, expression, operator, variable. The software that provides an interface between application programs and hardware. It is the part of a computer system that makes it possible for the user to interact with the computer. It manages processes by allocating the resources they need. See also command line, execute, process, resources. A symbol or keyword built into a language that returns a value from the values of its operands. Operators can generate a value from a single value (unary operators) or from two values (binary operators). See also arithmetic operators, assign, associativity, binary operator, Boolean operators, built-in operator, operand, precedence, relational operators, string operators, unary operators. A le in which the results of a query or a report are stored. See also le, query, report.
Glossary 31
operand
operating system
operator
output le
owner
A designation that associates an individual with a le or set of les. Informix databases can use ownership to restrict access to certain columns or tables. On UNIX systems, ownership also applies to les and directories for the purpose of limiting access to their contents and location within the le system. See also database, operating system. Abbreviation for pseudo-code. P-code is an intermediate form of code generated by the Rapid Development System. Although p-code takes more memory to run, it is machine independent. See also compile, debug, execute, interpret, link. A unit of data analogous to the page of a book. One page of a program array is the number of rows that can be displayed in the screen array at one time. The database server stores data in pages. See also program array, screen array. The top part of a page in a report. A running header appears at the top of each page of a report. Information (for example, the title and date) printed at the top of each page of a report is formatted in the PAGE HEADER and FIRST PAGE HEADER control blocks of a report. See also control block, page trailer, report. The bottom part of a page in a report. Information (for example, the page number) printed at the bottom of each page of a report is formatted in the PAGE TRAILER control block. A page trailer is also referred to as a footer. See also control block, page header, report. A method used in a function call that determines how an argument is passed to the programmer-dened function. With pass-by-reference, the address in memory of the actual argument is passed to the function. This method means that changes made to the value of the formal argument within the body of the function will be visible from the calling routine when the function terminates. 4GL uses pass-by-reference only for blob (BYTE and TEXT) variables. See also argument, blob, function call, pass-by-value. A method used in a function call that determines how an argument is passed to the programmer-dened function. With pass-by-value, the actual argument is evaluated and the resulting value is passed to the function. This method means that changes made to the value of the formal argument within the body of the function will not be visible from the calling routine when the function terminates. 4GL uses pass-by-value for variables of all data types except blob (BYTE and TEXT). See also argument, blob, data type, function call, pass-by-reference.
p-code
page
page header
page trailer
pass-byreference
pass-by-value
32
pathname
The list of directories needed to identify a le within a directory hierarchy. In UNIX, directories of a pathname are separated by the slash ( / ). A le can be referred in two ways: by its absolute pathnameall directories starting from the root (top) of the directory hierarchyor by its relative pathnamethe directories relative to the current directory. See also current, directory, le. On some operating systems, the right to have access to les and directories. Compare with privileges. A row of a table that is initially modied or inserted during a transaction but subsequently rolled back. Another process might see a phantom row if the isolation level is DIRTY READ. No other isolation level allows a changed but uncommitted row to be seen. A connection of one process to another process such that the output of the rst process is sent directly as input to the second process. It is one of several ways in which processes can communicate. It is common to speak of a process piping some data to another process. See also process. To remove a value from a stack in memory. See stack and push. A 4GL window that automatically appears when a predened condition or event occurs. In a 4GL application, a popup window often contains a list of values for a given eld. The user can choose from this list rather than needing to type in the value directly. See also 4GL window. The hierarchy of operators. It determines the order in which 4GL evaluates operators within an expression. 4GL evaluates higher-precedence operators before those of lower precedence. The order in which operators at the same precedence level are evaluated is left to right. Precedence order can be changed by surrounding expressions with parentheses. See also associativity, expression, operator. The total number of signicant digits in the representation of a numeric value or in a data type specication. The number 3.14 has a precision of 3. See also oating-point number, scale. The executable form of an SQL statement. SQL statements can be executed dynamically by creating character strings with the text of the statement. This character string must then be prepared with the PREPARE statement. The result of the PREPARE is a prepared statement. The prepared statement can then be executed with the EXECUTE or DECLARE statements. See also query by example, SQL, statement, statement identier.
Glossary 33
pipe
precedence of operators
precision
prepared statement
preprocessor
A program that translates macro code into statements that conforms to the host language. The results of preprocessing can then be passed to a standard language compiler, such as C or COBOL. When using the C Compiler of 4GL, the compiler rst sends the 4GL source module through a preprocessor to translate SQL statements into INFORMIX-ESQL/C calls before passing the le to a C compiler. See also compile, source module. The information from a column or set of columns that uniquely identies each row in a table. The primary key is sometimes called a unique key. The logical location of the print head. A print position can be compared to a screen cursor in that both refer to a specic x,y coordinate on the page or screen. See also column, report, row. A character that can be displayed on a terminal or printer. The locale les specify what characters are printable. These characters might include the ASCII codes 32 through 126: A-Z, a-z, 0-9, symbols (!, #, $, ;, *, and so on), TAB (CONTROL-I), NEWLINE (CONTROL-J), FORMFEED (CONTROL-L) and the blank space character. See also ASCII, blank space, character. The right to use or change the contents of a database. An independent unit of operating system execution. It keeps track of the state of execution for a program. The operating system creates a process for each program being executed. It allocates resources needed by a program (memory, disk, CPU) to its process. The current process is the one that has been allocated use of the CPU. A 4GL application usually runs with two processes: the 4GL application (the front end) and a database server (the back end). See also application development tool, background process, database server, foreground process, operating system, pipe, resources, shell. A 4GL variable dened with the ARRAY keyword. A common use for a program array is as an array of records to store information to be displayed in a screen array. The DISPLAY ARRAY and INPUT ARRAY statements can manipulate program array values or records within the screen array. See also array, program record, screen array, structured data type, variable.
printable character
privileges process
program array
34
program block
A programmer-dened group of 4GL statements that has its own scope during execution. The scope includes denitions and values of variables and can include arguments and return values. 4GL has the following program blocks: a MAIN program block, 4GL functions, and reports. Every executable statement must appear within some program block. Program blocks can neither overlap nor be nested. Any variable dened within a program block is local to that block. See also 4GL function, call stack, executable statement, MAIN program block, programmer-dened function, report, scope of reference, statement block, variable. The process of running (executing) a program. A program can be in the following states: running, suspended (by the system or the program itself), or terminated (abnormally or normally). See also abnormal termination, debug, execute, normal termination. A 4GL variable dened with the RECORD keyword. A common use for a program record is for storing information in a screen record, a row of a table, or in a line of a screen array. See also program array, record, row, screen record, structured data type, variable. A database that describes the resources needed to create some executable programs. It is called syspg4gl (by default), and is accessed by the Programmers Environment. Regardless of the version of 4GL that you are using, (RDS Version or C Compiler), this database tracks for each 4GL program such resources as source les and compiler options. See also executable le, Programmers Environment. A function written in 4GL that can be called in a 4GL program. The developer can write 4GL functions (dened with the FUNCTION statement), a MAIN program block (dened with the MAIN statement), and reports (dened with the REPORT statement). Collectively these types of functions are often called 4GL program blocks. See also 4GL function, function, built-in function, built-in operator, MAIN program block, program block, report. The interface to the 4GL application development package. The Programmers Environment is an integrated development environment that allows you to create, compile, link, run, and debug a 4GL program. See also C Compiler, compile, debug, development environment, execute, link, program design database, Rapid Development System, target. To place a value onto a stack in memory. See stack and pop.
program execution
program record
programmerdened function
Programmers Environment
push
Glossary 35
query
A request to the database to retrieve data that meets certain criteria. The SELECT statement performs database queries. In 4GL, the CONSTRUCT statement allows you to implement a query by example. See database, exception, output le, query by example. A formalized way of implementing a query. The CONSTRUCT statement allows the user to enter query criteria on a screen form, and then it creates a Boolean expression based on these criteria. This Boolean expression can then be appended to an SQL statement (usually a SELECT) to retrieve the desired rows from the database. The SQL statement must then be prepared and executed. See also Boolean expression, cursor, query, prepared statement, query criteria, screen form. A set of data values that specify qualications to apply when looking for data to be returned in a query. The CONSTRUCT statement accepts query criteria on a screen form. See also data entry, query by example, screen form, user interaction statement. The logical key that the user can press within a 4GL application to indicate cancellation of the entered data or query criteria. Pressing it requests abnormal completion of the INPUT, CONSTRUCT, PROMPT, INPUT ARRAY, or DISPLAY ARRAY statements. The physical key for Quit is CONTROL-\. If the 4GL program does not include the DEFER QUIT statement, pressing this key terminates program execution. With DEFER QUIT, pressing the Quit key sets the built-in quit_ag variable to TRUE but does not cancel the current interaction statement. See also Accept key, exception handling, Interrupt key, logical key. See Quit key. A string enclosed in double quotation ( " " ) marks. With the exception of ll characters, the contents of quoted strings are literals. See also character, ll character, literal, string. One of two implementations of the 4GL application development language for UNIX systems. The RDS compiler produces p-code that can then be executed by a runner. The other implementation of 4GL for UNIX systems is the C Compiler; it uses preprocessors to generate C code, which is then compiled and linked to make a stand-alone, executable le. See also C Compiler, compile, execute, interpret, link, p-code, preprocessor, Programmers Environment, program design database. A UNIX disk partition that is dened as a character device and that is not mounted. The UNIX le system is unaware of a raw device.
query by example
query criteria
Quit key
raw device
36
raw I/O
The process of transferring data between memory and a raw device. Informix Dynamic Server can bypass the UNIX le system and address raw devices directly. The advantage of raw I/O is that data on a disk can be organized for more efcient access. Raw I/O is sometimes referred to as direct I/O. 1) A data structure that has a xed number of components. Each component is called a member. Members can have the same or different data types. See also input record, record member, screen record. 2) In uppercase, RECORD is the keyword for dening a program record in 4GL. The RECORD data type is a structured data type. In 4GL, all members of the record are accessed by listing the record name followed by the member name, with a period ( . ) separating them. See also asterisk notation, program record, structured data type. 3) In some database terminologies, a term used for a row. See also row.
record
record member
A named component of a program record. A member can be of any 4GL data type, including RECORD or ARRAY. Some 4GL statements support the asterisk notation (record.*) to specify all the members of a record. See also asterisk notation, program record, record. A pattern used to match variable text. The elements of a regular expression include literal characters that must match exactly; the wildcard symbols asterisk ( * ) to mean one or more characters here and question mark ( ? ) to mean any one character, and the classa list of characters (within brackets) that are acceptable. The MATCHES and LIKE operators of SQL allow you to search for character strings that match to regular expression patterns. See also expression, literal, wildcard. See table. See database. Operators that perform comparison operations. These operators return the values TRUE (=1), FALSE (=0), and in some cases UNKNOWN. (If an operand evaluates to NULL, Boolean operators can yield a third unknown result that 4GL treats as FALSE.) 4GL relational operators are: equal (=), not equal (!= or <>), greater than (>), less than (<), greater than or equal to (>=), and less than or equal to (<=). All relational operators have the same precedence level. See also associativity, binary operator, Boolean operators, operator, precedence.
regular expression
Glossary 37
REPEATABLE READ
A level of process isolation available through Informix Dynamic Server that ensures all data read during a transaction is not modied by another process. Transactions under REPEATABLE READ are also known as serializable transactions. It is the default level of isolation under Informix Dynamic Server for MODE ANSI databases. A 4GL program block dened with the REPORT statement. A report formats data sent as input records. The report header follows the REPORT keyword and denes the name and formal argument list (the input record) for the report. The report body (all statements between the report header and the END REPORT keywords) denes the actions of the report. See also argument, control block, function, input record, output le, page header, page trailer, program block, programmer-dened function. Areas in a 4GL window that are set aside for use by the form or window. These areas include the Error line, where the output of the ERROR statement appears (the default is the last line on the screen); the Comment line, where the text in the COMMENTS eld attribute appears (the default is the next to last line on the screen and the last line on all other 4GL windows); the Form line, where the rst line of the screen form appears (the default is the third line of the current 4GL window); the Menu line, where the ring menu appears (the default is the rst line of the current 4GL window); the Message line, where the output of the MESSAGE statement appears (the default is the second line of the current 4GL window); and the Prompt line, where the output of the PROMPT statement appears (the default is the 1st line of the current 4GL window). These default positions can be changed with the OPTIONS statement or with the ATTRIBUTES clause of the OPEN WINDOW statement. See also 4GL window, ring menu, screen, screen form. A string that you cannot use in any other context of the language or program. In 4GL versions before 4.1, all keywords were reserved words. In Version 4.1 and higher, you can use keywords as identiers, if they do not create an ambiguity for the 4GL compiler. If you compile a 4GL program for an ANSI-compliant database, many keywords are still reserved words, and therefore should not be declared as identiers. See also ANSI compliant, identier, keyword.
report
reserved lines
reserved word
38
resources
1) The hardware and software needs of an executing program. Examples include CPU, memory, disk, printer, terminal (or workstation). These are allocated to the programs process by the operating system. See also operating system, process, terminal. 2) Visual and other attributes that can be chosen at runtime. Resources can be chosen by using command-line options or by using other platform-specic methods. On X/Motif systems, resources can be specied using pre-dened resource names in some les. 4GL statements and ATTRIBUTE settings can override resource choices made through the native resource management systems of a platform. See also attribute.
The key to indicate the end-of-line. The RETURN key is the default Accept key in 4GL. See also key. The value returned by a 4GL function to the calling routine. To return a value, the FUNCTION program block must include the RETURN statement. The calling routine must have some way of handling returned values for a function. Reports cannot return a value to a calling function. See also 4GL function, calling routine, function denition, programmer-dened function. A menu in which the items appear in a single horizontal line. Each menu item is called a menu option. The user can press the SPACEBAR or RIGHT ARROW to make the menu cursor traverse the menu like a ring, as if the rst option followed the last. In 4GL, the MENU statement creates a ring menu. The highlighted option is the current option. If the menu includes more options than the current 4GL window can display on a single line, the menu continues onto successive pages, with the rst page following the last. The line below the Menu line can display text that describes the current option. See also activation key, menu, menu option, page, user interaction statement. To terminate a transaction by undoing any changes to the database since the beginning of the transaction. The database is restored to the state that existed before the transaction began. When the transaction is rolled back, all open database cursors (except hold cursors) are closed and all locks are released. The ROLLBACK WORK statement rolls back the current transaction. See also commit, cursor, log, transaction. The initial dbspace for an Informix Dynamic Server system. In addition to any data, the root dbspace contains all system management tables, the physical log, and at least the initial logical log.
ring menu
roll back
root dbspace
Glossary 39
row
1) In a database, a row is a set of related values, called columns, stored together in a table. A table holds a collection of rows, each one distinct from the others in the contents of its key. In other database terminologies, a row is sometimes called a record or a tuple. See also column, current, cursor, key, rowid, table. 2) In a screen form, a row is the visible display of the values from one database row. The row (of data elds on the screen) might or might not be identical to a row (of values in a table in the database). A single line of a screen array is sometimes called a row. See also screen array. 3) In a report, a row is the information sent by the report driver function. A 4GL program generates a report by sending rows of data to a report function. These rows might or might not correspond to database rows. These rows are also called input records. See also input record. 4) On a screen or in output from a report, a row (or line) is the y-coordinate of a given position on the vertical axis. The x-coordinate (of the horizontal axis) is called a column. Several 4GL statements use rows (or lines) and columns in this sense to identify locations within displays. See also column, screen.
rowid
A hidden, automatically generated column in each table of some Informix databases. It uniquely identies a row, based on its position within the table. A rowid number is assigned when each row is added to a table and released when a row is deleted. Once assigned, the rowid for a specic row cannot be changed, and the rowid number cannot be reused for that table. See also column, row, table. See execute, interpret. Errors that occur during program execution. See also compile-time errors. The number of digits to the right of the decimal point in the representation of a number or in a data type specication. The number 3.14 has a scale of two. See also xed-point number, oating-point number, precision. The portion of the 4GL source code in which the compiler can recognize an identier name. The scope of reference (often referred to simply as scope) refers to the program blocks in which an identier can be referenced. Outside its scope, an identier might not be dened or might even be dened differently. In 4GL, there are three levels of scope: local (a single program block), module (all program blocks in a single source module), and global (all program blocks within a program). See also dene, global variable, identier, local variable, module variable, name space, program block, scope, source module, variable.
scope of reference
40
screen
1) On a character terminal, the rectangular area on a CRT in which text is displayed.The screen takes up the entire terminal display and it can display the output of only one program at a time. See also terminal. 2) On a workstation, the entire display in which text and, possibly, graphical objects are visible. Under a window manager in a graphical environment, a physical screen might contain multiple graphical windows. 3) In a 4GL application, the default 4GL window that is displayed in the 4GL screen. This logical screen is a data structure kept in memory that is a representation of a 4GL screen. The logical screen is not directly affected by window manager operations, though its graphical image on the physical screen might change. See also 4GL screen, 4GL window, column, row.
screen array
In a 4GL form, a screen array consists of consecutive lines that contain identical elds and eld tags. Each line of the screen array is a screen record. The screen array denes the region of the form that will display program array values. The DISPLAY ARRAY and INPUT ARRAY statements can manipulate program array values or records within a screen array. See also eld, eld tag, program array, row, screen record, scrolling. See eld. A data-entry form displayed in a 4GL window (or the 4GL screen) and used to support input or output tasks in a 4GL application. A screen form is dened in a form specication le. Before a 4GL program can use a screen form, this le must rst be compiled. The form in the current 4GL window is called the current form. Most user interaction statements use a screen form for their input and output. See also 4GL window, 4GL screen, active form, attribute, current, form specication le, reserved lines, user interaction statement. A named group of elds on a screen form. Screen forms have one default screen record for each table referred to in the TABLES section, including FORMONLY. The name of a default screen record is the same as the name of the table. See also program record, record, screen array, table. To move forward and back (or up and down) through a series of items. Referring to a screen array, scrolling is the action of bringing invisible lines into view. Displayed data can be scrolled either vertically (to bring different rows into view) or horizontally (to show different columns). Referring to database cursors, a sequential cursor can return only the current row and cannot return to it, but a scroll cursor can fetch any row in the active set. Thus a scrolling cursor can be used to implement a scrolling screen display. See also cursor, screen array.
Glossary 41
screen record
scrolling
search path
The list of directories in which the operating system or a program will look for needed les. This path can be set by the user. Often, the user can specify several different paths to be searched; if one path does not lead to the le, one of the others might. For executable les, the setting of an environment variable called PATH is used. For Informix database les, the setting of the DBPATH environment variable is used. See also database, environment variable, operating system. A join between a table and itself. A self-join occurs when a table is used two or more times in a SELECT statement (under different aliases) and joined to itself. A UNIX communication device that controls the use of system resources. A process that handles the user interaction with the operating system. From the shell, the user can execute operating system commands. A shell is usually provided to contain activity in a given part of the computer system. In UNIX, for example, the shell handles command-line input, and standard output and error reporting. UNIX shells have their own special commands that are not usable within applications. They even have their own special variables and scripting facilities that make the user interface customizable. See also command line, environment variable, operating system, process. Any 4GL or SQL data type that has no component values. Simple data types include integer (SMALLINT, INTEGER); oating-point (FLOAT, SMALLFLOAT, DECIMAL(p)); xed-point (DECIMAL(p,s), MONEY); time (DATE, DATETIME, INTERVAL); and character (CHAR, VARCHAR). Although individual characters in a string can be accessed, as in a C language character array, the data types CHAR and VARCHAR are considered simple data types, rather than structured data types. See also blob, character, data type, xed-point number, oating-point number, integer, interval, structured data type. A transaction that is made up of a single SQL statement. The transaction automatically begins before each SQL statement that alters the database executes and ends when this statement completes. If the single SQL statement fails, the transaction is rolled back; otherwise it is committed. A database that is not ANSI compliant and that does not use transaction logging uses singleton transactions. See also ANSI compliant, commit, roll back, transaction. A le that contains source code for a language; it is used as input to a compiler or interpreter. See also compile, le, interpret, source module.
self-join
semaphore shell
singleton transaction
source le
42
source module
A module that contains one or more related 4GL program blocks. A source module is a single ASCII le with the .4gl extension. Several source modules can be compiled and linked to produce a single executable le. See also compile, executable le, execute, le, le extension, link, module, program block. Acronym for structured query language. A database query language developed by IBM and standardized by an ANSI standards committee. Informix relational database management products are based on an extended implementation of ANSI-standard SQL. See also cursor, database, prepared statement, statement identier. Acronym for SQL Communications Area. It is a built-in record that stores information about the most recently executed SQL statement. The SQLCODE member stores the result code returned by the database server; it is used for error handling by 4GL and the Informix embedded-language products. The SQLAWARN member is a string of eight characters whose individual characters signal warning conditions. SQLERRD is an array of six integers that returns information about the results of an SQL statement. See also database server, error handling, status variable. A data structure that stores information linearly with all operations performed at one end (the top). Such types of data structures are often called LIFO (last-in, rst-out) structures. Stack operations include push, which adds a new piece of data to the top of the stack, and pop, which removes the piece of information at the top of the stack. 4GL uses one stack to transfer arguments to C functions and another to keep track of open 4GL windows. See also 4GL window, call stack. An instruction that 4GL executes. This instruction is a single executable unit of program code but might cover several lines within the source module. For example, the FOR statement might have several lines between the line introduced with the FOR keyword and the line introduced with END FOR keywords. The FOR statement, however, is a single statement because it performs a single action. During program execution, the statement currently being executed is often called the current statement. A statement is distinct from a command: the LET or PRINT command is executed by the INFORMIX-4GL Interactive Debugger; the LET or PRINT statement can be compiled and executed by 4GL. See also current, source module, statement block.
SQL
SQLCA record
stack
statement
Glossary 43
statement block
A group of statements executed together. For example, all statements between the WHILE keyword and the END WHILE keywords constitute a statement block. All the statements within the AFTER INPUT block of the INPUT (or INPUT ARRAY statement) are also considered a statement block. See also control block, program block, statement. The name that represents a prepared statement created by a PREPARE statement. It is used in the management of dynamic SQL statements by 4GL and the Informix embedded language products. See also identier, prepared statement. The built-in variable that 4GL sets after executing each SQL and form-related statement. If the statement is successful, status is set to zero. If the value of status is negative, 4GL terminates program execution unless the program contains the appropriate error handling. After execution of SQL statements, 4GL copies the value of SQLCA.SQLCODE into status. See also error handling, SQLCA record. A value that consists of one or more characters. You can store strings in CHAR, VARCHAR, and TEXT variables. Strings can include printable or nonprintable characters, but 4GL does not provide facilities to display nonprintable characters. Literal string values in 4GL statements generally must be enclosed within quotation ( " ") marks. See also character, literal, printable character, quoted string, subscript, substring. Operators that perform operations on character strings. 4GL string operators include concatenation ( | | ) and substring ( [ ] ) operators, the CLIPPED operator that truncates trailing white space, and the USING operator that can apply formatting masks to character strings. See also associativity, built-in operator, clipped, concatenate, operator, precedence, subscript. Any 4GL data type that contains component values. Structured data types include ARRAY and RECORD. Although individual characters in a string can be accessed, the data types CHAR and VARCHAR are considered simple data types, not structured data types. See also array, data type, record, simple data type. A query that is embedded as part of another SQL statement.
statement identier
status variable
string
string operators
subquery
44
subscript
An integer value to access a single part or element of certain data structures like strings and arrays. In 4GL, the subscript operator is an integer value, surrounded by brackets ( [ ] ). For example, the syntax "strng[3]" accesses the third character of the CHAR string variable by specifying a subscript (or index) of 3; the syntax "pa_customer[5]" accesses the fth element of the pa_customer program array. Two subscripts allow you to specify the starting and ending characters. For example, "strng[3,10]" accesses the third through tenth characters of strng. See also array, character, program array, string, string operators, substring. Consecutive characters within a string. To access a substring in a character expression, put square brackets around a pair of comma-separated unsigned integers to specify the location of the substring within a character string. For example, "strng[3,10]" accesses the third through tenth characters of strng. See also character, subscript, string. Database tables that contain information about the database itself, such as the names of tables or columns in the database, the number of rows in a table, information about indexes and database privileges, and so forth. See also column, database, index, table. The UNIX le that the database keeps to record signicant events like checkpoints, lling of log les, recovery of data, and errors. A collection of related database rows. It can be thought of as a rectangular array of data in which each row describes a set of related information and each column contains one piece of the information. A table sometimes is referred to as a le or a relation. See also column, cursor, database, key, row, rowid. The intended result of a build. The Programmers Environment can create executable les from multiple source modules. This process is called a build. See also executable le, Programmers Environment, source module. An ASCII le in UNIX systems that contains the names and capabilities of all terminals known to the system. See also terminal, terminfo.
substring
system catalog
target
termcap
Glossary 45
terminal
A peripheral device usually centered around a raster screen. Terminals usually come with keyboards, and are used by the user of a computer system to communicate with the computer by typing commands in and looking at the output on the screen. Terminals are often character-based and are thereby distinguishable from displays that are usually graphical. Terminals support monochrome or color output, depending on their designed capabilities and computer system conguration. See also character, key, screen. A database in UNIX systems that contains compiled les of terminal capabilities for all terminals known to the system. See also terminal, termcap. 1) In the SCREEN section a 4GL form, any characters outside the elds, such as labels, titles, and ornamental lines. See also label. 2) In uppercase letters, TEXT is the 4GL and SQL data type that can store up to 231 bytes of character data. See also blob.
terminfo text
Pointer within a text eld that shows the position where typed text will be entered. Often referred to simply as the cursor. See also cursor, text. System software used to create and to modify ASCII les. Usually source code is entered into a source le in a text editor. See also ASCII, source le. A graphical object for displaying, entering, and modifying text, a single line of character data. For example, form elds are text elds for use in screen forms. Text elds are used more generally, for example, to accept text in PROMPT statements. See also eld, screen form, text. A UNIX program that compiles terminfo source les or terminfo les that have been decompiled using infocmp. A named object, specied by a debugger, that the programmer can associate with a statement, program block, or variable. When the tracepoint is reached, the debugger displays information about the associated statement, program block, or variable and executes any optional commands that are specied by the programmer. A tracepoint must be enabled to take effect. See debugger.
tic tracepoint
46
transaction
A collection of one or more SQL statements that must be treated as a single unit of work. The SQL statements within the transaction must all be successful for the transaction to succeed. If one of the statements in a transaction fails, the entire transaction can be rolled back (cancelled). If the transaction is successful, the work is committed and all changes to the database from the transaction are accepted. The transaction log contains the changes made to the database during a transaction. If a database is not ANSI compliant, it uses singleton transactions if it does not use a transaction log and it uses explicit transactions otherwise. If a database is ANSI compliant, it uses implicit transactions. See also ANSI compliant, commit, explicit transaction, implicit transaction, log, roll back, singleton transaction. The process of discarding trailing characters from a string value, or discarding trailing digits from a number. Truncation can produce a warning or error in data type conversion, if the receiving data type has a smaller length or scale than the source data type. It can also cause rounding errors. See also data type conversion, error, scale. See row. An operator that requires only one operand. The unary operator appears before the operand. In an expression, unary operators always have higher precedence than binary operators. In 4GL, examples include logical NOT, unary plus (+), and unary minus (-). 4GL associates most unary operators from right to left. See also arithmetic operators, associativity, binary operator, Boolean operators, operand, operator, precedence. A specication that a database column (or composite list of columns) cannot contain two rows with identical values. You can assign a name to a constraint. An individual who interacts with a 4GL program. The user is a person or process that uses an application program for its intended purpose. Also referred to as the end user. The documentation for Informix database servers sometimes applies this term to the programmer. See also application program, developer. A 4GL statement that allows a user to interact with a screen form or a eld. These statements include CONSTRUCT, DISPLAY ARRAY, INPUT, INPUT ARRAY, MENU, and PROMPT. They suspend execution of the 4GL application for user input. See also attribute, control block, data entry, query by example, ring menu, statement.
truncation
Glossary 47
user interface
The portion of a software or hardware system where communication to or from a human can occur. In 4GL applications, it is that part of a program that waits for input from the user of that program and displays messages or other output based on that users input. Typical user interfaces include menus, prompts, screen forms, and on-line help messages. See also shell. A string that identies a specic user to a computer. It is common for it to be based on an actual name, but this is not required. Once created, the user name is used thereafter during the login process, in establishing ownership, and in permissions and privileges. See also login, owner. A named storage location that holds a value (which can be modied) of a specied data type. A program can access and change this value by specifying its name. A 4GL variable (sometimes called a program variable) can transfer information between a 4GL form, report, and program. To use a 4GL variable, you must rst declare it (with the DEFINE statement) to specify its name and data type. Names of variables must follow the naming rules for 4GL identiers. See also assign, constant, declare, dene, global variable, identier, local variable, module variable, name space, screen form. A derived column of information that is not stored in the database. For example, you can create virtual columns in a SELECT statement by arithmetically manipulating a single column, such as multiplying its values by some quantity, or by combining columns, such as adding the values from two columns. An exception that indicates an unexpected or abnormal condition that could lead to an error in processing or data storage. Warnings can be generated because of language syntax during compilation or because of processing or data exceptions. At runtime, warnings can be generated by the 4GL program or by the database server. By default, 4GL continues execution when it encounters a warning. The developer can change this default behavior with the WHENEVER WARNING directive. See also database server, exception. In a pattern-matching string, a character that means any characters at this point. A For example, in the pattern "v*.4gl" the asterisk means any number of characters after the v and preceding the period. See also regular expression. In 4GL, a rectangular area on the screen in which you can take actions without leaving the context of the background program.
user name
variable
virtual column
warning
wildcard
window
48
B C
N O
V W
Index
Index
A
-a option 1-78, 1-81, D-10 Abbreviated years 4-328, 4-329, 6-35, D-15 Abnormal termination 4-123, 4-246 Accelerator keys 4-173, 4-208 Accept key with CONSTRUCT 4-63 with DISPLAY ARRAY 4-111 with INPUT 4-160 with INPUT ARRAY 4-188 ACCEPT keyword in OPTIONS statement 4-293 Access privileges checking 4-252, 5-121 database 4-72 with ASCII files 4-231, 4-367 Accounting parentheses 5-125 ACE report writer 4-231 a-circumflex character, coding E-35 acsc setting 6-22 ACTION Menu (upscol utility) B-6 Activation clause CASE statement 4-23 CONSTRUCT statement 4-44 DISPLAY ARRAY statement 4-106 IF statement 4-153 INPUT ARRAY statement 4-197 INPUT statement 4-167 PROMPT statement 4-329 WHILE statement 4-382 Activation key CONSTRUCT control block 4-47 DISPLAY ARRAY control block 4-106
INPUT ARRAY control block 4-205 INPUT control block 4-171 MENU control block 4-256 PROMPT control block 4-329 Active set 4-134, 4-379 Addition ( + ) operator in termcap F-14 number expressions 3-64, 5-26 precedence of 3-54 precision and scale 3-44 returned values 5-23 time expressions 3-84, 5-26 AFTER CONSTRUCT block 4-51 AFTER DELETE block in INPUT ARRAY statement 4-210 AFTER FIELD block CONSTRUCT statement 4-50, 5-89 INPUT ARRAY statement 4-208 INPUT statement 4-174 AFTER GROUP OF block 4-334, 5-128, 7-34 AFTER INPUT block INPUT ARRAY statement 4-211 INPUT statement 4-175 AFTER INSERT block, INPUT ARRAY statement 4-209 AFTER keyword CONSTRUCT statement 4-51 INPUT ARRAY statement 4-209 INPUT statement 4-167 REPORT statement 4-334, 7-34 AFTER ROW block, INPUT ARRAY statement 4-210, 5-29, 5-83
Aggregate function AVG( ) 5-16, 7-61 COUNT( * ) 4-366, 5-16, 7-61, 7-63 GROUP 5-15, 7-36, 7-60 MAX( ) 5-16, 7-61 MIN( ) 5-16, 7-61 PERCENT( * ) 4-334, 5-16, 7-61 SUM( ) 5-16, 7-61 two-pass reports 4-334 view columns 3-36, 4-89, 6-26 with BYTE or TEXT arguments 3-15, 3-40 with NULL values 5-15, 7-61 with reports 4-125, 4-334, 4-364, 7-36 with SQL statements 7-59, I-38 Alias of a column D-28 Alias of a table CONSTRUCT statement 4-41 in a field clause 3-86, 4-37 in a form 3-89, 6-24 scope of reference 2-18 ALL keyword MENU statement 4-250 SQL Boolean operator 3-51 ALLOCATE COLLECTION statement 4-351 ALLOCATE DESCRIPTOR statement 4-351 ALLOCATE ROW statement 4-351 Allocation of resources 4-82, 4-239 Alphanumeric characters E-13 ALTER INDEX statement, interrupting 4-302 ALTER TABLE statement interrupting 4-302 query by example 4-39 Ambiguous selections in menus 2-24 Ampersand ( & ) symbol 5-124 AND operator Boolean operator 3-55, 4-35, 5-33, 5-44 precedence of operators 5-43 with BETWEEN 3-55, 5-40, 6-39, 6-82 Angle ( < > ) brackets 3-15, 4-57, 5-35, 6-63, 7-57
ansi option of c4gl command 1-38 option of fglpc command 1-78 ANSI C compiler 1-38 ANSI compliance 2-43 DBANSIWARN D-14 icon Intro-10 -ansi flag 2-43, 4-76, D-10, D-43, G-2 ANSI reserved words G-2 ANSI SQL3 standard G-3 ANSI-compliant database comment indicators 2-8 database references 3-89 DECIMAL(p) data types 3-25 default attributes 6-84 default values 4-157 error handling 5-111 initializing variables 4-157 interrupting transactions 4-303, 4-305 lettercase of identifiers 2-16 LOAD operations 4-236 opening 4-75 owner naming 3-90, 4-40, 4-83, 4-156, 4-373, 6-24 upscol utility B-9 validation criteria 4-374 ANY keyword SQL Boolean operator 3-51 WHENEVER statement 2-43, 4-376 ANYERR 4-378, 5-63, 5-64 -anyerr flag 2-44, 2-42, D-10, D-43 AnyError error scope 2-42, 2-44, D-11 Application programming interface to C 5-7, C-1 program, compiling 1-29, 1-35, 1-77 Argument for 4GL program command line 5-19, 5-99 in function calls 4-17, 4-376 in report definition 4-332, 4-333, 7-7 passed to a C function C-26 passing by reference 4-19, 4-243, 4-309, 4-339, 5-9
passing by value 4-18, 4-308, 4-338, 5-9 stack C-3, C-16 Arguments, of C functions 2-3 ARG_VAL( ) 5-18 Arithmetic functions C-40 Arithmetic operators binary 3-64, 5-23 integer expressions 3-64 list of 3-54 number expressions 3-66, 5-20 time expressions 3-84, 5-21, 5-26, 5-68 unary 3-65, 5-23 Array of records 5-29, 5-83 program array 5-29, 5-83 screen array 6-74, 6-77 ARRAY data type declaration 3-13, 4-87 in FOREACH statement 4-135 in MENU statement 4-264 in report parameter list 4-333, 7-10 index 3-55 ARRAY keyword DEFINE statement 4-87 DISPLAY ARRAY statement 4-102, 4-105 INPUT ARRAY statement 4-187 Arrow keys CONSTRUCT statement 4-61 DBESCWT variable D-21 INPUT ARRAY statement 4-219, 4-220, 4-221 INPUT statement 4-181, 4-268 termcap entry F-5 WORDWRAP fields 4-183, 6-71 ARR_COUNT( ) syntax and description 5-27 with DISPLAY ARRAY 4-103 with INPUT ARRAY 4-215 ARR_CURR( ) syntax and description 5-29, 5-83 with INPUT ARRAY 4-215 ASC keyword 7-24 ASCII characters and corresponding codes A-1 ASCII operator 4-93, 4-274
collating sequence 3-70, 4-59, 6-54, A-1 default codeset E-2 from integer codes 5-31 in screen layouts 6-20 printable 3-71 unprintable 3-71 ASCII file data input 4-231 data output 4-367 error log 5-65, 5-110 form specification 6-5 help file 5-106 Help messages 2-31 source code module 2-10 .4gl source files 1-29, 1-71 ASCII operator PRINT statement 5-32, 7-62 Asian languages E-6, E-15 Assignment statements 2-11, 4-156, 4-227, 6-25 Asterisk ( * ) notation arithmetic operator 5-81, 5-83, 5-84 database columns 3-92, 4-37 exponentiation operator 3-54, 3-64, 5-23 in REPORT prototype 4-332, 4-333, 7-7 multiplication operator 3-54, 3-64, 3-84, 5-23, 5-26 overflow in data conversion C-30 program record members 3-36, 3-92 screen array elements 3-93, 4-98 screen field overflow 4-104, 5-123, 6-18 screen record members 3-87, 3-93, 5-87, 5-97, 6-76 wildcard with CONSTRUCT 4-59 wildcard with MATCHES 5-38 with COUNT function 5-16, 7-61 with PERCENT function 4-334, 5-16, 7-61 Asynchronous message handling 4-78 AT keyword DISPLAY statement 4-90
OPEN WINDOW statement 4-282 At ( @ ) symbol back currency symbol D-26 database servers 4-37, 4-71 MENU statement 4-256 table or column prefix 2-19, 6-6 ATTRIBUTE keyword CONSTRUCT statement 4-41, 6-83 DISPLAY ARRAY statement 4-105, 6-83 DISPLAY FORM statement 4-113, 6-84 DISPLAY statement 4-99, 6-83 ERROR statement 4-119 INPUT ARRAY statement 4-191, 6-83 INPUT statement 4-166, 6-83 MESSAGE statement 4-274 OPEN WINDOW statement 6-84 OPTIONS statement 4-294, 6-83 PROMPT statement 4-327 Attribute types AUTONEXT 4-42, 6-34, B-7 BLACK 3-96 BLINK 3-97, 6-37, 6-82, F-11, F-31 BOLD 6-82, F-31 BORDER 4-287, F-7, F-27 CENTURY 4-327, 4-328, 6-33, 6-35 COLOR 3-15, 3-40, 3-58, 6-33, 6-37, 6-92, B-8 COMMENTS 6-33, 6-43 COUNT 4-193 CURRENT ROW DISPLAY 4-105, 4-192 CYAN 3-96 DEFAULT 6-30, 6-33, 6-45, B-7 DELETE ROW 4-195 DIM 6-82, F-31 DISPLAY LIKE 6-23, 6-33, 6-48 DOWNSHIFT 6-33, 6-49, B-7 FORM 4-298 FORMAT 4-97, 6-50, B-8 GREEN 3-96 INCLUDE 4-373, 6-30, 6-33, 6-53, B-7 INSERT ROW 4-195
INVISIBLE 3-97, 4-100, 4-113, 6-33, 6-56, 6-82, F-31 LEFT 4-97, 6-37, B-9 MAGENTA 3-96 MAXCOUNT 4-194 NOENTRY 4-41, 6-33, 6-57 NORMAL 4-275, 6-82 PICTURE 6-58 PROGRAM 3-15, 3-40, 4-96, 6-33, 6-60 REQUIRED 6-33, 6-62 REVERSE 3-97, 4-286, 6-33, 6-37, 6-63, 6-82, F-4, F-11, F-31 SHIFT B-7 UNDERLINE 3-97, 6-37, 6-82, F-11, F-31 UPSHIFT 6-33, 6-64, B-7 VALIDATE LIKE 6-23, 6-33, 6-65 VERIFY 6-33, 6-66 WORDWRAP 6-32, 6-33, 6-67 YELLOW 3-96 Attributes option B-5 ATTRIBUTES section of form specification default values 6-80, B-7 field attributes 6-25, 6-27, 6-29, 6-33 field names 6-25, 6-27, 6-29, 6-33 field tags 6-26, 6-39 fields linked to columns 6-23, 6-27 FORMONLY fields 6-25, 6-29 multiple-segment fields 6-31 multiple-table forms 6-11 syntax 6-25, 6-33 AUTONEXT attribute 4-42, 5-79, 6-34, B-7 AVG( ) aggregate function 5-16, 7-61 a.out file 1-37, 1-88
B
Background process 4-343 Backslash ( \ ) symbol as escape character 2-4 default Quit key 4-78 escape character 4-227, F-23
Index 3
in forms 6-20 in output files 4-371 in pathnames 4-72 with LIKE 5-39 with MATCHES 5-38 Backspace key for menus 2-24, 4-266 Backup files 1-47, 1-91 Base-100 digits 3-24 BEFORE DELETE block in INPUT ARRAY statement 4-201 BEFORE FIELD block CONSTRUCT statement 4-46 INPUT ARRAY statement 4-205 INPUT statement 4-170 BEFORE GROUP OF block definition of 7-37 variables 4-334 BEFORE INPUT block INPUT ARRAY statement 4-200 INPUT statement 4-170 BEFORE INSERT block in INPUT ARRAY statement 4-203 BEFORE keyword CONSTRUCT statement 4-46, 5-85 INPUT ARRAY statement 4-203, 4-205, 5-85 INPUT statement 4-170, 5-85 MENU statement 4-252 REPORT statement 4-334, 7-37 BEFORE MENU block 4-252 BEFORE ROW block in INPUT ARRAY statement 4-201, 5-29, 5-83 BEGIN WORK statement 4-235, 4-236, 4-303 Bell, ringing 4-118, 4-227, 5-31, 6-58 BETWEEN operator 3-51, 5-41, 6-39, 6-82 Binary arithmetic operators 3-55, 3-64, 5-23, 5-24 Binary large objects (BYTE or TEXT data) data types 3-12 in Boolean expressions 5-37, 6-39 in screen forms 6-60 passing by reference 4-18, 4-309
Binding of forms to database 6-26 of variables to screen fields 4-38, 4-97, 4-103, 4-161, 4-189, 6-6 BITFIXED data type 3-7 BITVARYING data type 3-7 BLACK attribute 3-96, 6-37, 6-56, 6-82 Blank characters between menu options 4-264 CLIPPED operator 3-54, 5-45 DATETIME separator 3-21, 3-29, 3-78, 3-82 default character value 4-163, 4-190, 6-14, 6-30, 6-45 in 4GL statements 2-4 in identifiers 2-14 in input files 4-231 in literal numbers 3-67 in output strings 5-126 INTERVAL separator 3-27, 3-80 padding CHAR values 3-41 PICTURE attribute 6-58 SPACE or SPACES operator 5-108, 7-64 trailing blank spaces 3-41, 5-45 versus NULL values 6-53 with FORMAT attribute 6-50 WORDWRAP fields 4-182, 6-68, 6-70 WORDWRAP operator 5-136, 7-66 BLINK attribute 3-96, 3-97, 6-37, 6-82, F-11, F-31 BLOB data type 3-7 Blob. See BYTE or TEXT data. BLUE attribute 3-96, 6-37, 6-82 BOLD attribute 3-96, 6-82, F-31 Boldface type Intro-9 Boolean capabilities F-4, F-24 BOOLEAN data type 3-7 Boolean expression CASE statement 4-22, 4-26 CONSTRUCT statement 4-34 IF statement 4-153 in 4GL statements 3-60 in SQL statements 3-51 in syscolatt table 6-82, B-9 logical operators 5-35
WHILE statement 4-382 wildcards in searches 5-39 with COLOR attribute 6-38, 6-92 Boolean operators AND 3-61, 5-33, 5-41 BETWEEN 3-51, 3-54, 5-41 description of 5-33 IN 3-51, 3-54, 5-40 IS NOT NULL 5-37 IS NULL 5-37 LIKE 5-38 MATCHES 5-38 NOT 3-61, 5-33 OR 3-61, 5-33, 5-34 BORDER attribute 4-287 Bordered window, graphics characters used 6-22, F-27 BOTTOM MARGIN keywords 7-15, 7-47 START REPORT statement 4-360 Bourne shell 1-4, D-2, D-4 .profile file D-2 Braces ( { } ) symbols comment indicator 2-8, 4-314 in configuration files D-62 screen layout of forms 6-17 Brackets ( [ ] ) symbols array elements 3-54 in string comparisons 5-38 records within screen arrays 3-86, 5-89, 6-79 subsets of BYTE values 3-15 substring operator 3-54 substrings in character arrays 3-14 substrings of TEXT columns 3-39 to specify program arrays 3-70 to specify screen arrays 6-74, 6-77 to specify search criteria 4-59 to specify substrings 3-70, 4-93, 4-275, 6-27 with SCROLL 4-344 BSD UNIX systems 4-207 Build dependencies 1-20, D-58 Built-in constants FALSE 5-22 NOTFOUND 2-46 TRUE 5-22
Built-in functions Aggregates 5-14 ARG_VAL( ) 5-18 ARR_COUNT( ) 5-27 ARR_CURR( ) 5-29, 5-83 AVG( ) 5-16 COUNT( * ) 5-16 CURSOR_NAME( ) 5-53 DOWNSHIFT( ) 5-59 ERRORLOG( ) 5-65 ERR_GET( ) 5-61 ERR_PRINT( ) 5-63 ERR_QUIT( ) 5-64 FGL_DRAWBOX( ) 5-70 FGL_GETENV( ) 5-73 FGL_GETKEY( ) 5-75 FGL_KEYVAL( ) 5-76 FGL_LASTKEY( ) 5-78 FGL_SCR_SIZE( ) 5-81 LENGTH( ) 5-92 MAX( ) 5-16 MIN( ) 5-16 NUM_ARGS( ) 5-99 ORD( ) 5-100 PERCENT( * ) 5-16 SCR_LINE( ) 5-102 SET_COUNT( ) 5-104 SHOWHELP( ) 5-106 STARTLOG( ) 5-110 SUM( ) 5-16 UPSHIFT( ) 5-121 Built-in operators AND 5-33 Arithmetic 5-20 ASCII 5-31 BETWEEN . . . AND 5-41 Boolean 5-33 CLIPPED 5-45 COLUMN 5-47 concatenation 5-50 CURRENT 3-56, 5-51, 6-47 DATE( ) 3-56, 5-56 DAY( ) 3-56, 5-58 EXTEND( ) 3-56, 5-67 FIELD_TOUCHED( ) 3-51, 5-84 GET_FLDBUF( ) 3-51, 5-87 INFIELD( ) 3-51, 5-90 IN( ) 5-41 IS NOT NULL 5-37
IS NULL 5-37 LIKE 5-38 LINENO 3-51, 5-94 MATCHES 5-38 MDY( ) 3-56, 5-95 membership 5-97 MOD 5-25 MONTH( ) 3-56, 5-98 NOT 5-33 OR 5-33 PAGENO 3-51, 5-101 relational operators 5-35 SPACE or SPACES 5-108 substring 5-114 TIME 3-51, 3-56, 5-116 TODAY 3-56, 5-117, 6-47 UNITS 6-46 USING 5-123 WEEKDAY( ) 3-56, 5-133 WORDWRAP 5-135 YEAR( ) 3-56, 5-138 Built-in SQL functions 5-5, 5-7 Built-in variables int_flag 4-78, 4-172, 4-206, 4-256, 4-300 quit_flag 4-78, 4-172, 4-206, 4-256, 4-300 SQLAWARN 2-46, 3-42, 4-75 SQLCA record 2-45, 4-378 SQLCODE 2-45, 2-46, 5-61 SQLERRD 2-46 SQLERRM 2-46 SQLERRP 2-46 status 2-45, 4-373, 4-377, 5-61 BY keyword CONSTRUCT statement 4-38 DISPLAY statement 4-90 Form specification file 6-15 INPUT statement 4-164, 6-6 REPORT statement 4-334, 7-23 SCROLL statement 4-344 BY NAME clause CONSTRUCT statement 4-38 DISPLAY statement 4-90 INPUT statement 4-164, 6-6 BYTE data type ASCII representation 4-232, 4-368 Boolean expressions 5-37, 6-39 data entry 4-185, 4-218
declaration 4-81 description 3-14 display fields 4-96, 4-104, 6-28, 6-60 display width 6-89, 7-57 in expressions 3-58 in program records 3-35, 4-88 in report output 7-57 initializing 4-239 passing by reference 4-18, 4-339 query by example 4-57 selecting a BYTE column 3-15 size limit 3-12 storing data in 3-15 syscolval table 4-373, 6-65 BYTE or TEXT data, description of 4-86 Byte-based string operations E-16
C
C code 1-8 C compiler 1-8, D-12, D-44 C Compiler version of 4GL 1-3, 1-6 C language API 5-7 decimal separator D-28 functions 1-36, 1-80, 1-83, 4-16, 5-7, C-8 generated from 4GL code 1-8 keywords G-2 C shell D-2 .cshrc file D-2 .login file D-2 C shell variants 1-45 C symbol CENTURY 4-328, 6-35 DBCENTURY D-15 c4gl command effect 1-5 help message 1-43 phases 1-36 setting defaults D-10 specifying a C compiler D-12, D-44 C4GLFLAGS environment variable 1-36, 1-38, 1-40, 1-78, 2-42, D-10
Index 5
C4GLNOPARAMCHK environment variable D-11 CALL keyword in WHENEVER statement 4-376, 4-380 CALL statement description 4-16 with C functions 1-88 Calling routine 4-16, 4-337, 5-9, 7-5 CANCEL keyword INPUT ARRAY statement 4-202, 4-204 Caret ( ^ ) symbol 7-22 with CONSTRUCT 4-60 with MATCHES 5-38 with termcap F-3 with terminfo F-23, F-29 with TOP OF PAGE 7-22 CASCADE keyword 4-316 Case insensitivity 2-3 CASE statement 4-22, 4-26 cat utility 1-80 cc compiler 1-37, D-12, D-44 CC environment variable D-12 CENTURY attribute 4-327, 4-328, 6-33, 6-35 cfglgo command 1-83, 1-87 CHAR data type data type conversion 3-42, 3-47, C-30 declaration 3-9, 4-85 description 3-16 display fields 6-50, 6-58, 6-67 display width 4-93, 6-89, 7-57, 7-58 in report output 7-57, 7-58 returned by functions 4-20, 4-339 searching with LIKE 5-39 searching with MATCHES 5-38 subscripts 6-27, 6-30 unprintable characters 3-71 Char data type (of C) C-28 CHAR keyword DEFINE statement 4-85 PROMPT statement 4-327 Character data types 3-11, 3-69 position 6-27 set E-2 CHARACTER data type 3-17
Character expression CLIPPED operator 5-45 data type conversion 3-48 description of 3-69 NULL values 6-30 searching with LIKE 3-55, 5-39, 5-43, 5-134 searching with MATCHES 3-55, 5-38, 5-43 substring 4-275, 6-27 syntax 3-69 Character set E-35 Character string as Boolean expression 4-36 as DATETIME value 3-22 as INTERVAL value 3-31 concatenation 4-228 determining the length 5-92 printable characters 3-71, E-12 Child process 4-340 Chinese language E-6, E-9 .cshrc file D-2 CLEAR statement 4-28 Client locale E-10 CLIENT_LOCALE environment variable 2-15, D-8, E-12, E-27 CLIPPED operator 5-46 description of 5-45 DISPLAY statement 4-93 in a string expression 5-92 MESSAGE statement 4-274 PRINT statement 7-57 with concatentation 5-50 CLOB data type 3-7 CLOSE DATABASE statement 4-72, 4-126 CLOSE FORM statement 4-31 CLOSE statement 4-133 CLOSE WINDOW statement 4-32 Code page 1252 E-27 Code points E-2, E-34 Code set definition E-3 order of collation E-4, E-14 Code-set conversion handling E-34 tables E-12 COLLATION category 4-73, 5-16, 5-35, 5-40, 7-62, E-28
COLLATION locale category 3-41 Collation sequence 7-61, E-4, E-14 Colon ( : ) symbol after database name 3-89 after label identifiers 4-224 after menu name 4-266 before label identifier 4-152 DATETIME separator 3-21, 3-78, 3-82, 4-59, 5-116 in termcap entries F-3 INTERVAL separator 3-27, 3-31, 3-80, 4-59 ranges with CONSTRUCT 4-59 Color number codes 6-82 screen displays 4-285 setting INFORMIXTERM D-51 COLOR attribute 6-33, 6-37, 6-92 Column changing data type 3-42, 4-39 distribution D-40 in screen arrays 6-77 inserting data 4-230, 4-234 name 2-16, E-13 upscol utility 6-81, B-5 with LIKE 4-155, 4-372 with table qualifier 3-89 COLUMN keyword COLUMN operator 5-47, 7-62 DISPLAY statement 4-93 MESSAGE statement 4-274 COLUMN operator 5-47 COLUMNS environment variable D-13 COLUMNS keyword in OPEN WINDOW statement 4-282 Comma ( , ) symbol array subscripts 3-13 in LET statement 4-228, 5-50 in substring specifications 4-275 in USING format strings 5-124 separator in lists 3-93, F-23 COMMAND keyword, MENU statement 4-253, 4-257 Command line arguments of a 4GL program 5-19, 5-99 RUN statement 4-340 START REPORT statement 4-359
to compile a message file B-3 to compile a screen form 6-88 to create a customized runner 1-87, 1-89 to invoke a 4GL program 1-5, 1-80, 1-82, 1-90, 5-19, 5-99 to invoke compiler 1-5, 1-37, 1-77 Comment indicators 2-8, 4-314, 6-15, 6-20, D-3, E-11, F-3, F-23 COMMENT keyword OPEN WINDOW statement 4-285 OPTIONS statement 4-293 Comment line 2-27, 4-61, 4-114, 4-220, 4-288, B-7 COMMENTS attribute 6-43, B-7 COMMIT statement 4-235 COMMIT WORK statement 4-235, 4-236 interrupting transactions 4-303, 4-305 with LOAD 4-235 Comparison operators 3-55, 3-61, 3-85, 4-57, 5-35, 5-36, 5-42, 5-43 Compatible data types 3-46 COMPILE Menu 1-29 Compile option FORM Menu 1-19, 1-60, 6-86 MODULE Menu 1-14, 1-54 PROGRAM Menu 1-24, 1-66 Compiler C compiler 3-25 directive statements 4-13, 4-14 maximum number of variables allowed 4-81 mkmessage 5-106 p-code 4-81 Compiler directives 2-6 Compile-time errors 1-12, 1-53, 6-86 Compiling command line 1-34, 1-37, 1-76 help messages B-2 in Programmers Environment 1-11, 1-34, 1-52, 1-76 programs that call C functions 1-81 screen forms 1-17, 1-58
with ansi flag 1-38, 1-78 Compliance icons Intro-10 Composite characters E-10, E-15 Compound statements 2-7, 2-12, 4-66, 4-116 COMPRESS keyword, WORDWRAP attribute 4-182, 6-67, 6-70 Concatenation ( || ) operator description 5-50 precedence 3-54 condition column of syscolatt 5-40 Conditional comment symbol 2-9 Conditional statements CASE statement 4-22 COLOR attribute 6-37, 6-92 IF statement 7-46 NEED statement 7-52 syscolatt table 6-82, B-9 CONNECT privilege 1-20, 1-61 CONNECT statement 4-349, 4-367, D-45 CONNECT statement, and INFORMIXSERVER environment variable D-48 Connection setting INFORMIXCONRETRY D-44 setting INFORMIXCONTIME D-45 Constant name 2-18, E-14 Constant, Boolean 3-60 CONSTRAINED keyword in OPTIONS statement 4-61, 4-294 CONSTRAINT keyword SET CONSTRAINT statement 4-238 Constraint name E-13 CONSTRUCT keyword AFTER CONSTRUCT block 4-51 BEFORE CONSTRUCT block 4-46 CONSTRUCT statement 4-34 CONTINUE CONSTRUCT 4-53 END CONSTRUCT statement 4-55 EXIT CONSTRUCT statement 4-54 Contact information Intro-21
Context of variable declarations 4-82 CONTINUE keyword CONTINUE CONSTRUCT 4-53 CONTINUE FOR 4-129 CONTINUE FOREACH 4-137 CONTINUE INPUT statement 4-177, 4-214 CONTINUE MENU 4-259 CONTINUE WHILE 4-383 description 4-66 WHENEVER statement 4-376, 4-381, 5-111 Control blocks AFTER GROUP OF 7-34 BEFORE GROUP OF 7-37 CONSTRUCT statement 4-45 description 2-12 DISPLAY ARRAY statement 4-106 FIRST PAGE HEADER 7-40 IF statement 4-153 in FORMAT section of a report 7-32 INPUT ARRAY statement 4-197, 4-199 INPUT statement 4-169 MENU statement 4-67, 4-250 ON EVERY ROW 7-42 ON LAST ROW 7-44 PAGE HEADER 4-346, 7-45 PAGE TRAILER 4-346, 7-47 CONTROL keys INPUT ARRAY statement 4-220 WORDWRAP fields 4-184, 6-72 Conversion errors 2-43 Cooked mode 4-307, 4-341 Correct menu option 1-60 COUNT attribute 4-193 COUNT keyword INPUT ARRAY statement 4-193 COUNT( * ) aggregate function 4-366, 5-16, 7-61 CPU cost for a query 2-46 CREATE FUNCTION statement 5-7 CREATE INDEX statement, interrupting 4-302
Index 7
CREATE PROCEDURE FROM statement 4-349, 4-352 CREATE PROCEDURE statement 4-352 CREATE TRIGGER statement 4-349 crtcmap utility E-38 .cshrc file D-2 CTYPE category 4-73 Currency symbol default ( = $ ) 6-45 East Asian E-16 in format strings 5-127 in input files 4-231 in literal numbers 3-67 in output files 4-368 Current database 4-71, 4-367 file 1-11, 1-51 form 4-35, 4-69, 4-160, 4-188, 4-326 menu option 2-26 option of a menu 1-9, 1-50 window 2-28, 4-29, 4-35, 4-68, 4-160, 4-188 Current field 6-7 CURRENT keyword Boolean expressions 6-37 CURRENT operator 5-51, 6-47 CURRENT WINDOW statement 4-68 DISPLAY ARRAY statement 4-105 INPUT ARRAY statement 4-192 WHERE CURRENT OF clause 5-54 CURRENT operator 5-51 CURRENT ROW DISPLAY attribute 4-104, 4-192 CURRENT WINDOW statement 4-68 Cursor manipulation statements 4-11 menu cursor 4-248, 4-268 scope of reference 2-18 visual cursor 2-26, 6-7 CURSOR keyword in DECLARE statement 4-36
Cursor movement CONSTRUCT statement 4-61 defined in termcap file F-5 defined in terminfo file F-25 DISPLAY ARRAY statement 4-111 editing keys 4-63, 4-181, 4-219, 4-220 in a screen form 6-34 in a screen record 6-26 INPUT ARRAY statement 4-190 INPUT statement 4-162 MENU statement 2-24, 4-268 NEXT FIELD clause 4-52, 4-177, 4-213 NEXT OPTION clause 4-260 unprintable characters 3-71 Cursor name 5-53, E-14 CURSOR_NAME( ) 5-53 Customized runners 1-42, 1-64, 1-83 CYAN attribute 3-96, 6-37, 6-82 Cyrillic alphabet E-9 C++ language 2-15 language keywords G-2
D
d symbol in format strings 5-127, 6-51 D symbol, DBDATE D-17 Data access statements 4-12, 4-13, 4-14 definition statements 4-11, 4-12, 4-13, 4-14 entry 4-181, 4-183, 4-184, 4-293, 6-8 integrity statements 4-12, 4-13, 4-14 manipulation statements 4-11, 4-12, 4-13, 4-14 Data input INPUT ARRAY statement 4-187 INPUT statement 4-159 LOAD statement 4-230 Data type C language C-27
character 3-11 compatible 3-47 conversion 2-47, 3-42, C-27 conversion between 3-46, 5-23, 5-57, 5-68 declaration 3-7, 4-81 display width 7-57 fixed point 3-10 flat file format 4-232, 4-369 floating point 3-10, 3-25, 3-37 indirect declaration 4-73, 4-83 keywords 3-6 large 3-12, 4-86, 4-185, 4-218, 4-239, 4-308 large binary 4-85 large types 3-12 number 3-10 simple 3-9 SQL I-32 structured 3-12, 4-86 time 3-11 whole number 3-10 Data types ARRAY 3-13, 4-87, 6-25 BITFIXED 3-7 BITVARYING 3-7 BLOB 3-7 BOOLEAN 3-7 BYTE 3-12, 3-14, 3-58, 5-37, 6-28, 6-48, 6-60, 6-65, 6-89, 7-57 CHAR 3-11, 3-16, 5-47, 6-46, 6-67, 6-89, 7-57 CHARACTER 3-17 CLOB 3-7 DATE 3-11, 3-17, 3-74, 5-47, 5-123, 6-46, 6-89, 7-57 DATETIME 3-11, 3-18, 3-75, 5-47, 6-46, 6-89, 7-57 DEC 3-23 DECIMAL 3-23, 3-43, 3-66, 5-22, 6-50, 6-89, C-26 declaration 3-8 DISTINCT 3-7 DOUBLE PRECISION 3-25 FLOAT 3-25, 3-66, 5-22, 6-50, 6-89 INT 3-26 INT8 3-7 INTEGER 3-26, 3-66, 5-22, 6-89
INTERVAL 3-11, 3-27, 3-80, 3-84, 5-21, 5-47, 6-46, 6-89, 7-57 large binary 4-86 LIST 3-7 LVARCHAR 3-7 MONEY 3-32, 3-66, 5-22, 5-47, 5-123, 6-45, 6-89, 7-57 MULTISET 3-7 NCHAR 3-33, 3-41, 5-40, E-4 NUMERIC 3-34 NVARCHAR 3-34, 3-41, 5-40, E-4 OPAQUE 3-7 REAL 3-34 RECORD 3-35, 4-88, 4-190, 6-25 REFERENCE 3-7 ROW 3-7 SERIAL 3-7, 4-83, 4-162, 4-189, 5-47, 6-57, 7-57 SERIAL8 3-7 SET 3-7 SMALLFLOAT 3-37, 3-66, 5-22, 6-50, 6-89 SMALLINT 3-38, 3-66, 5-22, 6-89 TEXT 3-11, 3-12, 3-39, 3-58, 5-37, 5-135, 6-60, 6-67, 6-89, 7-65 VARCHAR 3-11, 3-40, 4-15, 6-67, 6-89 Data validation INCLUDE attribute 6-54 NOENTRY attribute 6-57 upscol utility 6-80, 6-82, B-7 VALIDATE LIKE attribute 6-65 VERIFY attribute 6-66 Database administrator (DBA) access privileges 1-20 ANSI-compliant 4-75, 5-111, 6-23, 6-84 binding to screen forms 6-6 closing 4-72, 4-73, 4-126 connection E-26 creating 2-47 current 3-90, 4-74, 4-367 data integrity 4-235 default 4-73, 4-157, 4-374 engine 3-51, 3-89, 4-71, 4-75, 6-13 exclusive mode 4-75 explicit transactions 4-303, 4-304 lock 4-75
name E-13 naming rules 2-15 opening 4-71 remote 4-71, D-34 schema 6-30 server 3-89, 4-71, 4-372, 6-13 server, specifying default for connection D-48 singleton transactions 4-303, 4-304 specification 4-72 types of transactions 4-303 with transactions 4-75, 4-136 Database cursor FOREACH statement 4-132 naming rules 2-15 DATABASE keyword CLOSE DATABASE statement 4-72 CREATE DATABASE statement D-32 DATABASE statement 4-71 DROP DATABASE statement D-33 START DATABASE statement D-33 Database name DATABASE statement 4-71 non-ASCII characters 2-16 table qualifier 3-89, 4-37 DATABASE section of form specification creating as FORMONLY 6-29 syntax 6-12 WITHOUT NULL INPUT 6-14, 6-45 DATABASE statement indirect typing 4-83 syntax and description 4-71 syscolval table 4-156, 4-374 two-pass reports 4-126 DATE data type arithmetic operations 3-84, 5-26 converting to DATETIME 3-44, 5-67 converting to other data types 3-47 declaration 3-9, 4-85 default value 6-30, 6-45
description 3-17 display fields 4-163, 4-190, 5-127, 6-46, 6-51 display width 4-93, 6-89, 7-57 formatting 4-328, 5-128, 6-35, D-15, D-17 in integer expressions 3-84, 5-26 in report output 7-57 in time expressions 3-74 literal values 3-75, 4-231, 4-368, 5-127 time data type 3-11 values 3-74 DATE keyword DATE data type 3-17 DATE operator 3-51, 5-56, 6-47 DATE operator 5-56 DATE value formatting D-17 DATETIME data type arithmetic operations 3-83, 5-68 as character string 3-22, 3-45 data type conversion 3-44, 3-47, 5-57, 5-67 declaration 3-9, 3-18, 4-85 default value 6-30, 6-45 description 3-11 display fields 6-46, 6-59 display width 4-93, 6-89, 7-57 in report output 7-57 in time expressions 3-75 literal values 3-78, 4-231 qualifiers 3-19, 3-76, 6-46 values 3-75 DAY keyword CURRENT operator 5-51 DATETIME qualifier 3-76 DAY( ) operator 5-58 EXTEND( ) operator 5-68 INTERVAL qualifier 3-29, 3-80, 5-69 Day of the week 5-134 DAY( ) operator 5-58 DB2 database 2-4 DB-Access utility 1-68 dbaccessdemo7 script Intro-6 DBANSIWARN environment variable 2-16, 2-43, 4-76, D-14, G-2
Index 9
DBAPICODE environment variable 3-72 DBASCIIBC environment variable E-24 DBCENTURY environment variable 3-18, 3-22, 3-76, 3-79, D-15 DBCODESET environment variable E-24 DBCONNECT environment variable E-24 DBCSOVERRIDE environment variable E-24 DBDATE environment variable 3-17, 3-48, 4-36, 4-231, 4-368, 5-57, 5-127, D-17, E-23, E-28 DBDELIMITER environment variable 4-233, 4-369, D-19 DBEDIT environment variable 1-13, 1-28, 1-54, 1-70, D-20 DBESCWT environment variable D-21 dbexport utility, specifying field delimiter with DBDELIMITER D-19 DBFLTMASK environment variable 4-36 DBFORM environment variable D-23 DBFORMAT environment variable 3-67, 4-36, 5-124, D-25, E-23, E-29 DBLANG environment variable 5-57, 5-107, 5-117, B-4, D-28, E-28 dbload utility, specifying field delimiter with DBDELIMITER D-20 DBMONEY environment variable 3-33, 3-48, 3-67, 4-36, 5-124, D-30, E-23, E-29 DBNLS environment variable 3-17, 3-41, 5-40, D-66, E-14, E-28 DBPATH environment variable 1-20, 1-32, 1-74, 4-39, 4-72, D-32
DBPRINT environment variable 4-357, D-35 DBREMOTECMD environment variable D-36 Dbspace D-37, D-38 DBSPACETEMP environment variable D-37 DBSRC environment variable D-38 DBTEMP environment variable 4-242, D-39 DBTIME environment variable 4-36, D-39 DBUPSPACE environment variable D-40 DB_LOCALE environment variable E-26 DEALLOCATE COLLECTION statement 4-351 DEALLOCATE DESCRIPTOR statement 4-351 DEALLOCATE ROW statement 4-351 Deallocation of variables 4-243 Debug option MODULE Menu 1-55 PROGRAM Menu 1-67 Debugger 1-51, 1-67, 1-75, 1-76, 1-82, 4-123, E-11 Debuggers, of source code 1-41 DEC data type 3-23 decadd( ) C-40 deccmp( ) C-41 deccopy( ) C-42 deccvasc( ) C-28 deccvdbl( ) C-38 deccvflt( ) C-36 deccvint( ) C-32 deccvlong( ) C-34 decdiv( ) C-40 dececvt( ) C-43 decfcvt( ) C-43 DECIMAL data type arithmetic operations 5-23 data type conversion 3-42, 3-47 declaration 3-9, 4-85 description 3-23 display fields 6-50 display width 6-89, 7-57 floating point 3-24
in report output 7-57 internal representation C-26 literal values 3-67 scale and precision 3-24, 3-43 DECIMAL functions for C C-26 Decimal separator 5-129, D-25 Decimal ( . ) point DATETIME separator 3-21, 3-78 DBFORMAT values E-29 DECIMAL values 3-23 fixed-point values 3-23 FLOAT values 3-25 floating-point values 3-23, 3-38 in format strings 5-124 in literal numbers C-28 INTERVAL separator 3-27, 3-80 literal numbers 3-67 decimal.h file C-26 Declaration statements 2-11, 2-14 DECLARE statement 4-132, 4-351 declaring a cursor 4-133 query by example 4-36 decmul( ) C-40 decsub( ) C-40 dectoasc( ) C-30 dectodbl( ) C-39 dectoflt( ) C-37 dectoint( ) C-33 dectolong( ) C-35 dec_t structure C-26 Default activation key 4-255 attributes 6-80 currency format D-6 database 4-73, 4-156 DATE format D-6 editor 1-28, 1-70 environment settings D-5 error record 5-65 field attributes 3-98, 6-83 field label 6-90 field separator D-6 field width 6-89 Help key 2-30 precision 5-67 report margins 5-136, 7-13, 7-66 reserved line positions 4-114, 4-288 screen layout 6-90
10
screen record 6-76 validation criteria 4-374 values 4-157 window attributes 4-285 DEFAULT attribute field attribute 6-33 syntax and description 6-45 with INITIALIZE statement 6-83 with INPUT 4-162 with INPUT ARRAY 4-190 with WITHOUT DEFAULTS 6-45 with WITHOUT NULL INPUT 6-45 Default form specification file creating at system prompt 6-88 generating 1-18, 1-59, 6-86 modifying 1-18, 1-59, 6-86 Default locale Intro-6 DEFAULTS keyword INPUT ARRAY statement 4-191 INPUT statement 4-163 DEFER statement 4-78 DEFINE section of REPORT statement 7-10, 7-68 DEFINE statement in a report 2-17 in FUNCTION statement 4-74, 4-143 in GLOBALS statement 4-74, 4-145 in MAIN statement 4-74 in REPORT statement 4-333 location 2-17 outside program blocks 4-73, 4-82 syntax and description 4-81 Delete key deleting a line F-6, F-26 disabling 4-300 DELETE keyword INPUT ARRAY statement 4-201, 4-210 OPTIONS statement 4-293 DELETE ROW attribute 4-195 DELETE statement, interrupting 4-302 DELIMIDENT environment variable 2-4, 2-16 Delimited SQL identifiers 2-4
Delimiter changing in a screen form 6-79 for DATETIME values 3-21 for input file 4-233 for INTERVAL values 3-21, 3-29 for output file 4-369 for screen fields 2-25 in a screen form 6-17 symbols 2-4 DELIMITER keyword LOAD statement 4-233 UNLOAD statement 4-369 Demonstration application, listing H-1 Demonstration database, restoring 1-5 Dependencies, software Intro-5 Deployment E-11 DESC keyword 7-24 DESCRIBE statement 4-351 DESTINATION keyword 4-356 Diacritical marks E-3 DIM attribute 3-96, 6-82, F-11 Dimensions of an array 3-13, 4-86 Direct nesting 2-32 DIRECTION clause 3-12, 3-18, 3-19, 3-36, 3-41, 3-72, 3-75, 5-74, 5-93, 5-114, 5-137, A-1 Directory, msg E-20 Disabled form fields 6-8 menu options 2-24 DISABLED keyword ALTER TABLE statement 4-349 SET INDEX statement 4-238 DISCONNECT statement 4-349 DISPLAY ARRAY statement ARR_CURR( ) 5-29, 5-83 SET_COUNT( ) 5-104 syntax and description 4-102 DISPLAY ATTRIBUTE keywords 4-298 Display characteristics background colors 5-71 default screen attributes 6-80 field attributes 6-82 formatting output 4-92 output from a report 4-311, 7-19, 7-54
query by example 4-41 screen coordinates 6-15 table of color and intensity values 6-82 Display field attributes 2-29, 3-98, 4-43, 4-167, 4-196, 6-83 cursor movement 4-61 default attributes 6-26, 6-48, 6-65, 6-81 default field lengths 6-18, 6-89 delimiters 2-25, 6-17 display label 2-26 dividing character columns 6-30 field names 6-18, 6-25 field tag 6-17, 6-39, 6-92 format 6-17 FORMONLY 6-25, 6-29 Help messages 2-29, 4-43, 4-167, 4-196 labels for 6-20 multiple-line fields 6-18 multiple-segment fields 6-67 names 6-26, 6-29 screen arrays 6-18 screen records 6-76 substring of a character column 6-27 THRU notation 3-93 verifying field widths 6-18 DISPLAY FORM statement 4-113 DISPLAY keyword DISPLAY ARRAY statement 4-102, 4-105 END DISPLAY statement 4-108 EXIT DISPLAY statement 4-108 INPUT ARRAY statement 4-192 OPTIONS statement 4-294 DISPLAY LIKE attribute 6-23, 6-33, 6-48 Display modes Formatted mode 4-91, 4-96 Line mode 4-91 DISPLAY statement CLIPPED 5-45 formatting 5-126 syntax and description 4-90 Display width E-16 DISTINCT data type 3-7
Index 11
Division ( / ) operator 3-44, 3-64, 3-84, 5-23, 5-26 DM symbols with DBDATE D-17 with DBFORMAT D-27 with DBMONEY D-31 Documentation on-line manuals Intro-18 related reading Intro-20 types of Intro-16 Dollar ( $ ) sign currency symbol D-26 host variable prefix 4-350 Double data type (of C) C-39 DOUBLE PRECISION data type 3-9, 4-85 Double ( -- ) hyphens 2-8 DOWN keyword SCROLL statement 4-344 syscolval table B-7 DOWNSHIFT attribute 6-33, 6-49, 6-80, B-7 Downshifting by compiler 2-3 DOWNSHIFT( ) 5-59 DRDA 2-4 Drop option, PROGRAM Menu 1-26 Dummy functions 2-13 Dynamic 4GL 2-9, 5-12 Dynamic management statements 4-11 Dynamic SQL 4-370 Dynamically linked (shared library) program 1-44
E
East Asian languages E-15 Editing keys CONSTRUCT statement 4-63 INPUT ARRAY statement 4-220 INPUT statement 4-181, 4-183, 4-184 WORDWRAP fields 4-183, 6-71 Editor blanks in fields 6-70 specifying with DBEDIT D-20 Eight-bit clean E-2
Ellipsis ( ) symbols in code examples Intro-11 in menu pages 2-23, 4-266 ELSE keyword, IF statement 4-153 Embedded SQL statements 2-5 ENABLED keyword SET TRIGGER statement 4-238 END keyword 2-12 ATTRIBUTES section of form 6-26 END CASE statement 4-25 END CONSTRUCT statement 4-55 END DISPLAY statement 4-108 END FOR statement 4-130 END FOREACH statement 4-138 END FUNCTION statement 4-144 END GLOBALS statement 4-146 END IF statement 4-153 END INPUT statement 4-178, 4-215 END MAIN statement 4-123 END MENU statement 4-263 END PROMPT statement 4-331 END RECORD declaration 3-35, 4-88 END REPORT statement 7-28 END SQL delimiter 4-350 END WHILE statement 4-383 INSTRUCTIONS section of form 6-74 SCREEN section of form 6-15 TABLES section of form 6-23 END statement 4-116 Endless loop 4-129, 4-381, 4-383 End-of-data character 3-16, 3-41 End-of-data condition 4-322, 4-379 End-of-file character 3-72 ENTER key in ON KEY clause 4-48, 4-172 in query by example 4-63 env utility D-4 ENVIGNORE environment variable D-3, D-41 Environment configuration file example D-2 Environment variable case sensitivity D-4
default assumptions D-5 defining in configuration file D-2 definition of D-1 GLS environment variables D-8, D-65 overriding a setting D-3, D-41 setting at command line D-2 setting in Bourne shell D-4 setting in C shell D-4 setting in configuration file D-2 setting in Korn shell D-4 UNIX environment variables D-9 Environment variables Intro-9 C4GLFLAGS 1-36, 2-42, D-10 C4GLNOPARAMCHK D-11 CC D-12 CLIENT_LOCALE 2-15, D-8, E-12, E-27 COLUMNS D-13 DBANSIWARN 2-16, 2-43, 4-76, D-14, G-2 DBAPICODE 3-72 DBCENTURY 3-18, 3-22, 3-76, 3-79, 4-231, D-15 DBDATE 3-17, 3-48, 4-36, 4-231, 4-233, 4-368, 5-57, 5-127, D-17, E-16, E-23, E-28 DBDELIMITER 4-233, 4-369, D-19 DBEDIT 1-13, 1-17, 1-28, 1-54, 1-58, 1-70, 6-86, D-20 DBESCWT D-21 DBFLTMASK 4-36 DBFORM D-23 DBFORMAT 3-67, 4-36, 4-233, 5-124, D-25, E-16, E-23, E-29 DBLANG 5-57, 5-107, 5-117, B-4, D-28, E-28 DBMONEY 3-33, 3-48, 3-67, 4-36, 5-124, D-30, E-23, E-29 DBNLS 3-17, 3-41, D-66, E-14, E-28 DBPATH 1-20, 1-32, 1-74, 4-39, 4-72, D-32 DBPRINT 4-357, D-35 DBREMOTECMD D-36 DBSPACETEMP D-37 DBSRC D-38 DBTEMP 4-242, D-39
12
DBTIME 4-36, D-39 DBUPSPACE D-40 DB_LOCALE E-26 DELIMIDENT 2-4, 2-16 ENVIGNORE D-3, D-41 FET_BUF_SIZE D-42 FGLPCFLAGS D-10, D-43 FGLSKIPNXTPG D-43 GL_DATE 3-18, 3-19, 3-75, 4-231, 5-57 GL_DATETIME 3-79, 4-233 IFX_LONGID 2-16 INFORMIXC D-44 INFORMIXCONRETRY D-44 INFORMIXCONTIME D-45 INFORMIXDIR B-4, D-47 INFORMIXSERVER D-48 INFORMIXSHMBASE D-49 INFORMIXSTACKSIZE D-50 INFORMIXTERM D-51, F-1, F-22 IXOLDFLDSCOPE D-53 LC_COLLATE E-14 LD_LIBRARY_PATH 1-4, 1-45, D-67 LINES D-55 LPATH 1-45, D-67 ONCONFIG D-56 PATH D-67 PDQPRIORITY D-57 PROGRAM_DESIGN_DBS 1-20, D-58 PSORT_DBTEMP D-60 PSORT_NPROCS D-61 SERVER_LOCALE E-24 SHLIB_PATH 1-45, D-67 SQLEXEC D-62 SQLRM D-64 SQLRMDIR D-65 SUPOUTPIPEMSG D-63 TBCONFIG D-56 TERM D-69 TERMCAP D-70 TERMINFO D-71, F-22, F-29 Environment-configuration file D-2, D-3, D-41 en_us.1252@dict E-7 en_us.1252@dict locale E-5, E-14 en_us.8859-1 locale Intro-6, E-7
Equal ( = ) sign Boolean expressions 3-55, 5-33, 5-43 CONSTRUCT statement 4-57 environment configuration separator D-67 FOR statement 4-128 LET statement 4-227 Error displaying 5-63 log file 5-61, 5-65, 5-110 logging 5-65, 5-110 messages 1-48, 4-120, 5-61, 5-63, 5-64, 5-65, 5-111, B-4 record 5-65, 5-111 Error handling 4GL built-in functions 5-61, 5-64, 5-65 compile-time errors 1-12, 1-53, 6-88 creating an error log 5-110 displaying error messages 5-63, 5-64, 5-65 ERRORLOG( ) 5-65 logging error messages 5-65 run-time errors 1-82, 5-111 SQLCA global record 2-45 STARTLOG( ) 5-111 with status variable 5-61, 5-63, 5-64 ERROR keyword ERROR statement 4-118 WHENEVER statement 4-224, 4-376 Error line 4-61, 4-114, 4-119, 4-220, 4-290, 5-63, 5-64, 5-65 Error messages 4-322 Error messages and internationalization E-22 Error record 5-111 Error scope 2-41 ERROR statement 4-118, 6-56 ERRORLOG( ) 5-65 Errors, runtime 2-40 ERR_GET( ) 5-61 ERR_PRINT( ) 5-63 ERR_QUIT( ) 5-64 Escape character in input files 4-234
in output files 4-371 in quoted strings 2-4 in termcap entries F-3 in terminfo entries F-23 ESCAPE keyword with LIKE 5-40 with MATCHES 5-40 ESQL/C functions 1-36, 1-80 ESQL/C libraries 1-37, 1-83 EVERY ROW keywords default format of a report 4-334, 7-28 ON EVERY ROW control block 7-42 Exceptional conditions 2-40 end of data 4-379 in evaluating expressions 4-378 SQL errors 4-378 warnings 4-75, 4-376 Exceptions handling with DEFER 2-41 handling with WHENEVER 2-41 WHENEVER statement 4-376 Excess-65 format 3-24 Exclamation ( ! ) point Boolean expressions 3-55, 5-33, 5-43 invisible MENU options 4-258 PROGRAM attribute 6-60, 6-61 EXCLUSIVE keyword of DATABASE 4-75 Exclusive mode, DATABASE statement 4-75 Executable statements 2-6, 4-82, 4-147 EXECUTE IMMEDIATE statement 4-351 EXECUTE PROCEDURE keywords in INSERT statement 4-234 EXECUTE PROCEDURE statement 4-135, 4-381, 5-7 EXECUTE statement 4-315 EXECUTE statement in query by example 4-36 EXISTS keyword 3-51 Exit code 4-123, 4-341 EXIT keyword 2-12 EXIT CASE statement 4-25
Index 13
EXIT CONSTRUCT statement 4-54 EXIT DISPLAY statement 4-108 EXIT FOR statement 4-130 EXIT FOREACH statement 4-137 EXIT INPUT statement 4-178, 4-186, 4-214, 4-222 EXIT MENU statement 4-259, 4-269 EXIT PROGRAM statement 4-121, 4-246 EXIT REPORT statement 7-50 EXIT WHILE statement 4-383 versus GOTO statement 4-151 Exit option FORM Menu 1-19, 1-60 MODULE Menu 1-15, 1-56 PROGRAM Menu 1-26, 1-68 UPDATE SYSCOL B-5 EXIT statement 4-121 Exponent DECIMAL data type C-26, C-28 FLOAT data type 3-26, 3-66, 5-25 SMALLFLOAT data type 3-38, 3-66, 5-25 Exponentiation ( * * ) operator 3-66, 5-23, 5-25 export utility D-4 Expressions in form specifications 6-38 in SQL statements 3-51, 5-10 in syscolatt table 6-82 Expressions in 4GL statements arithmetic expressions 3-64, 5-20 Boolean expressions 3-60, 5-33 character expressions 3-69 data type conversion 3-42, 3-65, 3-77, 5-26, 5-69 expression types 3-49 field operators 5-44, 5-81, 5-83, 5-84, 5-87, 5-90 integer expressions 3-62 number expressions 3-66 operands 3-56 operators 5-11, 5-12, 5-13 parentheses 3-52 resetting status 4-378 time expressions 3-72, 5-68, 5-69 Extended ASCII character sets E-2
EXTEND( ) operator implicit 3-48 in arithmetic expressions 3-79, 5-69 syntax and description 5-67 Extensions to SQL syntax D-14 External editor 6-60, 6-89 functions 5-7 table, query by example 4-40 EXTERNAL keyword EXTERNAL REPORT statement 4-364 REPORT statement 4-334, 7-27
F
F symbol CENTURY 4-328, 6-35 DBCENTURY D-15 FALSE keyword INPUT ARRAY statement 4-195 FALSE (Boolean constant) 2-18, 3-61, 4-78, 6-37 Feature icons Intro-10 Fetch buffer D-42 FETCH statement avoiding in PREPARE statements 4-315 implicit with FOREACH 4-132 interrupting 4-302 NOTFOUND code 2-46 with Update cursors 4-136 with WHENEVER 4-379 FET_BUF_SIZE environment variable D-42 fgicfunc.h file 1-89 fgiusr.c file 1-84 fglapi.h C-16 fgldb command 1-82 fglgo command 1-5, 1-42, 1-64, 1-80, 4-343, 5-19 fglpc command 1-5, 1-77, 5-54 FGLPCFLAGS environment variable 1-78, D-10, D-43 FGLSKIPNXTPG environment variable D-43 fglsys.h file G-1
fglusr.h file G-1 fgl_call( ) macro C-23 FGL_DRAWBOX( ) 5-70, 5-71 fgl_end( ) macro C-24 fgl_exitfm( ) macro C-24 FGL_GETENV( ) 5-73 FGL_GETKEY( ) 5-75 FGL_KEYVAL( ) 5-76 FGL_LASTKEY function 5-78 FGL_LASTKEY( ) syntax and description 5-78 with CONSTRUCT 4-56 with DISPLAY ARRAY 4-110 with INPUT 4-179 with INPUT ARRAY 4-216 FGL_SCR_SIZE( ) 5-81 with CONSTRUCT 4-55 with INPUT ARRAY 4-216 fgl_start( ) macro C-21 Field buffer 4-55, 4-110, 4-178, 4-216, 5-87, 5-97 clause 3-86, 5-81, 5-83, 5-84 data type 6-26, 6-29 description 3-98, 6-25, 6-83 editing keys 4-63, 4-181, 4-183, 4-184, 4-293 labels 6-19, 6-90 length 6-18 multiple-segment 6-31, 6-67 names in screen forms 5-90, 6-24, 6-26, 6-29 operators 3-56, 5-44, 5-81, 5-83, 5-84, 5-87, 5-90 qualifier 6-27 single-character 6-19 tags 6-18 Field attributes interacting with users 2-27 order of precedence 6-83 query by example 4-41 FIELD keyword AFTER FIELD 4-50 BEFORE FIELD 4-46, 4-170, 4-205 CONSTRUCT statement 4-46, 4-50, 4-52 INPUT ARRAY statement 4-208 INPUT statement 4-174 NEXT FIELD 4-52
14
OPTIONS statement 4-294 FIELD ORDER CONSTRAINED keywords 4-61, 4-296 FIELD ORDER UNCONSTRAINED keywords 4-61, 4-296 Field tag in Boolean expressions 3-58, 6-40, 6-92 in default forms 6-18, 6-90 in the ATTRIBUTES section 6-25, 6-39 in the SCREEN section 6-17, 6-67 naming conventions 6-18 naming rules 2-14 FIELD_TOUCHED( ) operator 3-51 syntax and description 5-84 with CONSTRUCT 4-53 with DISPLAY ARRAY 4-110 with INPUT 4-178 File environment configuration D-2 temporary for Dynamic Server D-37 temporary for SE D-39 File extensions 4ec 1-48 .4be 1-48, 1-91 .4bl 1-48, 1-91 .4bo 1-48, 1-91 .4ec 1-7, 1-35 .4ge 1-12, 1-15, 1-22, 1-35, 1-47, H-1 .4gi 1-63, 1-71, 1-74, 1-80, 1-90 .4gl 1-7, 1-13, 1-28, 1-35, 1-47, 1-69, 1-77, 1-90, 2-8, 4-148, D-38, H-1 .4go 1-64, 1-71, 1-77, 1-80, 1-90 .c 1-8, 1-23, 1-35, 1-48, 1-87 .dbs 4-71, 6-12, D-39 .ec 1-8, 1-23, 1-32, 1-35, 1-36, 1-48, 1-87 .erc 1-48, 1-90 .err 1-34, 1-48, 1-52, 1-76, 1-90, 6-88 .fbm 1-48, 1-91 .frm 1-47, 1-91, 4-278, 4-283, 6-86, 6-88, D-23 .h 1-41, 1-88, C-26
.iem B-4, D-28, D-30, E-32 .msg B-4, E-20 .o 1-11, 1-29, 1-35, 1-47 .out 1-37, 1-88 .pbr 1-48, 1-91 .per 1-16, 1-47, 1-91, 4-278, 6-88 .rc D-41 .sql D-32 .src H-1 FILE keyword LOCATE statement 4-241 OPTIONS statement 4-294, 4-299, B-2 PRINT statement 7-57 REPORT statement 7-18 START REPORT statement 4-358 Filename E-14 LOAD statement 4-230 UNLOAD statement 4-367 Fill character ampersand ( & ) symbol 5-124 parentheses 5-125 pound sign 6-50 pound ( # ) sign 5-124 finderr script Intro-18 FINISH REPORT statement 4-125, 7-5 FIRST keyword OPEN WINDOW statement 4-285, 4-289 OPTIONS statement 4-295 REPORT statement 7-40 FIRST PAGE HEADER control block 4-354, 7-40, 7-45 Fixed-point numbers 3-26, 3-38, 3-67 FLOAT data type data type conversion 3-42, 3-47 declaration 3-9, 4-85 description 3-25 display fields 6-50 display width 6-89, 7-58 literal values 3-26, 3-67 Float data type (of C) C-37 Floating-point numbers 2-47, 3-26, 3-38, 3-43, 3-67, C-36 Font requirements E-4
FOR keyword CONTINUE FOR statement 4-66, 4-129 DECLARE statement 4-132 END FOR statement 4-130 EXIT FOR statement 4-130 FOR statement 4-128 PROMPT statement 4-327 SELECT statement 4-315 FOR statement 4-128 FOREACH keyword in CONTINUE FOREACH statement 4-66 FOREACH statement interrupting 4-302 syntax and description 4-131 Foreground colors 5-71, F-21 Form binding fields to variables 6-6 binding to the database 6-6 clearing 4-28 closing 4-31, 4-32 declaring 4-279 dimensions 6-15 displaying 4-278, 4-291 fields 3-86, 4-37, 6-7 identifying the current field 5-90 line 2-27, 4-114, 4-288 naming rules 2-14 screen records 6-76 syntax of form specification 6-10 FORM Design Menu 1-15 Form driver 6-5 FORM keyword CLEAR FORM statement 4-28 CLOSE FORM statement 4-31 DISPLAY FORM statement 4-113 OPEN FORM statement 4-278 OPEN WINDOW statement 4-31, 4-285 OPTIONS statement 4-293, 4-298, 4-307 REPORT statement 7-17 RUN statement 4-341 START REPORT statement 4-355 FORM LINE keywords OPEN WINDOW statement 4-285 OPTIONS statement 4-293
Index 15
Form management blocks, CONSTRUCT statement 4-44 Form mode 4-359 Form specification file ATTRIBUTES 6-9, 6-25 DATABASE 6-9, 6-12 DISPLAY FORM statement 3-98, 6-84 INSTRUCTIONS 6-9, 6-74 multiple tables 6-23 OPEN FORM statement 4-278 OPEN WINDOW statement 4-283 overview 6-5 PERFORM forms 6-91 SCREEN 6-9, 6-15 TABLES 6-9, 6-23 Form specification file, using correcting errors 1-17 creating 6-88 default form specification file 6-88 generating 1-15, 1-56 graphics characters 6-21 multiple tables in 6-85 FORM4GL attribute syntax 6-33 command line syntax 6-88 creating a default form specification file 6-86 default attributes 6-26 default field tags 6-88 default screen records 6-76 description 6-5 field attributes 6-32 file extensions created by 6-88 from Programmers Environment 1-18, 1-59 graphics characters in screen section 6-21 verifying field widths 6-18 Formal arguments name space 2-19 non-English characters E-14 of reports 3-6 scope of reference 2-18 Format date data D-17 monetary data D-25
numeric data D-25 FORMAT attribute syntax and description 6-50 FORMAT keyword FORMAT attribute 6-50 REPORT statement 4-334 FORMAT section of REPORT statement AFTER GROUP OF 7-34 BEFORE GROUP OF 7-37 CLIPPED 7-57 COLUMN 7-45 COLUMN operator 5-47 EVERY ROW 7-29 FIRST PAGE HEADER 7-40 NEED statement 4-276, 7-52 ON EVERY ROW 7-42 ON LAST ROW 7-44 PAGE HEADER 7-45 PAGE TRAILER 7-47 PAUSE statement 4-311, 7-54 PRINT statement 4-324, 7-55 SKIP statement 4-346, 7-68 syntax 7-28 USING 7-57 WORDWRAP 5-135, 7-65 Format strings in syscolatt table 6-82 with FORMAT attribute 6-50, 6-58, B-8 with PICTURE attribute 6-58 with USING operator 3-69, 5-123 Formatted mode 4-91, 4-96, 4-359, 7-18 Formatting data 2-27 date values 4-328, 6-35, D-15 number expressions 5-124 Formatting a report automatic page numbering 7-45 default report format 7-19, 7-29 formatting dates 5-127 formatting numbers 5-124 grouping data 5-15, 7-60 page headers and trailers 7-40, 7-45, 7-47 printing column headings 7-45 setting margins 5-135, 7-15, 7-16, 7-19, 7-20, 7-65
setting page eject character 7-21 setting page length 7-16 skipping to top of page 4-346 starting a new line 4-346, 5-136, 7-57, 7-66 starting a new page 4-276, 4-346, 5-136, 7-21, 7-52, 7-66, 7-68 FORMFEED character in TEXT values 3-39, 3-71 FORMONLY field 3-16, 4-57, 4-161, 6-29 FORMONLY keyword ATTRIBUTES section 6-29 CLEAR statement 4-30 CONSTRUCT statement 4-57 DATABASE section 6-23 field clause 3-86, 4-37 INSTRUCTIONS section 6-76 FOUND keyword in WHENEVER statement 4-376 4gluser.msg file E-20 4GL shared library implementation 1-43 4GL error handling 2-44 FRACTION keyword CURRENT operator 5-51 DATETIME qualifier 3-76 INTERVAL qualifier 3-28, 3-80 FREE statement 4-243 French language E-21 FROM keyword CONSTRUCT statement 4-40 CREATE PROCEDURE FROM statement 4-352 INPUT ARRAY statement 4-189 INPUT statement 4-165 LOAD statement 4-231 OPEN FORM statement 4-278 PREPARE statement 4-312 SELECT statement 4-369 Function keys 1-64, D-21, F-6, F-26 Function name E-14 FUNCTION statement, argument data types 3-6 Functions as arguments 3-58, 4-141 built-in 4GL functions 5-6, 5-13 built-in SQL functions 5-7 C language 1-36, 1-80, 5-7, C-26
16
dummy functions 4-142 ESQL/C 1-36, 1-80, 5-7 function calls in expressions 3-58 function calls in reports 7-59 invoking with CALL 4-16 invoking with WHENEVER 4-376 naming rules 2-14 overview 5-5 prototypes 5-8 -fwritable flag D-44 fwritable option of gcc D-12
G
gb setting 6-22 gcc compiler D-12, D-44 ge setting 6-22 Generate option, FORM Menu 1-18, 1-59 German language E-21 GET DESCRIPTOR statement 4-351 GET DIAGNOSTICS statement 4-351 get_fldbuf( ) function 3-97 GET_FLDBUF( ) operator 3-51, 4-53, 4-55, 4-215, 4-216, 5-87 Global aggregate functions 4-334 Source array 1-64 Global Language Support (GLS) Intro-6, D-65, E-20 Global string space 2-15, 4-81 Global variables declared in MAIN 4-246 declaring 4-82, 4-145 importing 4-147 scope of reference 2-17 GLOBALS keyword END GLOBALS statement 4-148 GLOBALS statement 4-145 Globals menu option 1-74 GLOBALS statement syntax and description 4-145 with DATABASE 4-74, 4-148 with DEFINE 4-146
-globcurs option 1-40, 1-78, 5-55, 1-40, 2-19, 4-313 Glossary of localization terms, keeping E-21 GL_DATE environment variable 3-18, 3-19, 3-75, 4-231, E-23 GL_DATETIME environment variable 3-79, E-23 GOTO keyword, WHENEVER statement 4-224, 4-376 GOTO statement 4-151 GRANT statement with LOAD 4-231 with UNLOAD 4-367 Graphical replacement conversion E-37 Graphics characters in forms 6-21 Greater than ( > ) symbol BYTE values in reports 7-57 COLOR attribute 6-38 relational operator 3-55, 4-57, 5-35, 5-43 REVERSE attribute 6-63 Greek characters E-35 Greek language E-9 GREEN attribute 3-96, 6-37, 6-82 grep utility D-51 GROUP keyword AFTER GROUP OF control block 7-34 aggregate functions 4-334, 5-15, 7-36, 7-60 BEFORE GROUP OF control block 7-37 gs setting 6-22
H
Header files, decimal.h C-26 HEADER keyword FIRST PAGE HEADER control block 7-40 PAGE HEADER control block 7-45 Help menu 5-106, B-4 message file 5-106, B-2
message number 5-106, B-2 window 2-30, 5-106 Help file compiling with mkmessage B-2 SHOWHELP( ) 5-107, B-3 Help key assigning 4-294 default 2-30 effect 5-107 valid contexts B-2 HELP keyword CONSTRUCT statement 4-43 INPUT ARRAY statement 4-196 INPUT statement 4-166 MENU statement 4-254 OPTIONS statement 4-294, 4-299, B-2 PROMPT statement 4-329 Help message creating and compiling 1-10, 1-51, B-2 displaying 1-9, 1-50, 4-43, 4-166, 4-196, 5-107 specifying Help file 4-294 using SHOWHELP( ) 5-106 Heterogeneous nesting 2-34 Hexadecimal numbers 4-233, 4-370 Hidden Comment line 4-290 Hidden menu options 4-260 HIDE keyword, MENU statement 4-260 High-order bit E-2 hkenv utility D-3 HOLD keyword in DECLARE statement 4-132 Host system 3-90 Host variables 4-350, 4-370 HOUR keyword DATETIME qualifier 3-19, 3-76 INTERVAL qualifier 3-29, 3-80 Hyphen ( - ) symbol comment indicator 2-8, 4-314 DATETIME separator 3-21, 3-29, 3-75, 3-78, 3-82 in window border 6-21, F-7 INTERVAL separator 3-27, 3-83 with CONSTRUCT 4-60 with MATCHES 5-38
Index 17
I
i4gl command 1-5, 1-27, 6-85 i4glc1 compiler 1-7, 1-35, 1-36, 1-41, 1-48, 5-54 i4glc2 compiler 1-7, 1-35, 1-36, 1-41 i4glc3 compiler 1-8, 1-35, 1-41 i4glc4 compiler 1-8, 1-35, 1-36, 1-41 i4gldemo script 1-5, 1-43 ICB statements, nested and recursive 2-31 Icon modification E-15 Icons compliance Intro-10 feature Intro-10 platform Intro-10 product Intro-10 syntax diagram Intro-13 Identifier database cursor 4-133 declaring 2-14 function arguments 4-141 naming conventions 2-14 predefined 2-18, 2-19 report arguments 4-333 report name 4-125, 4-354, 4-364 scope of reference 2-17 source-code module 1-13, 1-65 SQL and 4GL 2-15, E-13 SQL identifiers 2-16, 2-19 user name 2-17 IF statement 4-153 IFX_LONGID environment variable 2-16, 6-26, 6-75 Implicit names, declaring 4-88 IN keyword Boolean expressions 3-54, 5-41, 6-38, 6-82 CREATE TABLE statement 4-86 LOCATE statement 4-86, 4-241 OPTIONS statement 4-307 REPORT statement 7-17 RUN statement 4-341 START REPORT statement 4-355 INCLUDE attribute 6-53 INCLUDE keyword in syscolval table 4-373 Incompatible data types 3-47
INDEX keyword SET INDEX statement 4-238 Index name 2-16, E-13 Index to an array 3-13 Indirect nesting 2-33 Indirect typing 2-16, 4-73, 4-83, 4-148, 7-11 INFIELD( ) operator 3-51 field-level Help 4-43, 4-167, 4-196 Help messages 2-29 in ON KEY clause 4-173, 4-208 syntax and description 5-90 with CONSTRUCT 4-56 with INPUT 4-179 with INPUT ARRAY 4-216 INFO statement 4-351 infocmp utility F-27, F-31 Informix Developer Network (IDN) Intro-20, 1-34 Informix Dynamic 4GL 2-9 .informix environment configuration file D-2 informix owner name 2-17, 5-10, D-30 INFORMIX Relay Module D-62 INFORMIX-4GL as a report writer 7-4 command file names 1-76 program 2-3 screen forms 6-5 versions 1-3 INFORMIXC environment variable D-44 INFORMIXCONRETRY environment variable D-44 INFORMIXCONTIME environment variable D-45 INFORMIXDIR environment variable B-4, D-23, D-47 Informix-Dynamic Server database names 2-15 specific data types 4-15 INFORMIX-ESQL/C functions 1-36, 1-80, 2-10, 5-7 INFORMIX-NET D-62, E-34 INFORMIX-SE database names 2-15 database server E-13
interrupting SQL statements 4-302 rolling back transactions 4-304 specific data types 4-15 INFORMIXSERVER environment variable D-48 INFORMIXSHMBASE environment variable D-49 INFORMIX-SQL 1-68 Interactive Editor 6-73 screen forms 6-91 INFORMIXSTACKSIZE environment variable D-50 INFORMIXTERM environment variable D-51, F-1, F-22 informix.rc file D-2 INITIALIZE statement 4-155 inode number 5-55 INPUT ARRAY statement ARR_CURR( ) 5-29, 5-83 SCR_LINE( ) 5-102 SET_COUNT( ) 5-104 syntax and description 4-187 INPUT ATTRIBUTE keywords 4-298 Input Control Block (ICB) statements 2-31 Input file dbload utility 4-233 LOAD statement 4-231 INPUT keyword AFTER INPUT block 4-175, 4-211 BEFORE INPUT block 4-170, 4-200 CONTINUE INPUT 4-177, 4-214 CONTINUE INPUT statement 4-66 EXIT INPUT statement 4-178, 4-214 INPUT ARRAY statement 4-187 INPUT statement 4-159 OPTIONS statement 4-294 WITHOUT NULL INPUT 6-12 INPUT NO WRAP keywords 4-296 Input record 4-232, 4-308, 5-104, 7-5 INPUT statement ARR_COUNT( ) 5-27 syntax and description 4-159 INPUT WRAP keywords 4-296
18
Insert editing mode 4-63, 4-181, 4-220 privilege 4-231 Insert key defining F-6, F-26 INPUT ARRAY statement 4-206 INSERT keyword GRANT statement 4-231 INPUT ARRAY statement 4-203, 4-209 LOAD statement 4-234 OPTIONS statement 4-293 INSERT ROW attribute 4-195 INSERT statement DATETIME or INTERVAL values 3-45 interrupting 4-302 NOENTRY attribute 6-57 with INPUT 4-160 with INPUT ARRAY 4-188 with LOAD 4-234 INSTRUCTIONS section of form specification screen arrays 6-77 SCREEN RECORD keywords 3-86, 4-37, 5-84, 6-74, 6-75, 6-77 screen records 6-74 syntax 6-74 INT data type 3-26 Int data type (of C) C-32, C-33 INT8 data type 3-7 Integer division 3-64, 5-25, F-14 expression 3-63 literal 3-65 INTEGER data type data type conversion 3-42, 3-47 declaration 3-9, 4-85 description 3-26 display fields 6-14 display width 6-89, 7-58 in report output 7-58 literal values 3-67 Intensity attributes 6-82, D-51 Intentional blanks in multiplesegment fields 4-182, 6-70 Interactive Debugger Debugger path 1-65, D-38
description of 1-82 documentation Intro-17 invoking 1-51, 1-67 International Language Supplement E-9 Internationalization code-set conversion enabling for UNIX E-38 code-set conversion, description of E-34 definition E-2 fonts E-19 keyboard layouts E-19 measurement systems E-19 messages E-32 overview of methodologies E-22 paper size E-19 reports E-20 translation checklist E-20 Interprocess connections 4-77 Interrupt key interrupting SQL statements 4-80, 4-301, 4-303 with DEFER 4-79 with DISPLAY ARRAY 4-111 with INPUT 4-186 with INPUT ARRAY 4-222 with MENU 4-249, 4-268 with OPTIONS 4-301 with PROMPT 4-330 INTERRUPT keyword DEFER statement 4-78 MENU statement 4-256 OPTIONS statement 4-80, 4-294, 4-301, 4-303 Interrupt signal 2-41, 4-342, C-19 INTERVAL data type arithmetic operations 3-84, 5-26, 5-68 as character string 3-31, 3-45, 4-231 data type conversion 3-47 declaration 3-9, 3-27, 4-85 description 3-27 display fields 6-46, 6-59 display width 6-89, 7-58 in report output 7-58 in time expressions 3-84, 5-26 literal 3-29, 3-82
qualifiers 3-28, 3-80, 6-46 time data types 3-11 values 3-75 INTO keyword EXECUTE PROCEDURE statement 4-350 EXECUTE statement 4-134 FOREACH statement 4-134 INSERT statement 3-20, 6-6 LOAD statement 4-234 SELECT statement 3-39, 4-36, 4-135, 4-241, 4-314, 4-350 INTO TEMP keywords, SELECT statement 4-315 int_flag 4-64, 4-78, 4-256, 4-300, 4-302, 4-330 Inverse video 4-286, 6-63, 6-82 INVISIBLE attribute 3-96, 3-97, 4-100, 4-275, 6-56 Invisible menu options 4-257, 4-262 Invoking 4GL Compiler 1-5, 1-35, 1-37, 1-77 4GL programs 1-5, 1-33, 1-67 4GL reports 4-354 FORM4GL 1-18, 1-59, 6-88 Interactive Debugger 1-51, 1-75 Programmers Environment 1-5, 1-9, 1-49 ioctl( ) call D-12, D-55 IS keyword CURRENT WINDOW statement 4-68 IS NULL operator 3-54, 3-55, 5-43 NULL test 5-37, 6-39 ISAM error code 2-46 ISO 8859-1 code set Intro-6 ISO Standard A4 E-19 Italian language 4-101 IXOLDFLDSCOPE environment variable D-53
J
JA 7.20 supplement E-8 Japanese eras 3-75, 3-79 Japanese language E-6, E-8, E-9 Join columns 4-89, 6-92 Joins E-25
Index 19
Jump instructions 2-11, 4-66, 4-151, 4-224, 4-379 Jump statements 2-40 Justified data display left justified 4-103, 5-124, 5-136, 6-37, 7-66, C-30 right justified 4-103, 5-126, 6-50
L
LABEL statement syntax and description 4-224 with GOTO 4-151 with WHENEVER 4-380 Language features built-in functions 5-6 built-in operators 5-11 flat-file input 4-230 functions 5-5 statement types 4-9, 4-13 Language-sensitive files E-30 Language supplement D-23, E-8 Large binary data types 3-12, 4-86, 4-185, 4-218, 4-239 LAST keyword OPEN WINDOW statement 4-285, 4-289 OPTIONS statement 4-295 REPORT statement 4-334, 7-44 Latin alphabet E-9 LC_COLLATE environment variable E-14 LD_LIBRARY_PATH environment variable 1-4, 1-45, D-67 Leading currency symbol 5-129, D-25, D-30 Leap year 5-134 LEFT attribute 6-37 LEFT MARGIN keywords 7-16 START REPORT statement 4-360 Left margin of a 4GL window 4-280 Left-brace ( [ ) symbol 2-8 LENGTH keyword PAGE LENGTH clause 4-360, 7-16 Length of identifiers E-13 LENGTH( ) 5-92 Less than ( < ) symbol BYTE values in reports 7-57 COLOR attribute 6-38 relational operator 3-55, 4-57, 5-35, 5-43 REVERSE attribute 6-63 LET statement CLIPPED operator 5-45 syntax and description 4-226 USING operator 5-123
K
-keep option D-10 Key activation key 4-255 assigning logical functions 4-300 choosing menu options 4-265 Help 2-29 Help key B-2 Interrupt 4-80, 4-301 scrolling and editing 4-103, 4-220 KEY keyword ACCEPT KEY 4-293 CONSTRUCT statement 4-47 DELETE KEY 4-221, 4-293 DISPLAY ARRAY statement 4-106 HELP KEY 4-294 INPUT ARRAY statement 4-205 INPUT statement 4-171 INSERT KEY 4-293 MENU statement 4-256 NEXT KEY 4-293 PREVIOUS KEY 4-294 PROMPT statement 4-329 Keystroke buffer 4-55, 4-110, 4-178, 4-216 Keywords as identifiers 2-15 of C and C++ G-2 precedence G-1 Kinsoku processing 5-137, 6-68, 7-66, E-15 KO 7.20 supplement E-8 Korean language E-8, E-9 Korn shell 1-4, D-2, D-4 .profile file D-2
Letter case sensitivity 2-3, 2-14, 5-7, 5-127, 6-18 Lettercase conversion 2-3, 5-59, 5-122, 6-49, 6-64 Libraries, shared 1-42 Library functions decadd( ) C-40 deccmp( ) C-41 deccopy( ) C-42 deccvasc( ) C-28 deccvdbl( ) C-38 deccvflt( ) C-36 deccvint( ) C-32 deccvlong( ) C-34 decdiv( ) C-40 dececvt( ) C-43 decfcvt( ) C-43 decmul( ) C-40 decsub( ) C-40 dectoasc( ) C-30 dectodbl( ) C-39 dectoflt( ) C-37 dectoint( ) C-33 dectolong( ) C-35 LIKE keyword Boolean expressions 6-82 DEFINE statement 2-16, 4-73, 4-83 DISPLAY LIKE attribute 6-23, 6-48 FORMONLY fields 6-23 INITIALIZE statement 4-156 RECORD data type 3-35, 4-88 string operator 5-38 VALIDATE LIKE attribute 6-23, 6-65 VALIDATE statement 4-373 LINE keyword OPEN WINDOW statement 4-285 OPTIONS statement 4-307 REPORT statement 7-17 RUN statement 4-341 SKIP statement 4-346, 7-68 START REPORT statement 4-355 Line mode 4-91, 4-92, 4-359, 7-18 Line mode overlay 4-92, 5-48 Line number in a program array 5-29, 5-83
20
in a screen array 5-102, 6-74, 6-77 LINEFEED characters between statements 2-4 Linefeed key in ON KEY clause 4-48, 4-172 LINENO operator 5-94, 7-63 LINES environment variable D-55 LINES keyword NEED statement 4-276, 7-52 SKIP statement 4-346, 7-68 Link-time errors 4-16 LINUX operating system G-2 LIST data type 3-7 Literal quotation marks 2-4 Literal values DATE data type 3-75, 4-368 DATETIME data type 3-78, 4-368 in SQL I-39, I-41 integers 3-65 INTERVAL data type 3-82, 4-368 numbers 3-67, 4-368 LOAD statement interrupting 4-302 specifying field delimiter with DBDELIMITER D-20 syntax and description 4-230 Local variables 2-17, 4-82, 4-144, 4-246, 4-334, 7-10, 7-68 -localcurs option 1-40, 1-78 Locales assumption about Intro-6 client E-10, E-27 consistency checking 4-73 server E-10, E-26 Localization defined E-2 guidelines E-20 Localized collation order 5-40, E-4 LOCATE statement 3-39, 4-239 LOCK TABLE statement with LOAD 4-235 Logfile names 2-16, E-13 Logging error messages 5-65, 5-110 transactions 4-130, 4-136, 4-383 Logical characters 3-16, 3-41, 5-114, E-4, E-16 Logical operators 3-55, 5-33, 5-44 .login file D-2
Long data type (of C) C-34, C-35 LOOKUP attribute of PERFORM 6-92 Loops FOR statement 4-128 FOREACH statement 4-131 using CONTINUE 4-67 WHILE statement 4-382 Lossy conversion E-35 Lowercase characters DOWNSHIFT attribute 6-49, B-7 DOWNSHIFT( ) 5-59 in field tags 6-18 in identifiers 2-3, 2-14 names of C functions 5-7 SHIFT attribute B-7 UPSHIFT attribute 6-64, B-7 UPSHIFT( ) 5-121 lp utility D-6 LPATH environment variable 1-45, D-67 lpr utility D-6 LVARCHAR data type 3-7
M
m symbol in format strings 5-127, 6-51 M symbol, DBDATE D-17 MAGENTA attribute 3-96, 6-37, 6-82 MAIN statement in source-code modules 1-38 preceded by DATABASE 4-74 syntax 4-245 uniqueness 2-11 make utility D-12, D-44 Makefiles 1-34 Mangled name 5-54 Mantissa DECIMAL data type 3-24, C-26 FLOAT data type 3-26 SMALLFLOAT data type 3-38 Mapping files E-38 MARGIN keyword BOTTOM MARGIN clause 4-360, 7-15 LEFT MARGIN clause 4-360, 7-16
RIGHT MARGIN clause 4-360, 7-19, 7-65 TOP MARGIN clause 4-360, 7-20 WORDWRAP operator 5-135, 7-65 MATCHES keyword Boolean operator 5-38 in syscolatt table 6-82 with COLOR attribute 6-37 MAXCOUNT attribute 4-194 Maximum size BYTE or TEXT data type 3-12 CHAR or NCHAR data type 3-11 DATE data type 3-11 INTEGER data type 3-10 SMALLINT data type 3-10 VARCHAR or NVARCHAR data type 3-11 MAX( ) aggregate function 2-47, 7-61 MDY( ) operator 5-95 Member of input record 4-308 of program record 3-35, 4-88 Membership ( . ) operator 5-97 MEMORY keyword in LOCATE statement 4-241 Memory management CLOSE FORM statement 4-31 CLOSE WINDOW statement 4-32 FREE statement 4-243 Large variables 4-243 Menu help line 2-23, 2-25, 4-256 line 2-25, 4-114, 4-249, 4-288 option names 2-23 options of Programmers Environment 1-9, 1-33 Menu form files D-23 Menu items E-15 MENU keyword BEFORE MENU clause 4-252 CONTINUE MENU statement 4-66, 4-259 END MENU statement 4-263 EXIT MENU statement 4-259 OPEN WINDOW statement 4-285
Index 21
OPTIONS statement 4-293 MENU LINE keywords OPTIONS statement 4-293 Menu options disabled 2-25, 4-260, 4-268 hidden 2-24, 4-260 invisible 2-24, 4-257 MENU statement 4-248 COMMAND KEY conflict 4-272 Menus of 4GL in a national language D-23 MENU statement 2-23 menu title 2-23 nested 2-23 Message files B-2, D-28 line 2-27, 4-114, 4-273, 4-288 numbers in help files 5-106, B-2 Message Compiler B-2, E-11 MESSAGE keyword MESSAGE statement 4-273 OPEN WINDOW statement 4-285 OPTIONS statement 4-293 MESSAGE LINE keywords OPEN WINDOW statement 4-285 OPTIONS statement 4-293 MESSAGE statement 4-273 Method 5-5 Minus ( - ) sign comment indicator 2-8, 4-314 DATETIME separator 3-22 in format strings 5-125 in literal numbers 3-67, C-28 in window border 6-21, F-7 INTERVAL literals 3-29, 3-82 INTERVAL separator 3-32 subtraction operator 3-54, 3-84, 4-289, 4-295, 5-23, 5-26 unary operator 3-54, 3-66 MINUTE keyword DATETIME qualifier 3-19, 3-76 INTERVAL qualifier 3-29, 3-80 MIN( ) aggregate function 2-47, 5-16, 7-61 Mismatch handling E-37 mkdir command D-30
mkmessage utility 1-10, 1-51, 4-196, 4-299, 5-107, B-2 MODE keyword OPTIONS statement 4-307 REPORT statementt 7-17 RUN statement 4-341 START REPORT statement 4-355 Modify option FORM Menu 1-16, 1-57, 6-86 MODULE Menu 1-11, 1-51 PROGRAM Menu 1-21, 1-63 Modular scope operator 2-22 Module compiling 1-14, 1-54 option of INFORMIX-4GL Menu 1-10, 1-50 running multi-module programs 1-15, 1-55, 1-82 variables 2-17, 4-82, 4-246 MODULE Menu 1-28, 1-69 Modulus (MOD) operator 3-54, 3-64, 3-66, 3-83, 5-23, 5-25, 5-26 MONETARY locale specification 4-101, 5-129 MONEY data type data type conversion 3-42, 3-47 declaration 3-9, 4-85 default value 6-45 description 3-33 display width 4-94, 6-89, 7-58 formatting with DBFORMAT 5-124 in input files 4-231 in output files 4-368 in report output 7-58 literal values 3-67 Monochrome terminals 3-97 Month abbreviations 5-129 MONTH keyword CURRENT operator 5-51 DATETIME qualifier 3-19, 3-76 EXTEND( ) operator 5-68 INTERVAL qualifier 3-29, 3-80 MONTH( ) operator 5-98 UNITS operator 5-119 MONTH( ) operator 5-98 Multibyte locale 3-16, 3-41, E-16 Multiple-form programs 4-68
Multiple-module programs, compiling 1-14, 1-29, 1-54, 1-64, 1-71, 1-80 Multiple-segment fields description of 6-31 in WORDWRAP fields 6-67 with CONSTRUCT 4-62 with INPUT 4-182 Multiple-statement PREPARE 4-75, 4-322 Multiple-table forms 6-23 screen records 6-79 views 6-26 Multiplication ( * ) operator 3-18, 3-44, 3-83, 5-23, 5-26, F-14 MULTISET data type 3-7 myutil object 1-44
N
NAME keyword CONSTRUCT statement 4-38 DISPLAY statement 4-90 INPUT statement 4-164 Name mangling 5-53 Name scope 2-17 Name space 2-19 Named values 3-57, E-12 Naming conventions display fields 6-26, 6-27, 6-29 field tags 6-18 Naming rules 4GL identifiers 2-14 databases 4-71 SQL identifiers 2-14 NCHAR data type 3-17, 3-33, 3-41, 5-40, E-4 display width 4-94 NEED statement 4-276, 7-52 Nested and recursive operations early exits 2-36 Nested input 2-31 nettype field 4-77 Network environment variable SQLRM D-64 SQLRMDIR D-65
22
New option FORM Menu 1-18, 1-59 MODULE Menu 1-13, 1-53 PROGRAM Menu 1-24, 1-65 NEWLINE character in TEXT values 3-39, 3-71, 4-231, 4-368 in VARCHAR values 4-231, 4-368 in WORDWRAP fields 4-183, 6-69 input record separator 4-232 output record separator 4-368 report output 7-22, 7-66 Next key F-6, F-26 menu option 5-106 NEXT FIELD keywords CONSTRUCT statement 4-52 INPUT ARRAY statement 4-212 INPUT statement 4-176 NEXT keyword CONSTRUCT statement 4-52 MENU statement 4-260 OPTIONS statement 4-293 Next Page key DISPLAY ARRAY statement 4-111 INPUT ARRAY statement 4-206 OPTIONS statement 4-299 NEXTPAGE keyword 4-299 nm utility D-51 NO keyword OPTIONS statement 4-294 NOENTRY attribute 4-41, 6-57 Non-alphanumeric characters 2-16 Non-ASCII characters 1-8, 2-15, E-12 Non-composite Thai characters E-10 Nondestructive backspace 4-219 Non-English characters E-36 Non-executable statements 2-6 Non-local database 3-90 Nonprintable characters E-12 Non-significant characters 2-4 NORMAL attribute 3-96, 6-82 Normal error scope 2-41, 2-44 Normalized form of DECIMAL values C-26
NOT FOUND keywords in WHENEVER statement 4-376 NOT keyword Boolean operator 3-55, 5-33, 5-44 NULL test 3-58, 5-37 range test 5-41 set membership test 5-41 WHENEVER statement 4-379 NOT NULL keywords COLOR attribute 6-39 FORMONLY fields 6-29, 6-30 IS operator 5-34 NOTFOUND condition FOREACH statement 4-132 PREPARE statement 4-322 NOTFOUND keyword contrasted with NOT FOUND keywords 4-379 global scope 2-18 status after SELECT 2-46 with FOREACH 4-132 NOUPDATE attribute of PERFORM 6-92 NULL keyword COLOR attribute 6-38 DATABASE section 6-12 FORMONLY fields 6-30 INCLUDE attribute 6-53 INITIALIZE statement 3-93, 4-157 LET statement 4-226, 4-227 Null values aggregate functions 2-47, 5-16, 7-61 as default 4-163, 4-190 in ASCII files 4-232, 4-369 in Boolean expressions 4-129, 5-37, 6-39 in comma-separated lists 4-228 in concatenated strings 4-228 in concatenation 5-50 in display fields 6-30, 6-45, 6-53, 6-62 in number expressions 3-66 in reports 5-32, 7-62 in time expressions 3-85, 5-22 LET statement 4-228 searching for NULL 4-57
with arithmetic operators 3-64, 5-22 with logical operators 5-33 with relational operators 3-62, 5-34 with string comparisons 5-38 WITHOUT NULL INPUT 6-14 Number expression formatting 5-124, 6-50 syntax and description 3-66 Number of rows processed 2-46 Numeric color codes 5-71 date 3-75 date and time 3-78, 5-20 time interval 3-82, 5-20 NUMERIC data type 3-34 NUMERIC locale specification 4-101, 5-129 NUM_ARGS( ) 5-99 NVARCHAR data type 3-34, 3-41, 5-40, E-4 display width 4-94
O
Object file 1-47, 1-64, 1-91, B-4 OF keyword AFTER GROUP OF control block 7-34 BEFORE GROUP OF control block 7-37 DEFINE statement 4-87 REPORT statement 4-334 SKIP statement 4-346, 7-68 TOP OF PAGE clause 7-22 VARIABLE statement 4-87 WHERE CURRENT OF clause 5-54 OFF keyword OPEN WINDOW statement 4-290, 6-44 OPTIONS statement 4-294 ON DELETE CASCADE keywords ALTER TABLE statement 4-316 CREATE TABLE statement 4-316 ON EVERY ROW control block 7-42
Index 23
ON EXCEPTION statement 2-41 ON KEY keywords CONSTRUCT statement 4-47 DISPLAY ARRAY statement 4-106 INPUT ARRAY statement 4-205 INPUT statement 4-171, 5-107 PROMPT statement 4-329 ON keyword CONSTRUCT statement 4-39, 4-47 DISPLAY ARRAY statement 4-106 INPUT ARRAY statement 4-205 INPUT statement 4-171 OPTIONS statement 4-294 PROMPT statement 4-329 REPORT statement 4-334 ON LAST ROW block 4-125, 4-334, 4-364, 7-44 ONCONFIG environment variable D-56 onipcstr value in sqlhosts 4-77 On-line Help for developers Intro-18 Help for users 2-29 On-line manuals Intro-18 onload utility 4-233 OPAQUE data type 3-7 OPEN FORM statement 4-278 OPEN statement 4-315 interrupting 4-302 OPEN WINDOW statement 4-280 Operands of arithmetic operators 3-44, 3-66, 3-83, 5-26 Operating system invoking the Compiler from 1-37, 1-77 invoking the Programmers Environment from 1-27, 1-69, 1-75 Operators in 4GL statements compared with SQL operators 3-51 list of 5-12 query by example 4-59 Optical Subsystem statements 4-13 Optimizer directives 4-352
OPTION keyword GRANT statement 5-121 MENU statement 4-260 Options of 4GL menus 2-23 OPTIONS statement mkmessage utility B-2 SQL INTERRUPT 4-80, 4-301, 4-303 syntax 4-291 OR keyword 3-55 Boolean operator 5-33, 5-44 OR operator in query by example 4-59 ORDER BY clause REPORT statement 7-23, 7-37 SELECT statement 7-31 Order of screen fields 4-162, 4-190, 4-296 ORD( ) function 5-100 Other menu option 1-74 OTHERWISE keyword, CASE statement 4-24 Output from 4GL programs 7-3 record 4-368, 5-110 Output file STARTLOG( ) 5-110 UNLOAD statement 4-368 OUTPUT keyword OUTPUT TO REPORT statement 4-308 REPORT statement 4-332 START REPORT statement 4-357 OUTPUT section of REPORT statement BOTTOM MARGIN 7-15 DIRECTION 3-12, 3-18, 3-19, 3-36, 3-41, 3-72, 3-75, 5-74, 5-93, 5-114, 5-137, A-1 LEFT MARGIN 7-16 LEFT TO RIGHT 3-12, 3-18, 3-19, 3-36, 3-41, 3-72, 3-75, 5-74, 5-93, 5-114, 5-137, A-1 PAGE LENGTH 7-16 REPORT TO 7-17 RIGHT MARGIN 5-135, 7-19, 7-65 syntax 7-12 TOP MARGIN 7-20
TOP OF PAGE 7-21 OUTPUT TO REPORT statement 4-308, 7-5 Overflow in a display field 5-123 in data type conversion 3-42, 3-48, C-28, C-33, C-35, C-40 Overriding a Help message 4-43, 4-167, 4-196 Owner naming CONSTRUCT statement 4-41 DEFINE statement 3-36, 4-37, 4-83, 4-88 in ANSI-compliant database 3-90, 4-374, 6-24, 6-84 in form specification 6-9, 6-24 INITIALIZE statement 4-157 VALIDATE statement 3-90, 4-373
P
P symbol CENTURY 4-328, 6-35 DBCENTURY D-15 Page eject character 7-21 PAGE HEADER control block 4-354, 5-101, 7-41, 7-45 PAGE keyword FIRST PAGE HEADER control block 7-40 PAGE HEADER control block 7-45 PAGE LENGTH clause 7-16 PAGE TRAILER control block 7-47 SKIP statement 4-346, 7-68 START REPORT statement 4-360 TOP OF PAGE clause 4-346, 7-21, 7-68 PAGE LENGTH keywords 7-16 START REPORT statement 4-360 PAGE TRAILER control block 7-47 PAGENO operator 5-101, 7-47, 7-63 Pages of a help file message B-3 of a report 4-276, 4-346, 4-361, 7-13, 7-63, 7-66 of a screen form 6-16, 6-91
24
of menu options 4-266 of program array records 4-111 of reports 5-101, 5-136 Paper size E-19 Parameter-count checking D-11 Parameterizing a statement with SQL identifiers 4-321 Parentheses ( ( ) ) symbols Boolean expressions 5-33 CHAR data types 3-16 function calls 3-54, 5-6 IN operator 6-40 in USING format strings 5-125 INTERVAL values 3-28, 3-80 LOAD column list 4-230 SPACE operator 5-108, 7-64 UNITS operator 3-85, 5-23, 5-119 Partial characters 5-114, E-17 Passing by reference BYTE or TEXT function arguments 3-15, 3-39, 4-243, 5-9, C-8 BYTE or TEXT report arguments 3-15, 4-243, 4-309 PATH environment variable D-67 Pathname LOAD statement 4-230 non-English characters E-14 specifying with DBPATH D-32 specifying with PATH D-67 UNLOAD statement 4-367 Pattern matching 4-59, 5-39 PAUSE statement 4-311, 7-54 P-code 2-44 P-code runner customized 1-86, 1-87 Interactive Debugger 1-75 specifying name and location 1-64 using 1-77 P-code version number 1-78, 1-81, 1-88 PDQPRIORITY environment variable D-57 Peoples Republic of China E-8, E-9 Percent ( % ) symbol wildcard with LIKE 5-39 PERCENT( * ) aggregate function 5-16, 7-61
PERFORM forms 6-91 PERFORM (INFORMIX-SQL) forms with 4GL 6-91 Period ( . ) symbol DATETIME separator 3-78, 3-82 DECIMAL values 3-67 FLOAT values 3-26, 3-38 Help message numbers 2-31 in Help files 2-31, 5-106, B-2 in USING format string 5-124 INTERVAL separator 3-80 membership operator 5-97 MONEY values 3-67 prefix separator 3-36, 3-80, 3-89, 6-24 range operator 4-59 RECORD member 3-58 SMALLFLOAT values 3-38 -phase option 1-36 PICTURE attribute 6-58, 6-59, 6-60 Pipe D-63 PIPE key word START REPORT statement 4-359 PIPE keyword REPORT statement 7-17 PIPE keyword in REPORT TO clause 7-17 Pipe ( | ) symbol 4-233, 4-369, F-24 Planned_Compile option, PROGRAM Menu 1-25, 1-66 Platform icons Intro-10 Plus ( + ) sign addition operator 3-54, 3-84, 4-289, 4-295, 5-23, 5-26 in format strings 5-125 in optimizer directives 4-352 in window border F-7 RECORD declarations 3-35, 4-88 unary operator 3-54, 3-66, 5-125, C-28 Portugese language 4-101 Positioning a window 4-282 DISPLAY output 4-92 reserved lines 4-288 POSIX library G-1 Pound ( # ) sign comment indicator 2-8, 4-352, B-2, F-3
in format strings 6-50, 6-58 in USING masks 5-124 prdate( ) 1-89 Precedence in 4GL operators 5-44 in arithmetic operations 3-64 in default values 4-162, 4-190 in display attributes 3-98, 4-42, 6-83 in display elements 5-71 of identifiers 2-19 Precision DATETIME data type 3-76, 5-51, 5-67 DECIMAL data type 3-24, 3-43 FORMAT attribute 6-50 in arithmetic operations 3-43 INTERVAL data type 3-80 MONEY data type 3-32, 3-43 PRECISION keyword 3-25 Predefined identifiers 2-18, 2-19 PREPARE statement increasing performance efficiency 4-323 multi-statement text 4-318, 4-321 parameterizing a statement 4-319 parameterizing for SQL identifiers 4-321 query by example 4-36 question (?) mark as placeholder 4-312 statement identifier use 4-313 syntax and description 4-312 valid statement text 4-314 variable list 3-37 with DATABASE 4-75 with LOAD 4-230 with UNLOAD 4-367 with . * notation 3-94 Prepared statement prepared object limit 4-313 valid statement text 4-314 Prepared statement name E-14 Preprocessor, invoking 1-34, 1-37 Previous key F-6, F-26 PREVIOUS keyword CONSTRUCT statement 4-52 INPUT statement 4-176 OPTIONS statement 4-294
Index 25
Previous Page key DISPLAY ARRAY statement 4-111 INPUT ARRAY statement 4-206 OPTIONS statement 4-299 PREVPAGE keyword 4-299 Print position 4-346 PRINT statement CLIPPED operator 5-45 in a report 7-55 syntax and description 4-324 USING 5-128 Printable characters 3-71, 5-84, E-12 printenv utility D-4 PRINTER keyword REPORT statement 7-18 REPORT TO clause 7-17 START REPORT statement 4-357 Printing and DBPRINT D-35 Privilege Insert 4-231 Select 4-367 table-level 4-231, 4-367 Procedure 5-5 Product icons Intro-10 .profile file D-2 Program examples that call C functions 1-88 flow control statements 4-14 organization statements 4-13, 4-14 specification database 1-20, 1-61 Program array ARR_COUNT( ) 5-27, 5-29, 5-83 ARR_CURR( ) 5-29, 5-83 displaying 4-102 SET_COUNT( ) 5-104 PROGRAM attribute 6-33, 6-60, 6-89 Program block FUNCTION 4-140 MAIN 4-245 REPORT 7-7 scope of statement labels 4-151, 4-224, 4-380 scope of variables 4-82, 4-334, 7-10 three kinds of 2-10
Program execution commencing 1-75, 1-81, 5-19, 5-99 from the command line 1-5, 5-19 programs that call C functions 1-47, 1-83 terminating 5-64 with the Interactive Debugger 1-82, 1-90 Program features calling C functions 1-83 calling functions 4-16 commenting 2-8 compiler 1-35, 1-52 compiling through Programmers Environment 1-11 compiling, at operating system level 1-77 conditional statements 4-22, 4-26, 4-382 data validation 4-373 error messages 5-61, B-4 help messages 5-106, B-2 identifiers 2-14 letter case sensitivity 6-18 multi-module programs 1-14, 1-54 operating system pipes 4-359, 7-18 owner naming 3-89, 6-24 procedural statements 4-13 program arrays 4-102, 4-105, 4-192 program design database 1-61 reports 7-4 running at command line 1-80 screen interaction statements 4-291 screen records 6-75 SQL statements 4-9 suspending execution 4-348 transaction logging 4-130, 4-136, 4-383 types of program modules 1-11, 1-23, 1-32, 1-36, 1-64, 1-87 Program flow control statements 2-6 PROGRAM keyword EXIT PROGRAM statement 4-121 PROGRAM attribute 4-185, 4-218
Program record data entry 4-187 declaration 4-88 Programmers Environment accessing 1-5, 1-9, 1-49 COMPILE FORM Menu 1-17, 1-58 COMPILE MODULE Menu 1-11, 1-52 COMPILE PROGRAM Menu 1-24, 1-66 compiling a form 1-29, 1-71, 6-86 compiling a program 1-14, 1-29, 1-54, 1-71 correcting errors in a program 1-12, 1-53 creating a default form 6-86 database name D-58 Debug option, MODULE Menu 1-55 Debug option, PROGRAM Menu 1-67 defining a program 1-28, 1-69 definition of 1-4 Drop option, PROGRAM Menu 1-26 Exit option, FORM Menu 1-19, 1-60 Exit option, MODULE Menu 1-15, 1-56 Exit option, PROGRAM Menu 1-26, 1-68 files displayed 1-28, 1-80 FORM Menu 1-15, 1-56 Generate option, FORM Menu 1-18, 1-59 in C Compiler version of 4GL 1-9 in Rapid Development System 1-49 INFORMIX-4GL Menu 1-9, 1-50 invoking the Debugger 1-51, 1-67 menu options 1-76 modifying a form specification file 1-16, 1-57 MODULE Menu 1-10, 1-50 NEW FORM Menu 1-18, 1-59 NEW MODULE Menu 1-13, 1-54 NEW PROGRAM Menu 1-24, 1-65
26
Planned_Compile option, PROGRAM Menu 1-25, 1-66 PROGRAM Menu 1-20, 1-61 Program_Compile option, MODULE Menu 1-14, 1-54 QUERY LANGUAGE Menu 1-27, 1-68 Run option, MODULE Menu 1-14, 1-55 Run option, PROGRAM Menu 1-26, 1-67 Undefine option, PROGRAM Menu 1-68 Program_Compile option, MODULE Menu 1-14, 1-54 PROGRAM_DESIGN_DBS environment variable 1-20, D-58 Promotable locks 4-132 PROMPT keyword END PROMPT statement 4-331 OPEN WINDOW statement 4-285 OPTIONS statement 4-293 PROMPT statement 4-325, 6-36 Prompt line 4-114, 4-288, 4-326 PROMPT LINE keywords OPEN WINDOW statement 4-285 OPTIONS statement 4-293 PROMPT statement CENTURY attribute 6-36 syntax and description 4-325 Prototype of a function 5-8 of a report 7-8 Pseudo-code Intro-5, 1-3 Psort utility D-61 PSORT_DBTEMP environment variable D-60 PSORT_NPROCS environment variable D-61 PUBLIC keyword of GRANT 1-20 PUBLIC keyword of GRANT statement 1-61 Public owner name 2-17
Q
Qualifiers database name 3-89, 4-37, 4-83 DATETIME declaration 3-9, 4-85 DATETIME literals 3-20, 3-78, 4-231 INTERVAL declaration 3-9, 4-85 INTERVAL literals 3-29, 3-80, 4-231 of column names 3-89, 4-41, 4-83 of DATETIME values 5-67 of field names 3-86, 3-89, 6-27 of table names 3-89, 4-40, 4-83, 6-24 owner name 3-89, 4-37 Query by example CONSTRUCT statement 4-34 range operator 4-59 Query optimization information 4-12 QUERYCLEAR attribute of PERFORM 6-92 Query-design plan 4-135 Querying the database joins 3-90, 6-92 query by example 6-56, 6-57 Question ( ? ) mark as placeholder in PREPARE 4-312 in WORDWRAP fields 6-73 key in MENU statement 2-30 wildcard with CONSTRUCT 4-59 wildcard with MATCHES 5-38 Quit key with DEFER 4-78 with DISPLAY ARRAY 4-111 with INPUT 4-186 with INPUT ARRAY 4-222 with MENU 4-249, 4-268 with PROMPT 4-330 QUIT keyword, DEFER statement 4-78 Quit signal 2-41, 4-342 quit_flag built-in variable 4-64, 4-78, 4-256, 4-300, 4-330 Quotation ( " ) marks around activation keys 4-256 around character pointer 1-85
around character strings 6-46, 6-54 around database specification 4-71 around DATETIME literals 3-22 around filenames 4-278, 4-355, 7-17, 7-57 around format strings 5-123, 6-50, 6-58 around INTERVAL literals 3-31 around pipe names 7-18 around SQL identifiers 2-15 around time values 6-46 single and double 2-4 Quoted string E-12 Quotient 5-25
R
R symbol CENTURY 4-328, 6-35 DBCENTURY D-15 r4gl command 1-5, 1-69, 6-85 r4gldemo script 1-5 Range of values ASCII characters 5-38 COLOR attribute 6-39 DATETIME values 3-77 INCLUDE attribute 6-54 INTERVAL values 3-81 number expressions 3-66, 5-22, 6-39 query by example 4-59 time expressions 6-39 upscol utility 6-82, B-9 Range test 5-41 Rapid Development System (RDS) version of 4GL 1-3, 1-49, D-11 Raw mode 4-307, 4-341 REAL data type 3-34 Record membership ( . ) operator 3-58 SQLCA global record 2-45 RECORD data type 3-35, 3-57, 4-20, 4-88, 4-227 RECORD keyword data type 3-35, 4-88 defining screen arrays 6-74, 6-77
Index 27
defining screen records 6-75 END RECORD declaration 3-35, 4-88 SCREEN RECORD specification 3-94 Rectangles in screen forms 5-72 Recursive input 2-31 Recursive statements 2-35 RED attribute 3-96, 6-37, 6-82 Redirect ( > ) symbol 1-80 REFERENCE data type 3-7 Reference line D-51 Related reading Intro-20 Relational operators 3-55, 3-61, 3-85, 4-57, 5-35, 5-36, 5-42, 5-43, E-14 Relay Module D-62, D-64 SQLRM environment variable D-64 SQLRMDIR environment variable D-65 Remainder in expressions 3-64 Remote tape devices D-37 REOPTIMIZATION keyword FOREACH statement 4-135, 4-349 OPEN statement 4-135, 4-349 Report aggregates 5-14 driver 4-125, 4-362, 7-5 execution statements 4-142, 4-245 operators 3-51, 3-56, 5-13 writer 7-4 REPORT keyword 4-308 END REPORT statement 7-8 EXIT REPORT statement 7-50 FINISH REPORT statement 4-125, 7-5 OUTPUT TO REPORT statement 4-308, 7-5 REPORT statement 7-8 START REPORT statement 4-354, 4-355, 7-5 TERMINATE REPORT statement 4-364 Report name E-14 REPORT statement control blocks 7-32 DEFINE section 7-9, 7-10
displaying a report 7-13 FORMAT section 7-9, 7-28 grouping data 7-33 indirect typing 7-11 NEED statement 7-52 ORDER BY section 7-9, 7-23 ORDER EXTERNAL BY 7-23 OUTPUT section 4-356, 7-9, 7-12 passing arguments to 4-308 PAUSE statement 4-311, 7-54 PRINT statement 4-324, 7-55 SKIP statement 4-346, 7-68 statements in a report definition 7-48 structure 7-9 syntax and description 4-332 with DATABASE 4-74 REPORT TO keywords 7-17 Reports aggregate functions 7-36 calculations on groups 5-17, 7-61 counting rows 5-16, 7-61 default layout 7-29 features 7-4 formatting 7-28, 7-32 output of a report 7-12 printing output 4-324, 7-55 prototype 7-8 sending output to a file 7-17 sorting data 7-23 REQUIRED attribute 6-62 Reserved lines clearing 4-29 Comment line 2-27, 4-61, 4-95, 4-288, 6-43 default locations 2-27, 4-114, 4-288 Error line 2-28, 4-61, 4-95, 4-119, 4-290, 5-63, 5-64 Form line 2-27, 4-114, 4-288 in current window 4-68 Menu help line 2-27 Menu line 2-25, 4-249 Message line 2-27, 4-273, 4-288 positioning 4-288, 4-289, 4-295, 5-72 Prompt line 2-27, 4-288, 4-331 Reserved values 3-26
Reserved words as identifiers 2-15 list for 4GL G-1 list for SQL G-2 Response time, poor D-22 Restricted shell D-36 Resume option Help menu 2-29 Help window 5-106 RETURN character in WORDWRAP reports 7-66 Return key in ON KEY clause 4-48, 4-172 in query by example 4-63 RETURN keyword OPTIONS statement 4-299 RETURN statement 4-19, 4-337 RETURN statement 4-19, 4-337 RETURNING keyword CALL statement 4-19 RUN statement 4-342 REVERSE attribute 3-96, 3-97, 4-119, 6-37, 6-63, F-11 Right brace ( } ) symbol 2-8 RIGHT keyword attribute of PERFORM 6-92 OPTIONS statement 4-299 RIGHT MARGIN keywords OUTPUT section 7-19 START REPORT statement 4-360 WORDWRAP operator 5-135, 7-65 Ring menu 2-23, 2-24, 4-248 rmacs setting 6-22 Role name 2-16 ROLLBACK WORK statement 4-236 interrupting transactions 4-303, 4-305 with LOAD 4-235 with WHENEVER 4-381 Rounding error 3-24, 3-42, 3-48, 3-68, 5-26, 6-50 Round-trip conversion E-37 ROW data type 3-7 ROW keyword DISPLAY ARRAY statement 4-105 EVERY ROW statement 7-29
28
INPUT ARRAY statement 4-192, 4-201, 4-210 ON EVERY ROW control block 7-42 ON LAST ROW control block 7-44 REPORT statement 4-334 ROWID keyword 2-46, 3-51 ROWS keyword in OPEN WINDOW statement 4-282 RUN keyword OPTIONS statement 4-307 Run option MODULE Menu 1-14, 1-55 PROGRAM Menu 1-26, 1-67 RUN statement 4-340 Runner command to invoke 1-76 creating a customized 1-87 specifying location of 1-64 using to execute p-code Intro-5, 1-3 Running a 4GL program command line 1-5, 1-46 that calls C functions 1-47, 1-90 using Debugger 1-76 Russian language E-21
S
SA symbol in format strings 6-58 Scale DATETIME data type 3-76, 5-51 DECIMAL data type 3-9, 3-24, 3-43, 4-85, C-43 FORMAT attribute 6-50 INTERVAL data type 3-80 MONEY data type 3-9, 3-32, 4-85 Scope of reference 4GL identifiers 2-17 4GL windows 4-281 global variables 2-18, 4-147 identifiers of form entities 2-18 program variables 2-17, 2-19, 4-145, 4-246 screen array 6-79 screen form 2-18, 4-31 screen record 6-76
SQL identifiers 2-19 statement identifier 4-314 Screen clearing F-5, F-25 default attributes B-8 interaction statements 4-14 menu option 5-106 option of Help menu 2-29 Screen array clearing 4-30 cursor movement 4-219 declaring 6-77 format of 6-20 identifying the current row 5-29, 5-83, 5-102 scrolling 4-219, 4-344 syntax and description 6-77 testing with FIELD_TOUCHED( ) operator 5-81, 5-83, 5-84 Screen form closing 4-279 current 4-160, 4-188 scope of reference 2-18 specifying from the Programmers Environment 1-15, 1-56, 6-85 SCREEN keyword CLEAR SCREEN statement 4-29 CLEAR WINDOW SCREEN statement 4-29 CURRENT WINDOW statement 4-68 INSTRUCTIONS section 6-9 referencing the default window 2-28 REPORT statement 7-19 SCREEN section 6-15 START REPORT statement 4-357 Screen record clearing 4-30 default screen record 6-76 in field clause 5-87, 5-97 order of components 3-94, 4-40, 4-190, 6-76 scope of reference 6-76 within a screen array 4-344, 6-79 SCREEN RECORD keywords 5-84, 6-74, 6-75, 6-77
SCREEN section of form specification display field 6-17 field delimiters 6-80 field labels 6-19 field length 6-89 field tags 6-25, 6-27, 6-29, 6-90 graphics characters 6-21 screen layout 6-17 syntax 6-15 SCROLL keyword DECLARE statement 4-132 SCROLL statement 4-344 SCROLL statement 4-344 Scrolling keys 4-219 SCR_LINE( ) function 5-102 with DISPLAY ARRAY 4-109 with INPUT ARRAY 4-215 SECOND keyword DATETIME qualifier 3-19, 3-76 INTERVAL qualifier 3-28, 3-80 SELECT keyword GRANT statement 4-367 INSERT statement 4-234 SELECT statement 5-10 Select privileges 4-367 SELECT statement copying rows to an ASCII file 4-367 displaying results 7-4 interrupting 4-302 query by example 4-36 requiring no cursor 5-10 restrictions with INTO clause 4-314, 4-350 Semicolon ( ; ) symbol delimiter with PREPARE 4-314 in a field description 6-26 in PRINT statements 7-46, 7-58 statement delimiter 2-5, 2-7, 4-352 Separators E-16 Sequence of characters sent by function and arrow keys D-21 SERIAL data type as INTEGER variables 3-7, 3-27, 4-83 display fields 6-57 in input files 4-232
Index 29
in program records 3-35 in UPDATE statement 3-94 INSERT statement 6-57 SQLCA.SQLERRD[2] 2-46 SERIAL8 data type 3-7 Server locale E-10 SERVER_LOCALE environment variable E-24 SET AUTOFREE statement 4-351 SET CONNECTION statement 4-349 SET CONSTRAINT statement 4-238 SET data type 3-7 SET DEFERRED_PREPARE statement 4-351 SET DESCRIPTOR statement 4-351 SET INDEX statement 4-238 Set membership test 4-59, 5-41 SET TRIGGER statement 4-238 Setting environment variables D-4 SET_COUNT( ) function 5-104 with DISPLAY ARRAY 4-103 sg1 terminal specification F-4, F-21 sg#1 capability 4-42 -shared option 1-44, D-10 Shared library 1-42, 1-43 Shared memory 4-77, D-49, D-56 Sharp ( # ) symbol. See pound sign. Shell and DBREMOTECMD D-36 Bourne shell D-2 C shell D-2 default remote shell D-36 Korn shell D-2 SHLIB_PATH environment variable 1-45, D-67 SHOW keyword, MENU statement 4-261 SHOWHELP( ) function 5-106, B-3 ON KEY clause 2-29, 4-43, 4-167, 4-196 Signals Interrupt 4-78 Quit 4-78, 4-303 SIGQUIT signal 4-303 Simple data type 3-9, 4-85
Single-byte locale E-16 Single-character fields 6-90 Single-precision floating-point number, storage of 3-25 SIZE keyword, form specification 6-16 SKIP statement 4-346, 7-68 SKIP TO TOP OF PAGE D-43 Slash ( / ) symbol database specification 4-71 DATE literals 3-17, 3-44 division operator 3-54, 3-84, 5-23, 5-26 SLEEP statement 4-348 smacs setting 6-22 SMALLFLOAT data type data type conversion 3-42, 3-47 declaration 3-9, 4-85 description 3-37 display width 6-89, 7-58 FORMAT attribute 6-50 literal values 3-38, 3-67 SMALLINT data type conversion 3-42 data type conversion 3-47 declaration 3-9, 4-85 description 3-38 display width 6-89, 7-58 in report output 7-58 literal values 3-67 Software dependencies Intro-5 SOME keyword in SQL Boolean operator 3-51 Sorting data in a query E-14 in a report 7-23, E-14 PSORT_DBTEMP environment variable D-60 with a cursor 7-27 Source compiler 4-374 modules 1-35, 1-77, 1-79 path 1-64 Source code debuggers 1-41 SPACE or SPACES operator 5-108 Spacebar 4-268 Spanish language E-21 SPL expressions 3-51 SPL statements 4-317, 4-351
SQL built-in functions 5-5, 5-7 INTERRUPT option 4-80, 4-301, 4-303 keyword in OPTIONS statement 4-294 statement delimiters 2-5, 4-349 version number 1-38, 1-78, 1-81, 1-88 SQL identifiers 2-16, E-13 SQL keyword OPTIONS statement 4-303 SQL statement delimiter 4-350 SQL language accessing from the Programmers Environment 1-27, 1-68 concurrency control 4-132 cursor manipulation statements 4-11, 4-12, 4-13, 4-14 data access statements 4-12, 4-13, 4-14 data definition statements 2-7, 4-11, 4-12, 4-13, 4-14 data integrity statements 4-12, 4-13, 4-14 data manipulation statements 2-19, 4-11, 4-12, 4-13, 4-14 data types 3-7 expressions 3-51 interactive query language 1-50, 6-91 interrupting statements 4-80, 4-301, 4-303 operators 3-51 query optimization statements 4-12, 4-13, 4-14 testing statement execution 2-45 transaction logging 4-136, 4-235 views 4-83 SQL statements ALTER INDEX I-2 ALTER TABLE I-2 BEGIN WORK I-4 CLOSE I-4 CLOSE DATABASE I-4 COMMIT WORK I-4 CREATE AUDIT FOR I-5
30
CREATE DATABASE I-5 CREATE INDEX I-6 CREATE PROCEDURE FROM I-6 CREATE SYNONYM I-6 CREATE TABLE I-7 CREATE VIEW I-9 DATABASE I-9 DECLARE I-10 DELETE FROM I-10 DROP AUDIT I-11 DROP DATABASE I-11 DROP INDEX I-11 DROP SYNONYM I-11 DROP TABLE I-11 DROP VIEW I-11 EXECUTE I-12 FETCH I-12 FLUSH I-12 FREE I-14 GRANT I-15 INSERT INTO I-16 LOAD FROM I-17 LOCK TABLE I-18 OPEN I-18 PUT I-18 RECOVER TABLE I-18 RENAME COLUMN I-19 RENAME TABLE I-19 REVOKE I-19 ROLLBACK WORK I-20 ROLLFORWARD DATABASE I-20 SELECT I-20 SET EXPLAIN I-25 SET ISOLATION I-25 SET LOCK MODE I-25 SET LOG I-25 START DATABASE I-25 UNLOAD I-26 UNLOCK TABLE I-26 UPDATE I-26 UPDATE STATISTICS I-27 WHENEVER I-28 SQLAWARN characters 2-46 global record 4-75, 4-379 SQLAWARN[5] 3-42
SQLCA record SQLAWARN 1-41, 2-46, D-14 SQLCODE 2-46, 4-302 SQLERRD 2-46, 4-133, 4-234, 4-322 WHENEVER ERROR condition 4-378 SQLCODE global variable 4-302, 4-378 SQLERROR keyword 4-376, 4-378 SQLEXEC environment variable D-62 sqlhosts file 4-77 SQLRM environment variable D-64 sqlrm file D-62 SQLRMDIR environment variable D-65 SQLWARNING keyword 4-379 Stack argument C-3 START keyword START DATABASE statement D-33 START REPORT statement 4-354, 7-5, D-63 STARTLOG( ) 5-110 Statement blocks 2-12, 4-128 delimiter 2-7 labels 2-11, 2-18, 4-144, 4-151, 4-224 terminator 2-5 Statement identifier definition of 4-313 syntax in PREPARE 4-312 use in PREPARE 4-313 Statement label 2-18, E-14 Statement segments asterisk ( * ) notation 3-92 ATTRIBUTE clause 3-96 field clause 3-86 table qualifiers 3-89 THRU or THROUGH keywords 3-92 Statement syntax CALL 4-16 CASE 4-22, 4-26
CLEAR 4-22, 4-26, 4-28 CLOSE FORM 4-31 CLOSE WINDOW 4-32 CONSTRUCT 4-34 CONTINUE 4-66 CURRENT WINDOW 4-68 DATABASE 4-71 DEFER 4-78 DEFINE 4-81 DISPLAY 4-90 DISPLAY ARRAY 4-102 DISPLAY FORM 4-113 END 4-116 ERROR 4-118 EXIT 4-121 FINISH REPORT 4-125 FOR 4-128 FOREACH 4-131 GLOBALS 4-145 GOTO 4-151 IF 4-153 INITIALIZE 4-155 INPUT 4-159 INPUT ARRAY 4-187 LABEL 4-224 LET 4-226 LOAD 4-230 LOCATE 4-239 MAIN 4-245 MENU 4-248 MESSAGE 4-273 NEED 4-276, 7-52, 7-54 OPEN FORM 4-278 OPEN WINDOW 4-280 OPTIONS 4-291 OUTPUT TO REPORT 4-308 PAUSE 4-311, 7-54 PREPARE 4-312 PRINT 4-324, 7-55 PROMPT 4-325 REPORT 4-332, 7-7 RETURN 4-337 RUN 4-340 SCROLL 4-344 SKIP 4-346, 7-68 SLEEP 4-348 SQL 4-349 START REPORT 4-354, 4-355 TERMINATE REPORT 4-364
Index 31
UNLOAD 4-367 VALIDATE 4-372 WHENEVER 4-376 WHILE 4-382 Statement type compiler directive 4-13, 4-14 cursor manipulation 4-11, 4-12, 4-13, 4-14 data access 4-12, 4-13, 4-14 data definition 4-11, 4-12, 4-13, 4-14 data integrity 4-12, 4-13, 4-14 data manipulation 4-11, 4-12, 4-13, 4-14 definition and declaration 4-13, 4-14 executable 2-6 non-executable 2-6 program flow control 4-14 query optimization 4-12 report execution 4-14 screen interaction 4-14 storage manipulation 4-13, 4-14 Statements in reports NEED 4-276 PAUSE 4-311, 7-54 PRINT 4-324 SKIP 4-346 -static option 1-44 STATISTICS keyword D-40 Status code after data type conversion C-28 after program termination 4-123 of a child process 4-340 status variable 2-45 interrupting SQL statements 4-302 set to 100 4-132 VALIDATE statement 4-373 WHENEVER statement 4-378 with ERR_GET( ) 5-61, 5-63 with ERR_PRINT( ) 5-63 with ERR_QUIT( ) 5-64 stderr 2-40 stdout 2-40 STEP keyword in FOR statement 4-129 STOP keyword in WHENEVER statement 4-381
Storage manipulation statements 4-13, 4-14 Stored procedure 2-16, 4-381, E-13 Stored Procedure Language (SPL) 4-314, 4-318 stores7 database Intro-6 Stream-pipe connections 4-77 String comparison 3-55, 5-38, 5-43 String concatenation 3-55 String value NULL 6-30 substring 6-27 Strings character E-12 quoted E-12 -strings flag D-44 strings option of gcc D-12 Structure definition file, function 1-83 Structured data types 3-12, 4-86 programming 5-5 Structured query language (SQL) 2-5 stty utility 4-307, 4-341, D-12, D-55 Subroutine 5-5 Subscript of a character column 6-27 to specify array elements 3-13 to specify substrings 3-39 Substitution conversion E-37 Substring alignment of bytes E-18 description 5-113 expression 5-114 in a screen field 6-27 of character array elements 3-14 of character variables 4-228, 4-275 of TEXT values 3-39 Subtraction ( - ) operator in termcap F-14 number expressions 3-64, 5-26 precedence of 3-54 precision and scale 3-44 reserved lines 4-289, 4-295 returned values 5-23 time expressions 3-84, 5-26 SUM( ) aggregate function 2-47, 5-16, 5-128, 7-61
SUPOUTPIPEMSG environment variable D-63 Synonym 2-16, E-13 Syntax conventions description of Intro-12 icons used in Intro-13 Syntax diagrams, elements in Intro-13 Syntax of command line to compile a 4GL source file 1-37, 1-77 syscolatt table color and intensity values 6-82, B-8 creating 6-84, B-5 DISPLAY LIKE attribute 6-48 FGL_DRAWBOX( ) arguments 5-71 INPUT ARRAY statement 4-192 INPUT statement 4-166 precedence of attributes 6-83 schema 6-81 with FORM4GL 6-26, 6-80 syscolumns table 3-93, 4-39, 4-83, 4-234 syscolval table 4-164 as used by INITIALIZE 6-83 creating 6-84, B-5 data validation 6-83 INITIALIZE statement 4-156, 4-157 INPUT ARRAY statement 4-190 INPUT statement 4-162 schema 6-81 VALIDATE LIKE attribute 6-65 VALIDATE statement 4-374 with FORM4GL 6-26, 6-80 syspgm4gl database 1-20, 1-61, D-58 systables table 5-10 System calls G-2 System catalog syscolumns 4-83 systabauth 5-121 systables 5-10, 6-23 System clock CURRENT operator 5-51 DATE operator 5-56 EXTEND( ) operator 5-68 TIME operator 5-116
32
T
TAB character in report output 5-136, 7-66 in source code modules 2-4 in TEXT values 3-39, 3-71 TAB key in ON KEY clause 4-48, 4-172 in query by example 4-63 order of fields 4-61, 4-296 reassigning its function 4-48, 4-172 Table alias for table name 6-24 changing column data types 3-42 current 6-91 inserting data 4-230 locking 4-235 name 2-16, E-13 qualifiers 3-89, 4-40 reference 3-86, 4-37, 6-25 temporary 4-126, 5-15, 7-27 Table alias declaring 6-24 naming rules 2-14 qualifiers 3-89 scope of reference 2-18 TABLE keyword in LOCK TABLE statement 4-235 Table-based localization E-31 TABLES section of form specification description 6-9 syntax 6-23 Taiwanese E-8, E-9 Taiwanese eras 3-75, 3-79 TBCONFIG environment variable D-56 tbload utility 4-371 TEMP keyword, SELECT statement 4-318 Temporary files, and dbspace D-37
files, and DBTEMP D-38 tables, and DBSPACETEMP D-37 TERM environment variable D-69 TERMCAP environment variable D-70, F-8 termcap file 3-99, 4-42 and TERMCAP D-70 description F-2 graphics characters 6-21 rows or columns D-13, D-55 Terminal bell, ringing 4-118 Terminal code D-69 Terminal handling and TERM D-69 and TERMCAP D-70 and TERMINFO D-71 TERMINATE REPORT statement 4-364 Termination status 4-123, 4-341, 4-342 TERMINFO environment variable D-71, F-22, F-29 terminfo file 3-99, 4-42, 6-21, D-71, F-22 rows or columns D-13, D-55 terminal capability D-51 Text cursor in a field 6-7 in disabled fields 6-8 with CONSTRUCT 4-35 with DISPLAY ARRAY 4-103 with INPUT 4-162, 4-180 with INPUT ARRAY 4-219 with MENU 4-256 TEXT data type Boolean expressions 5-37, 6-39 data entry 4-185, 4-218 declaration 4-81 description 3-39 display fields 4-185, 6-60, 6-67 display width 6-89, 7-58 in expressions 3-58, 3-69 in input files 4-231 in program records 3-35, 4-88 in report output 7-58, 7-65 initializing 4-239 non-English characters E-12 passing by reference 4-18, 4-339 query by example 4-57
selecting a TEXT column 3-39 size limits 3-12 storing control characters 3-39 syscolval table 4-373 unprintable characters 3-71 See also BYTE or TEXT data. Text editor 1-12, 1-17, 1-34, 1-53, 1-58, 1-76, D-20 Text geometry E-15 Text labels E-15 TH 7.20 supplement E-8 Thai language E-10, E-15 THEN keyword, IF statement 4-153 Thousands separator 5-129, D-25, D-31, D-42 Threads D-61 THROUGH keyword 3-36, 3-92, 4-81, 6-77 THRU keyword 3-36, 3-92, 4-81, 4-97, 4-165, 6-77 th_th.thai620 E-10 tic utility F-22 tigetstr( ) D-51 Time data types 3-11, 3-72 Time expressions as operands 3-85, 5-23 description 3-74 formatting 5-123, D-39 TIME operator 3-51, 5-116 Time units in data type conversion 3-44 in DATETIME qualifiers 3-19, 3-77 in INTERVAL qualifiers 3-28, 3-81, 6-46 in numeric dates 3-17, 3-75, 5-56 with EXTEND( ) operator 5-67 with MDY( ) operator 5-95 Title of a menu 2-23 TO keyword DATETIME qualifier 3-19, 3-77, 6-46 DISPLAY statement 3-93, 4-90 EXTEND( ) operator 5-67 FOR statement 4-128 INCLUDE attribute 6-53 INITIALIZE statement 3-93, 4-157
Index 33
INTERVAL qualifier 3-28, 3-81, 6-46 OUTPUT TO REPORT statement 4-308, 7-6 REPORT TO clause 4-355, 7-17 SKIP statement 4-346, 7-68 START REPORT statement 4-355 UNLOAD statement 4-367, 4-368 WHENEVER statement 4-224, 4-376 TO PIPE clause D-63 TODAY operator 5-117, 6-47 TOP MARGIN keywords 7-20, 7-41 START REPORT statement 4-360 TOP OF PAGE clause OUTPUT section 7-22 SKIP statement 4-346, 7-68 TRAILER keyword, REPORT statement 7-47 Trailing blank spaces CLIPPED operator 5-45 VARCHAR values 3-41 Trailing currency symbol 5-129, D-25, D-30 Transaction logging explicit transactions 4-303, 4-304 For loops 4-130 FOREACH statement block 4-136 interrupting SQL statements 4-303 LOAD statement 4-236 singleton transactions 4-303, 4-304 while loading data 4-235 WHILE loop 4-383 with LOAD 4-235 Translation E-22 as part of localization E-2, E-20 checklist E-21 TRIGGER keyword SET TRIGGER statement 4-238 Trigger name 2-16 TRIM operator 5-50 TRUE (Boolean constant) 2-18, 3-61, 4-78, 4-383, 6-37 Truncation of data 2-47, 3-48, 4-103, 4-231, 5-25, 5-73, 6-69, 7-66 Turkish language E-9
Two-pass report 4-125, 4-126, 4-334, 4-364, 5-15, 7-27 TYPE keyword in FORMONLY fields 6-55 Types of statements 4GL statements 4-13 executable 2-6 non-executable 2-6 SQL statements 4-9 Typover editing mode 4-63, 4-181, 4-220
U
Unary minus ( - ) symbol 2-9, 3-54, 3-65, 3-67, 3-75, 5-22, 5-125 Unary plus ( + ) symbol 3-38, 3-54, 3-65, 3-67, 3-75, 5-22, 5-125 UNCOMPRESS keyword, WORDWRAP attribute 6-70 UNCONSTRAINED keyword in OPTIONS statement 4-61, 4-294, 4-296 Undefine option, PROGRAM Menu 1-68 Underflow conversion error 3-42, C-28, C-40 UNDERLINE attribute 3-96, 3-97, 6-37, 6-82, F-11 Underscore ( _ ) symbol E-13 in field tags 6-18 in identifiers 2-14 wildcard with LIKE 5-39 Units of time CURRENT operator 5-51 DATE operator 5-56 DATE values 3-17, 3-44, 3-75 DATETIME values 3-22, 3-44 DAY( ) operator 5-58 EXTEND( ) operator 5-68 INTERVAL values 3-27, 3-82 MDY( ) operator 5-95 UNITS operator 5-119 YEAR( ) operator 5-138 UNITS operator data type conversion 3-64 in arithmetic expressions 3-85, 5-23, 5-119
precedence 3-54 specifying a default value in a field 6-46 syntax and description 5-119 UNIX default print capability in BSD D-6, D-35 default print capability in System V D-6, D-35 sending output to a pipe 7-17 shell D-2 terminfo library support in System V D-51 viewing environment settings in BSD D-4 viewing environment settings in System V D-4 UNIX-based servers E-34 UNLOAD statement interrupting 4-302 specifying field delimiter with DBDELIMITER D-20 syntax and description 4-367 Unprintable characters 3-71, 5-136 Unsigned values 5-23 Untrappable errors 4-120 UP keyword SCROLL statement 4-344 syscolval table B-7 Updatable views 6-26 UPDATE keyword in DECLARE statement 4-132 statement, interrupting 4-302 UPDATE STATISTICS D-40 UPDATE SYSCOL Menu B-5 UPDATE statement 3-94 Uppercase characters DEFAULT attribute 6-46 DOWNSHIFT attribute 6-49, B-7 DOWNSHIFT( ) 5-59 in code set E-14 in field tags 6-18 in identifiers 2-3, 2-14 INCLUDE attribute 6-54 SHIFT attribute B-7 UPSHIFT attribute 6-64, B-7 UPSHIFT( ) 5-121
34
upscol utility 4-157, 4-374, 6-48, 6-81, 6-83, B-5 UPSHIFT attribute 6-33, 6-64, B-7 UPSHIFT( ) 5-121 USER keyword 3-51, 5-10 USING keyword EXECUTE statement 4-134 FOREACH statement 4-134 USING operator 5-123 USING operator DISPLAY statement 4-93 MESSAGE statement 4-274 PRINT statement 5-128, 7-57 syntax and description 5-123 Utility programs cc 1-37, D-12, D-44 chkenv D-3 DB-Access 1-27 dbaccessdemo7 Intro-6 emacs 6-61 env D-4 export D-4 gcc D-12, D-44 grep D-51 infocmp F-27 ldd 1-43 lp D-6 lpr D-6 make D-12, D-44 mkdir D-30 mkmessage 5-107, B-2 more Intro-19 nm D-51 onload 4-233 printev D-4 Psort D-61 stty D-12, D-55 tbload 4-371 tic F-22 upscol 6-80, B-5 vi 1-76, 6-61, D-6, D-20 U.S. English code set E-3
V
V command-line option 1-38, 1-78, 1-81, 1-88 VALIDATE LIKE attribute 6-23, 6-33, 6-65 VALIDATE Menu (upscol) B-7 Validate option B-5 VALIDATE statement 4-372, 4-378, 6-83 Validation errors 2-42, 4-373, 4-378 VALUES keyword in INSERT statement 4-234, 6-6 VARCHAR data type data type conversion 3-47 declaration 3-9, 4-85 display fields 6-58, 6-67 display width 6-89, 7-58 in input files 4-231 in report output 7-58 pattern matching 5-39 substrings 6-27 unprintable characters 3-71 Variables allocating 4-239 as operands 3-57 binding to database columns 6-6 declaring 4-81, 4-143, 4-246, 7-10 global 2-17, 2-18, 4-146 implicit names 4-88 in DATABASE statement 4-72 in REPORT statement 7-9 indirect typing 4-73, 7-11 local 2-17, 4-144, 4-246, 4-334 modular 2-17, 4-82 naming rules 2-14, E-14 scope of reference 2-17, 4-144, 4-246 status variable 2-45 uninitialized 4-227 visibility 2-19, 4-145 VERIFY attribute 6-33, 6-66 Version numbers of SQL software 1-38, 1-78, 1-81, 1-88 Versions of 4GL 1-3 Vertical ( | ) bar concatenation operator 5-50 default delimiter 4-233, 4-369 field separator in forms 6-80
graphics character F-7, F-28 in termcap specifications F-3 in window border F-7 vi utility 1-76, D-6, D-20 Video attributes 2-27, 3-96 View E-13 in form specification file 6-26 in FROM clause of CONSTRUCT 4-41 in INSERT clause of LOAD 4-230 in LIKE clause of DEFINE 4-83 name 2-16 Visibility of identifiers 2-19, 4-82, 4-144, 4-145
W
W warning character in SQLAWARN 2-46, 3-42, 4-75, D-14 WAITING keyword, RUN statement 4-343 Warning conditions 2-46, 3-42, 4-75 messages 1-38 WARNING keyword in WHENEVER statement 2-46, 4-376 Weekday abbreviations 5-129 WEEKDAY( ) operator 5-133 Western European languages E-9 WHEN keyword, CASE statement 4-23 WHENEVER statement ERROR keyword 4-224, B-4 GOTO action 4-224 syntax and description 4-376 versus GOTO statement 4-151 with ERROR statement 4-120 with LABEL statement 4-224 WHERE clause aggregate functions 5-16, 7-60 DELETE statement 5-54 pattern matching 4-59 query by example 4-36, 4-59 SELECT statement 4-34, D-28 UPDATE statement 5-54
Index 35
with COLOR attribute 5-40, 6-38, 6-92, B-9 WHERE keyword COLOR attribute 3-51, 6-37 Debugger command 4-123 SELECT statement 3-51, 4-38, 4-369 WHILE keyword in CONTINUE WHILE statement 4-67 WHILE statement 4-382 WHITE attribute 3-96, 6-37, 6-82 White-space characters 2-4, 3-16, 3-39, 3-41, E-4, E-13, E-17 Whole numbers 3-10 Wildcard symbols in syscolatt table 6-83 with LIKE 5-39, 5-134 with MATCHES 5-38 Window border F-7, F-27 clearing 4-29 closing 4-32 current 2-28 display attributes 3-98, 6-84 naming rules 2-14 opening 4-280 reserved lines 4-291 scope of reference 2-18 stack 2-28, 4-32, 4-68, 4-281 WINDOW keyword CLEAR WINDOW statement 4-29 CURRENT WINDOW statement 4-68 OPTIONS statement 4-298 WITH FORM clause in OPEN WINDOW statement 4-284 WITH keyword DECLARE statement 4-132 FOREACH statement 4-135 GRANT statement 5-121 OPEN statement 4-135 OPEN WINDOW statement 4-31, 4-282 WITHOUT DEFAULTS keywords INPUT ARRAY statement 4-191, 6-45 INPUT statement 4-163, 6-45 with SET_COUNT( ) 5-104
WITHOUT keyword INPUT ARRAY statement 4-191 INPUT statement 4-163 RUN statement 4-343 WITHOUT NULL INPUT keywords in DATABASE section 4-163, 4-190, 6-12, 6-45 Word length E-18 WORDWRAP keyword CONSTRUCT statement 4-62 INPUT statement 4-182 PRINT statement 7-65 WORDWRAP attribute 6-32, 6-33, 6-67 WORDWRAP operator 5-135 WORK keyword BEGIN WORK statement 4-303, 4-381 COMMIT WORK statement 4-235, 4-303 ROLLBACK WORK statement 4-235, 4-303, 4-381 WRAP keyword in OPTIONS statement 4-63, 4-294 Wrap-down method 5-137
Y4 symbols, DBDATE D-17 YEAR keyword CURRENT operator 5-51 DATETIME qualifier 3-19, 3-76, 6-30 EXTEND operator 5-68 INTERVAL qualifier 3-29, 3-80, 6-46 YEAR( ) operator 5-138 Years, abbreviated 4-328, 6-35, D-15 YEAR( ) operator 5-138 YELLOW attribute 3-96, 6-37, 6-82 YES keyword in syscolval table B-7 y-umlaut character 1-41
Z
-z option D-10, D-43 ZA function (termcap file) F-12, F-21 Zero as divisor 3-64, 5-25, C-40 as MOD operand 5-25 byte (ASCII 0) 3-72, 7-62 DATE to DATETIME conversion 3-44 DATE value 3-76 default INTERVAL value 3-46, 4-163, 4-190, 6-14, 6-45 default MONEY value 6-45 default number value 4-163, 4-190, 6-30, 6-45 entering SERIAL values 4-232 in Boolean expressions 3-60, 5-33, 6-40 in DBDATE values D-17 in output files 4-368 leading zero in numbers 3-16, 3-43 length of NULL strings 5-50, 5-92 midnight hour 3-77 or more characters, symbol for 4-59, 5-39 preserving leading zeros 3-16 scale in ANSI-compliant databases 3-25
X
X symbol in format strings 6-58 xmc#1 capability 4-42 terminal specification F-23 XOFF key 4-107, 4-172, 4-207, 4-300, 4-330 XOFF signal 4-48, 4-300 XON key 4-107, 4-172, 4-207, 4-300, 4-330 XON signal 4-48, 4-300 XPG3 categories 3-17 X/Open E-9
Y
y symbol in format strings 5-127, 6-51 in syscolatt table 6-82, B-8 Y2 symbols, DBDATE D-17 Y2K compliance 4-328, 6-35, D-15
36
scale in arithmetic 3-43 status code of SQL 2-46, 4-378, 4-383 terminal capability F-4 terminating C structures 1-85 trailing 3-43 WEEKDAY( ) value 5-133 zero fill ( & ) character 5-126 ZEROFILL attribute of PERFORM 6-92 ZHCN 7.20 supplement E-8 ZHTW 7.20 supplement E-8
Index 37