Specifies that the input file is a DEC Pascal or VAX Pascal
source file. If the /PASCAL qualifier is used on the command
line, the RDML preprocessor will assume a file extension of
".RPA" unless you specify otherwise in the file specification.
Format:
/PASCAL
Example:
$ RDML/PASCAL SALARY_PLAN
On Oracle Rdb for OpenVMS Alpha, Pascal users will need to compile
/ALIGN=VAX because RDML/PASCAL generates code that is byte aligned.
This is a permanent restriction.
1 – More
o RDML/Pascal does not generate the correct length for a character
string value expression in the form:
FOR E IN EMPLOYEES WITH E.LAST_NAME = ('T' | host_variable)
... some statements ...
END_FOR;
This statement generates an error from VAX Pascal, such as:
00470 0 0 RDB$PORT_FIELD_0 : VARYING[0] OF CHAR;
1
%PASCAL-E-MAXLENRNG, (1) Max-length must be in range 1..65535
%PASCAL-E-ENDDIAGS, Pascal completed with 1 diagnostic
To avoid this problem, construct the value needed before issuing the
query, using a method such as the following:
host_variable1 := 'T' + host_variable2;
FOR E IN EMPLOYEES WITH E.LAST_NAME = host_variable1
... some statements ...
END_FOR;
This method is recommended for all RDML statements when possible
because it generally improves the performance of the query.
o RDML/Pascal does not accept all possible valid Pascal host
language variables, and it issues the following error if one it
does not accept is encountered:
%RDML-W-HOST_VARIABLE, error detected in host variable syntax
The set of possible values is limited to the syntax described in the
RDML Reference Manual, with the restriction that the expression
allowed in an array index must be a simple name or expression.
The following illustrates an unacceptable statement:
FOR E IN EMPLOYEES WITH E.EMPLOYEE_ID = emparray[empstruct.index]
... some statements...
END_FOR;
In the preceding example, empstruct.index is a reference to a
structure member. To avoid this problem, you would assign
empstruct.index to an intermediate variable and use that variable
in the FOR statement WITH clause.