Операторы описания.......................................... 3-1
BYTE (однобайтное беззнаковое целое)................... 3-1
SHORT (двухбайтное целое со знаком).................... 3-2
USHORT (двухбайтное беззнаковое целое)................. 3-3
LONG (четырехбайтное целое со знаком).................. 3-4
ULONG (четырехбайтное целое без знака)................. 3-5
SREAL (четырехбайтное вещественное со знаком).......... 3-6
REAL (восьмибайтное вещественное со знаком)............ 3-7
DECIMAL (упакованное десятичное фикс. длины со знаком). 3-8
PDECIMAL (то же, что и DECIMAL)........................ 3-9
STRING (строка фиксированной длины).................... 3-10
CSTRING (строка фикс. длины, завершающаяся нулем)...... 3-11
PSTRING (строка со встроенным байтом длины)............ 3-12
DATE (четырехбайтная дата)............................. 3-13
TIME (четырехбайтное время)............................ 3-14
GROUP (составная структура данных)..................... 3-15
LIKE (определяемые пользователем типы данных).......... 3-16
Неявные переменные.......................................... 3-17
Элементы шаблонов........................................... 3-18
Отображение чисел и валюты............................. 3-18
Отображение научной нотации.(экспоненциальный формат).. 3-20
Отображения даты....................................... 3-21
Отображения времени.................................... 3-22
Отображение "по образцу"............................... 3-23
Key-in Template Pictures............................... 3-24
Отображения строк...................................... 3-26
Атрибуты переменных......................................... 3-27
PRE (префикс метки).................................... 3-27
DIM (размерность массива).............................. 3-28
Массивы как параметры ПРОЦЕДУР и ФУНКЦИЙ............... 3-29
EXTERNAL (переменная, описанная вне программы)......... 3-30
NAME (внешнее имя переменной).......................... 3-31
OVER (разделяет место в памяти)........................ 3-33
Директивы компилятора....................................... 3-34
EQUATE (назначить метку)............................... 3-34
SIZE (размер памяти в байтах).......................... 3-35
----------------------------------------------------------------
BYTE (однобайтное целое без знака)
================================================================
метка BYTE(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: однобайтная переменная
L---------------------
Биты: 7 0
Диапазон: 0..255
initial value Числовая константа. Если опущена, то подразуме-
вается ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет один и тот же участок памяти с другой
переменной
NAME Залает альтернативное, "внешнее" имя для поля.
EXTERNAL Указывает, что переменная описывается и память
под нее выделяется во внешней библиотеке. НЕ
разрешено для описаний FILE, QUEUE и GROUP.
BYTE описывает однобйтное беззнаковое целое. Присвоение значения
выходящего за пределы диапазона приводит к непредсказуемым ре-
зультатам.
Пример:
Countl BYTE !Declare one byte integer
Count2 BYTE,OVER(Countl) !Declare OVER the one byte integer
Count3 BYTE,DIM(4) !Declare it an array of 4 bytes
Count4 BYTE(5) !Declare with initial value
Count5 BYTE,EXTERNAL !Declare as external
Count6 BYTE,NAME('SixCount') !Declare with external name
ExampleFile FILE,DRIVER('Clarion') !Declare a file
Record RECORD
CountS BYTE,NAME('Counter')!Declare with external name
. .
----------------------------------------------------------------
SHORT (двухбайтное целое со знаком)
================================================================
метка SHORT(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
знак значение
Формат: L---+------------------
Биты: 15 0
Диапазон: -32,768..32,767
initial value Числовая константа. Если опущена, то подразуме-
вается ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает внешнее имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
SHORT описывает двухбайтное целое со знаком в формате целого
слова Intel 8086. Старший бит в этой конфигурации - знаковый бит
(0 = плюс, 1 = минус. Отрицательные значения представляются в
стандартном дополнении до двух. Присвоение значения, выходящего
за пределы диапазона SHORT дает к непредсказуемые результатам.
Пример:
Count2 SHORT,OVER(Countl) !Declare OVER the two-byte signed
! integer
Count3 SHORT,DIM(4) !Declare it an array of 4 shorts
Count4 SHORT(5) !Declare with initial value
Count5 SHORT,EXTERNAL !Declare as external
Count6 SHORT,NAME('SixCount') !Declare with external name
Examp]eFile FILE,DRIVER('Clarion') !Declare a file
Record RECORD
Count7 SHORT,NAME('Counter') !Declare with external
. . ! name
----------------------------------------------------------------
USHORT (two-byte unsigned integer)
================================================================
метка USHORT(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: значение
L-----------------
Биты: 15 0
Диапазон: 0..65,535
initial value Числовая константа. Если опущена, the initial
value is zero.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает внешнее имя для переменной.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
USHORT описывает двухбайтное целое без знака в формате слова
Intel 8086. В этой конфигурации НЕТ знакового бита. Присвоение
значения, выходящего за пределы диапазона USHORT приводит к не-
предсказуемым результатам.
Пример:
Countl USHORT !Declare two-byte unsigned integer
Count2 USHORT,OVER(Countl) !Declare OVER the two-byte unsi gned
! integer
Counts USHORT.DIM(4) !Declare it an array of 4 unsigned
! shorts
Count4 USHORT(5) !Declare with initial value
Count5 USHORT,EXTERNAL !Declare as external
Count6 USHORT,NAME('SixCount') !Declare with external name
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
Count7 USHORT,NAME('Counter') !Declare with external
. . ! name
----------------------------------------------------------------
LONG (четырехбайтное целое со знаком)
================================================================
метка LONG(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: знак значение
L---+----------------
Биты: 31 0
Диапазон: -2,147,483,648..2,147,483,647
initial value Числовая константа. Если опущена, подразумева-
ется ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает внешнее имя для переменной.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
LONG описывает четырехбайтное целое со знаком в формате длинного
целого Intel 8086. Старший бит - знаковый, (0 - положительное,
1 - отрицательное). Отрицательные значения представляются в
стандартном дполнении до двух. Присвоение значения, выходящего
за пределы диапазона LONG, приводит к непредсказуемым результа-
там
Пример:
Countl LONG !Declare four-byte signed integer
Count2 LONG,OVER(Countl) !Declare OVER the four-byte signed
! integer
Count3 LONG,DIM(4) !Declare it an array of 4 longs
Count4 LONG(5) !Declare with initial value
Count5 LONG,EXTERNAL !Declare as external
Counts LONG,NAME('SixCount') !Declare with external name
ExampleFile FILE,DRIVER('Clarion') !Declare a file
Record RECORD
Count7 LONG,NAME('Counter')!Declare with external name
. .
----------------------------------------------------------------
ULONG (четырехбайтное целое без знака)
================================================================
метка ULONG(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: значение
L--------------
Биты: 31 0
Диапазон: 0..4,294,967,295
initial value Числовая константа. Если опущена, то подразуме-
вается ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает внешнее имя переменной.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
ULONG описывает четырехбайтное целое без знака в формате длинно-
го целого Intel 8086. В этой конфигурации НЕТ знакового бита.
Присвоение значения, выходящего за пределы диапазона ULONG дает
непредсказуемые результаты.
Пример:
Countl ULONG !Declare four-byte unsigned integer
Count2 ULONG,OVER(Countl) !Declare OVER four-byte unsigned integer
Count3 ULONG,DIM(4) !Declare it an array of 4 unsigned longs
Count4 ULONG(5) !Declare with initial value
Count5 ULONG,EXTERNAL !Declare as external
Counts ULONG,NAME('SixCount')!Declare with external name
Examp]eFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
Count7 ULONG,NAME('Counter') !Declare with external
. . ! name
----------------------------------------------------------------
SREAL (четырехбайтное вещественное со знаком)
================================================================
метка SREAL(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: Знак порядок мантисса
L---+----------------+-----------------
Биты: 31 23 0
Диапазон: 0, +/- 1.17549435e-38 .. 3.40282347e+38
(6 значащих цифр)
initial value Числовая константа. Если опущена, подразумева-
ется ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Specify an alternate, "external" name for the
field.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
SREAL описывает четырехбайтную числовую переменную со знаком с
плавающей запятой в формате короткого целого Intel 8087 (одинар-
ной точности). Присвоение значения, выходящего за пределы диапа-
зона SREAL приводит к непредсказуемым результатам.
Пример:
Countl SREAL !Declare four-byte signed floating point
Count2 SREAL,OVER(Countl) !Declare OVER the four-byte
signed floating point
Count3 SREAL,DIM(4) !Declare it an array of 4 floats
Count4 SREAL(5) !Declare with initial value
Count5 SREAL,EXTERNAL !Declare as external
Count6 SREAL,NAME('SixCount') !Declare with external name
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
Count7 SREAL,NAME('Counter')!Declare with external name
. .
----------------------------------------------------------------
REAL (восьмибайтное вещественное со знаком)
================================================================
метка REAL(initial value)[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: знак порядок мантисса
L----+----------------+------------------
Bits: 63 52 0
Диапазон: 0,+/-2.22507385850720le-308..+/- 1.79769313496231e+308
(15 значащих цифр)
initial value Числовая константа. Если опущена, подразумева-
ется ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя для поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
REAL описывает восмибайтное вещественное число со знаком в фор-
мате длинного вещественного Intel 8087 (двойной точности. При-
свение числа, выходящего за пределы диапазона REAL приводит к
непредсказуемым результатам.
Пример:
Countl REAL !Declare eight-byte signed floating point
Count2 REAL,OVER(Countl) !Declare OVER the eight-byte
signed floating point
Count3 REAL,DIM(4) !Declare it an array of 4 rlelals
Count4 REAL(5) !Declare with initial value
Count5 REAL,EXTERNAL !Declare as external
Count6 REAL,NAME('SixCount') !Declare with external name
ExampleFile FILE,DRIVER('Clarion') !Declare a file
Record RECORD
Count5 REAL,NAME('Counter')!Declare with external name
. .
----------------------------------------------------------------
DECIMAL
(упакованное десятичное число фиксированной длины со знаком)
================================================================
метка DECIMAL(length[,places][,initial value])[,DIM()][,OVER()]
[,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат:
s d15 d14 d13 d12 d11 d10 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0
L-+---+---+---+---+---+---+---+---+---+---+---+--+--+--+--+---
60 0
Биты:
Диапазон: -999,999,999,999,999..999,999,999,999,999
length ТРЕБУЕМАЯ числовая константа, содержащая общее
число десятичных цифр (в целой и дробной частях
вместе взятых) в переменной. Максимальная длина
15.
places Числовая константа, уточняющая количество цифр
в дробной части (справа от десятичной точки) в
переменной. Она должна быть меньше или равна
параметру length. Если опущена, то описываемая
переменная считается целочисленной.
initial value Числовая константа. Если опущена, то по умолча-
нию - ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
DECIMAL описывает переменную переменной длины со знаком, в фор-
мате BCD (binary-coded-decimal) Intel 8087. Каждый байт в
DECIMAL хранит две десятиные цифры (по 4 бита на цифру). Самый
левый байт хранит знак числа в своем старшем ниббле (0 = плюс,
что-нибудь другое - минус) и одну десятичную цифру. Таким обра-
зом, переменные типа DECIMAL всегда содержат нечетное число цифр
(скажем, DECIMAL(10) и DECIMAL(11) оба занимают по 6 байт. При-
свение DECIMAL-переменным значений, выходящих за пределы DECIMAL
приводит к непредсказуемым результатам.
Пример:
Countl DECIMAL(5,O) !Declare three-byte signed packed decimal
Count2 DECIMAL(5),OVER(Countl) !Declare OVER the three-byte
signed packed decimal
Count3 DECIMAL(5.0),DIM(4) !Declare it an array of 4 decimals
Count4 DECIMAL(5,0,5) !Declare with initial value
Count5 DECIMAL(5,O),EXTERNAL !Declare as external
Count6 DECIMAL(5,O),NAME('SixCount')!Declare with external name
ExampleFile FILE,DRIVER('Clarion') !Declare a file
Record RECOROD
Count7 DECIMAL(5,O),NAME('Counter 1) !Declare with
. . !external name
----------------------------------------------------------------
PDECIMAL (то же, что и DECIMAL)
================================================================
метка PDECIMAL(length[,places][,iinitial value])[,DIM()]
[,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат:
dl5 dl4 d13 dl2 d11 d10 d9 d8 d7 d6 d5 d4 d3 d2 d1 d0 s
L---+---+---+---+---+---+---+---+---+---+---+--+--+--+--+--+--
63 5 0
Биты:
Диапазон: -999,999,999,999,999..999,999,999,999,999
length ТРЕБУЕМАЯ числовая константа, содержащая общее
число десятичных цифр (в целой и дробной частях
вместе взятых) в переменной. Максимальная длина
15.
places Числовая константа, уточняющая количество цифр
в дробной части (справа от десятичной точки) в
переменной. Она должна быть меньше или равна
параметру length. Если опущена, то описываемая
переменная считается целочисленной.
initial value Числовая константа. Если опущена, то по умолча-
нию - ноль.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
PDECIMAL описывает переменной длины десятичную переменную со
знаком в формате Btrieve и IBM/EBCDIC. Каждый байт PDECIMAL со-
держит две десятичные цифры, по 4 бита на цифру. Самый правый
байт содержит знак в своем младшем ниббле (OFh или OCh позитив-
ный, ODh негативный и одну десятичную цифру. Таким образом,
PDECIMAL-переменные всегда содержат строго "нечетное" число цифр
(скажем, PDECIMAL(10) и PDECIMAL(ll) используют по 6 байт). При-
своение числа, выходящего за диапазон PDECIMAL приводит к не-
предсказуемым результатам.
Пример:
Countl PDECIMAL(5,O) !Declare three-byte signed packed decimal
Count2 PDECIMAL(5),OVER(Countl)!Declare OVER the three-byte
signed packed decimal
Count3 PDECIMAL(5,O),DIM(4) !Declare it an array of 4 decimals
Count4 PDECIMAL(5,0,5) !Declare with initial value
Count5 PDECIMAL(5,O),EXTERNAL !Declare as external
Count6 PDECIMAL(5,O),NAME('SixCount')!Declare with external name
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
Count7 PDECIMAL(5,O),NAME('Counter') !Declare with
. . ! external name
----------------------------------------------------------------
STRING (строка фиксированной длины)
================================================================
¦ length ¦
метка STRING(¦string constant¦)[,DIM()][,OVER()][,NAME()]
¦ picture ¦ [,EXTERNAL]
----------------------------------------------------------------
Формат: Фиксированное число байт.
Диапазон: От 1 до 65,535 байт.
length Числовая константа, которая задает размер стро
ки в байтах. При использовани этого параметра,
строка инициализируется пробелами.
string constant Начальное значение строки. Длина STRING-a уста
навливается (в байтах) по длине этой строковой
константы.
picture Используется для форматирования значений, при-
своенных строке. Длина такой строки, это коли-
чество байт, достаточное для хранения формати-
рованной строки. Строка инициализируется про-
белами.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
STRING описывает символьную строку фиксированной длины.
Пример:
Name STRING(20) !Declare 20 byte name field
NameArray STRING(l),DIM(20),OVER(Name) !Declare array over name
! field
Company STRING('Clarion Software, Inc.,) !The software
! company - 22 bytes
Phone STRING(@P(###)###-####P) !Phone number field - 13
! bytes
ExampleFile FILE,DRIVER('Clarion') !Declare a file
Record RECORD
NameField STRING(20),NAME('Name') !Declare with external
. . ! name
----------------------------------------------------------------
CSTRING (строка фиксированной длины, завершающаяся нулем)
================================================================
¦ length ¦
метка CSTRING(¦string constant¦)[,DIM()][,OVER()][,NAME()]
¦ picture ¦ [,EXTERNAL]
----------------------------------------------------------------
Формат: Фиксированное число байт.
Диапазон: От 1 до 65,535 байт.
length Числовая константа, которая задает размер стро
ки в байтах, включая место для нулевого симво-
ла. При использовани этого параметра, строка
инициализируется пробелами.
string constant Начальное значение строки.Длина CSTRING-a уста
навливается (в байтах) по длине этой строковой
константы плюс завершающий нулевой символ.
picture Используется для форматирования значений, при-
своенных строке. Длина такой строки, это коли-
чество байт, достаточное для хранения формати-
рованной строки и завершающего нулевого симво-
ла. Строка инициализируется пробелами.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
CSTRING описывает символьную строку, завершающуюся нулевым сим-
волом (ASCII NULL). Она соответствует строкам, используемым в
языке C и типу данных "ZSTRING" в Btrieve Record Manager. Под
CSTRING в памяти выделяется участок постоянной длины, при этом,
завершающий нулефой символ помещается в конец введенных данных.
CSTRING во время исполнения преобразовывается в промежуточный
тип STRING. Тип CSTRING имеет смысл употреблять для совместимо-
сти с внешними файлами и/или процедурами.
Пример:
Name CSTRING(21) !Declare 21 byte field - 20 bytes data
OtherName CSTRING(21),OVER(Name) !Declare field over name field
Contact CSTRING(21),DIM(4) !Array 21 byte fields - 80
! bytes data Company
Company CSTRING('Clarion Software, Inc.') !23 byte string 22
! bytes data
Phone CSTRING(@P(###)###-####p) !Declare 14 bytes 13 bytes
! data
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
NameField CSTRING(21),NAME('ZstringField')
!Declare with external name
. .
----------------------------------------------------------------
PSTRING (строка со встроенным байтом-счетчиком длины)
================================================================
¦ length ¦
метка PSTRING(¦string constant¦)[,DIM()][,OVER()][,NAME()]
¦ picture ¦ [,EXTERNAL]
----------------------------------------------------------------
Формат: Фиксированное число байт.
Диапазон: От 1 до 255 байт.
length Числовая константа, которая задает размер стро
ки в байтах, включая место для первого по по-
рядку байта, в котором хранится длина такой
строки.
string constant Начальное значение строки.Длина PSTRING-a уста
навливается (в байтах) по длине этой строковой
константы плюс начальный байт-счетчик.
picture Используется для форматирования значений, при-
своенных строке. Длина такой строки, это коли-
чество байт, достаточное для хранения формати-
рованной строки и начального байта длины.
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
PSTRING описывает символьную строку с ведущим байтом длины и
длиной, заданной для этой строки.. Она соответствует типу, ис-
пользуемому в Паскале и типу данных "LSTRING" из Btrieve Record
Manager. Место в памяти под нее выделяется постоянной длины, но
байт длины содержит число символов, реально хранящихся в такой
переменной. Во время исполнения, PSTRING преобразуется в STRING.
Тип PSTRING имеет смысл употреблять для совместимости с внешними
файлами и/или процедурами.
Пример:
Name PSTRING(21) !Declare 21 byte field - 20 bytes data
OtherName PSTRING(21),OVER(Name)!Declare field over name field
Contact PSTRING(21),DIM(4)!Array 21 byte fields - 80 bytes data
Company PSTRING('Clarion Software,Inc.') !23 byte string - 22
! bytes data
Phone PSTRING(@P(###)###-####P) !Declare 14 bytes - 13 bytes
! data
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
NameField PSTRING(21),NAME('LstringField')
. . !Declare with external name
----------------------------------------------------------------
DATE (четырехбайтная дата)
================================================================
метка DATE[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: год мм дд
L--+--+--+---
Диапазон: год: 1..9999
месяц: 1..12
день: 1..31
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
DATE описывает четырех байтную переменную типа даты. Этот формат
соответствует типу поля "DATE" в Btrieve Record Manager. DATE,
используемые в числовых выражениях, преобразовываются в число
дней, прошедших с 28 декабря 1800 года (стандартная кларионовс-
кая дата, обычно хранится как LONG). Допустимый диапазон стан-
дартной кларионовской даты - от 1 января 1801 года по 31 декабря
2099 года. Использование значений, выходящих за пределы данного
диапазона, приводит к непредсказуемым результатам. Тип DATE име-
ет смысл употреблять для совместимости с внешними файлами и/или
процедурами.
Пример:
DueDate DATE !Declare a date field
OtherDate DATE,OVER(DueDate) !Declare field over date field
ContactDate DATE,DIM(4) !Array of 4 date fields
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
DateRecd DATE,NAME('DateField')
. . !Declare with external name
См. также: Standard Date
----------------------------------------------------------------
TIME (четырехбайтное время)
================================================================
метка TIME[,DIM()][,OVER()][,NAME()][,EXTERNAL]
----------------------------------------------------------------
Формат: чч мм сс ст
L--+--+--+---
Диапазон: часы: 0..23
минуты: 0..59
секунда: 0..59
секунды/100: 0..99
DIM Размерность(и) переменной как массива.
OVER Разделяет место в памяти с другой переменной.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
TIME описывает четырехбайтную переменную типа времени. Этот фор-
мат соответствует типу поля "TIME" в Btrieve Record Manager.
TIME используемые в числовых выражениях, преобразовываются в
число сотых долей секунды, прошедших с полуночи (стандартное
кларионовское время, обычно хранится как LONG). Тип DATE имеет
смысл употреблять для совместимости с внешними файлами и/или
процедурами.
Пример:
ChkoutTime TIME !Declare checkout time field
OtherTime TIME,OVER(CheckoutTime)!Declare field over time field
ContactTime TIME,DIM(4) !Array of 4 time fields
ExampleFile FILE,DRIVER('Btrieve') !Declare a file
Record RECORD
TimeRecd TIME,NAME('TimeField')!Declare with external name
. .
См. также: Standard Time
----------------------------------------------------------------
GROUP (составная структура данных)
================================================================
метка GROUP[,PRE()][,DIM()][,OVER()][,NAME()][,EXTERNAL]
declarations
.
----------------------------------------------------------------
declarations Одно или более последовательных описаний пере-
менных.
PRE Метка-префикс для переменных этой структуры.
DIM Размерность переменных как массива.
OVER Разделяет одно и то же место в памяти с другой
переменной или структурой.
NAME Задает "внешнее" имя поля.
EXTERNAL Указывает на то, что переменная описана и па-
мять под нее выделена во внешней библиотеке. НЕ
разрешено с описаниями FILE, QUEUE или GROUP.
(SPA - Мне кажется, что они противоречат сами себе - пишут, что
атрибут external не разрешен для group, а сами указывают его в
списке возможных параметров...)
Структура GROUP позволяет обращаться к нескольким переменным по
одной метке. Это может использоваться для измерения (?) набора
переменных, или для присвоения или сравнения наборов переменных
одним оператором. В больших сложных программах, структуры GROUP
удобны для подержки наборов связанных разнотипных данных. GROUP
должна завершаться точкой или оператором END.
При обращении оператора или выражения к переменной типа GROUP,
GROUP рассамтривается как STRING, составленная из всех перемен-
ных этой структуры. Структура GROUP может быть вложена в другую
структуру данных, как например, RECORD или другая GROUP.
Из-за внутреннего представления, числовые переменные (кроме
DECIMAL) описанные в группе не совсем корректно обрабатываются,
при использовании их как строк. По этой причине, построение клю-
ча, в котором используются поля типа GROUP, содержащие числовые
переменные, может привест к неожиданной последовательности срав-
нения (collating sequence).
Пример:
NameGroup GROUP,PRE(Nme) !Name group
First STRING(20) ! first name
Middle STRING(L) ! middle initial
Last STRING(20) ! last name
. !End group declaration
DateTimeGrp GROUP,PRE(Dtg),DIM(10) !Date/time array
Date LONG
Time LONG
. !End group declaration
----------------------------------------------------------------
LIKE (определяемые пользователем типы данных)
================================================================
новое_описание LIKE(выглядит_как)[,DIM()][,OVER()][,PRE()]
[,NAME()]
----------------------------------------------------------------
новое_описание Метка описания нового типа данных.
выгдядит_как Метка описания элемента данных, чье определение
будет использовано.
LIKE говорит компилятору определить новое_описание используя то
же описание, что и для выглядит_как, включая все атрибуты.
Новое_описание может использовать атрибуты DIM и OVER. Если вы-
глядит_как имело атрибут DIM, то новое_описание сразу будет мас-
сивом. Если в будущем атрибут DIM добавится к новому_описанию,
то размерности массива определятся в будущем (???).
Атрибуты PRE и NAME могут быть использованы, если надо. Если вы-
глядит_как уже имеет эти атрибуты, новое_описание унаследует их
и может привести к ошибке компилятора. Чтобы исправить это поло-
жение, задай принудительно PRE или NAME для нового_описания,
чтобы перекрыть унаследованный(е) атрибут(ы).
Пример:
Amount REAL !Описываем поле
QTDAmount LIKE(Amount) !Используем то же описание
YTDAmount LIKE(OTDAmount) !И еще раз
MonthlyAmts LIKE(Amount),DIM(12)!То же описание, но для массива
!из 12 элементов
AmtPrPerson LIKE(MonthlyAmts),DIM(10)
!То же описание, но уже для 120 элементов (12,10)
Construct GROUP,PRE(Con) !Описываем группу
Fieldl LIKE(Amount) ! con:field1 - real
Field2 STRING(10) ! con:field2 - string(10)
.
NewGroup LIKE(Construct),PRE(New)!Описываем новую группу с
! new:field1 - real
! new:field2 - string(10)
AmountFile FILE,DRIVER('Clarion'),PRE(Amt)
Record RECORD
Amount REAL !Define a field
OTDAmount LIKE(Amount) !Use same definition
. .
См. также: DIM, OVER, PRE, NAME
НЕЯВНЫЕ ПЕРЕМЕННЫЕ
Неявные переменные НЕ описываются в описаниях данных. Они созда-
ются компилятором, когда он встречает их впервые. Любая неявная
переменная, использованная области описания глобальных данных
(между ключевыми словами PROGRAM и CODE) это "Глобальные Стати-
ческие Данные". Любая неявная переменная между ключевыми словами
MEMBER и PROCEDURE (или FUNCTION) это "Локальные Статические
Данные". Все остальные неявные переменные - это "Локальные Дина-
мические данные".
Неявные переменные обычно используются для: индексов массивов,
флагов true/false, промежуточных переменных в сложных вычислени-
ях; как управляющие переменные циклов, итд. Язык Clarion предла-
гает три типа неявных переменных:
# Неявная LONG-переменная, ее метка (имя) завершается сим-
волом # (решетка, номер).
$ Знак доллара указывает на неявную REAL-переменную, метка
котороя завершается символом $ (доллар).
" Двойная кавычка (не путать с двумя апострофами!) означа-
ет неявную 32хбайтную строку. Имя такой переменной за
канчивается символом " (кавычка или двойная кавычка).
Пример:
LOOP Counter# - 1 TO 10 !Implicit LONG
ArrayField[Counter#] = Counter# * 2 !Initialize an array
.
Address"=CLIP(City) & ','&State &' '&ZIP!Implicit STRING(32)
SHOW(12,16,Address") !Used to display a temporary value
Percent$ = ROUND((Quota/Sales),.1) * 100 !Implicit REAL
SHOW(15,22,Percent$,@P%<<<.##P)
!Used to display a temporary value
См. также: Глобальные, Локальные, Статические, и Динамические
данные.
ЭЛЕМЕНТЫ ШАБЛОНОВ
Элементы шаблонов предлагают формат масок для просмотра и/или
редактирования переменных. Элементы шаблонов можно использовать
как параметры для описания переменных типа STRING, ENTRY, или
STRING OPTION в SCREEN-структурах; как параметры операторов
STRING в REPORT-структурах; как параметры некоторых процедур и
функций Клариона; или, как параметры описаний STRING, CSTRING и
PSTRING. Есть семь типов элементов шаблонов: числовые и валюта,
научная нотация, дата, время, образец, key-in template и строки.
----------------------------------------------------------------
Шаблоны чисел и валюты
================================================================
@N[валюта][знак][заполнение]размер[группирование][места]
[валюта][знак][B]
----------------------------------------------------------------
@N Все шаблоны чисел и валюты начинаются с @N.
валюта Либо знак доллара ($) либо строковая константа,
заключенная в тильды (~). Если есть признак зна-
ка и нет признака заполнения, то символ валюты
будет "плавать" возле старшей левой цифры. Если
же есть признак заполнения, то символ валюты
остается в крайней левой позиции. Если символ
валюты стоит после размера и группирования, то
он будет располагаться в конце показываемого
числа.
знак Задает формат вывода отрицательных чисел. Если
тире стоит перед ЗАПОЛНЕНИЕМ и РАЗМЕРом, то от-
рицательные числа будут выводиться с ведущим
знаком "минус". Если же тире идет после РАЗМЕРа,
ГРУППИРОВАНИя, places, и ВАЛЮТы, то числа будут
выводиться с хвостовым минусом. Если в обоих по-
зициях, предназначенных для ЗНАКа стоят скобки,
то отрицательные числа будут выводиться без ми-
нуса, но заключенными в скобки.
заполнение Указывает вид ведущих нулей - нули, пробелы или
звездочки (*). Если ЗАПОЛНЕНИЕ опущено, то веду-
щие пробелы подавляются.
0 Ведущие нули выводятся, ГРУППИРОВАНИЕ подавлено
- Вместо нулей - пробелы, ГРУППИРОВАНИЕ подавлено
* Вместо ведущих нулей выводятся звездочки
размер РАЗМЕР требуется, чтобы указать общее число зна-
чащих цифр для вывода, включая количество цифр в
признаке МЕСТА и всех символов форматирования.
группирование Признак ГРУППИРОВАНИя (кроме запятой, которая
принимается по умолчанию) может быть помещен
справа от РАЗМЕРа, для указания разделителя
групп из трех цифр.
. Порождает точки - Порождает тире
_ Порождает пробелы (НЕ подчеркивания!)
места Задает символ десятичного разделителя и число
цифр в дробной части. Число цифр в дробной части
должно быть меньше, чем РАЗМЕР. Десятичным раз-
делителем может быть точка (.), слабое ударение
('), или буква "v" (только для описания формата
хранения STRING-полей, а не для вывода).
. Точка порождает точку как десятичный раздели-
тель
` Слабое ударение порождает запятую как деся-
тичный разделитель.
v НЕ порождает десятичный разделитель (только
для хранения STRING-полей)
B Если значение нулевое, то число выводится в виде
пробелов.
Элементы шаблонов чисел и валюты форматируют числа для вывода на
экран или в отчет. Если значение больше, чем можно вывести в те-
кущем шаблоне, такое значение выводится в виде строки из звездо-
чек.
Пример:
Число Результат Формат
@N9 4,550,000 Девять цифр, группирование запятыми (по
умолчанию)
@N_9B 4550000 Девять цифр, без группирования, ведущие нули
выводятся как пробелы
@N09 004550000 Девять цифр, ведущие нули выводятся
@N*9 ***45,000 Девять цифр, заполнение звездочками, группи-
рование запятыми
@N9_ 4 550 000 Девять цифр, группирование пробелами
@N9. 4.550.000 Девять цифр, группирование точками
Десятич. Результат Формат
дробь
@N9.2 4,550.75 Две цифры в дробной части, десятичный разде-
литель - точка
@N_9.2B 4550.75 То же, без группирования, если ноль, то вы-
водится строка пробелов.
@N_9'2 4550,75 Две цифры в дробной части, десятичный разде-
литель - запятая
@N9.'2 4.550,75 Десятичный разделитель - запятая, группиро-
вание точками
@N9_'2 4 550,75 Десятичный разделитель - запятая, г руппиро-
вание пробелами
Со знак- Результат Формат
ом
@N-9.2B -2,347.25 Ведущий минус, если ноль, то вывести пустую
строку
@N9.2- 2,347.25- Хвостовой минус
@N(10.2) (2,347.25) Вывести в скобках, если отрицательное
Знак доллара Результат Формат
@N$9.2B $2,347.25 Ведущий знак доллара, вывести пустую
строку, если ноль
@N$10.2- $2,347.25- Ведущий знак доллара, хвостовой ми-
нус, если отрицательное
@N$(11.2) $(2,347.25) Ведущий знак доллара, вывести в скоб-
ках, если отрицательное
Национальные валюты Результат Формат
@N12_'2~ F~ 1 5430,50 F Франция
@N~L. ~12' L. 1.430.050 Италия
@N~L~12.2 L1,240.50 Великобритания
@N~kr~12'2 kr1.430,50 Норвегия
@N~DM~12'2 DM1.430,50 Германия
@N12_'2~ mk~ 1 430,50 mk Финляндия
@N12'2~ kr~ 1,430.50 kr Швеция
Только храниене Шаблоны:
Variablel STRING(@N_6v2) !Шесть байт хранятся БЕЗ десятич-
!ного разделителя
CODE
Variablel = 1234.56 !Храним в виде '123456'
SHOW(1,1,Variablel,@N_7.2)
!Выводим с десятичн. точкой: '1234.56'
----------------------------------------------------------------
Шаблоны научной нотации
================================================================
@Em.n[B]
----------------------------------------------------------------
@E Все шаблоны научной нотации начинаются с @E.
m Общее число символов в формате, предлагаемом данным шаб-
лоном.
n Число цифр после десятичной точки.
B Если число равно нулю, то вывести пустую строку.
Шаблоны научной нотации форматируют очен большие или же очень
маленькие числа. Вывод в виде десятичного числа в степени деся-
ти.
Пример:
Шаблон Значение Результат
@E9.0 1,967,865 .20e+007
@E12.1 1,967,865 1.9679e+006
@E12.1B 0
@E12.1 -1,967,865 -1.9679e+006
@E12.1 .000000032 3.2000e-008
----------------------------------------------------------------
Шаблоны даты
================================================================
@Dn[s][B]
----------------------------------------------------------------
@D Все шаблоны даты начинаются с @D.
n Номер шаблоны даты. Допустимые номера от 1 до 16.
s Разделитель. Слэш (/) ставится между днем, месяцем и го-
дом в большинстве шаблонов даты. Можно использовать аль-
тернативные разделители, как то:
. Порождает точки ` (слабое ударение) порождает запятые
- Порождает тире _ (подчеркивание) порождает пробелы
B Вывести пустую строку, если число равно нулю.
Даты можно хранить в числовых переменных (обычно LONG), DATE-по-
лях (для совместимости с Btrieve), или в STRINGах описанных в
виде дат. Дата, хранящаяся в числовой переменной называется
Стандартной Кларионовской датой. Ее зачение представляет собой
количество дней, прошедших с 28 декабря 1800 года. Шаблон даты
преобразует это число в один из форматов даты.
Для ввода данных нельзя использовать шаблоны @D3, @D4, @D7 и @D8
поскольку в них требуется вводить не только цифры, но и буквы.
Пример:
Шаблон Формат Результат
@Dl mm/dd/yy 10/31/59
@D2 mm/dd/yyyy 10/31/1959
@D3 mmm dd, yyyy OCT 31,1959
@D4 mmmmmmmmm dd, yyyy October 31, 1959
@D5 dd/mm/yy 31/10/59
@D6 dd/mm/yyyy 31/10/1959
@D7 dd mmm yy 31 OCT 59
@D8 dd mmm yyyy 31 OCT 1959
@D9 yy/mm/dd 59/10/31
@D10 yyyy/mm/dd 1959/10/31
@D11 yymmdd 591031
@D12 yyyymmdd 19591031
@D13 mm/yy 10/59
@014 mm/yyyy 10/1959
@D15 yy/mm 59/10
@D16 yyyy/mm 1959/10
------ Альтернативные разделители ----------
@Dl. mm.dd.yy Разделитель - точка
@D2- mm-dd-yyyy Разделитель - тире
@D5_ dd mm yy Подчеркивание порождает разделитель
пробел
@D6` dd,mm,yyyy Слабое ударение порождает разделитель
запятую
----------------------------------------------------------------
Шаблоны времени
================================================================
@Tn[s][B]
----------------------------------------------------------------
@T Все шаблоны времени начинаются с @T.
n Номер формата времени. Допустимые номера форматов - от 1
до 6.
s Разделитель. Двоеточие (:) ставится по умолчанию между
часами, минутами и секундами в большинстве форматов вре-
мени. Можно использовать альтернативные разделители, как
то:
. Порождает точки ' (слабое ударение) порождает запятые
- Порождает тире _ (подчеркивание) порождает пробелы
B Если значение равно нулю, то вывести пустую строку.
Время можно хранить в числовой переменной (обычно LONG), в TIME-
полях (для совместимости сBtrieve), или в STRINGах, описанных в
формате времени. Время, хранящееся в числовой переменной называ-
ется стандартныс кларионовским временем. Оно представляет из се-
бя количество сотых долей секунды, прошедших с полуночи. Шаблон
времени переводит это число в один из 6 форматов времени.
Нельзя использовать для ввода шаблоны (@T3 и @T6), в которых
требуется вводить не только цифры, но и буквы.
Пример:
Шаблон Формат Результат
@T1 hh:mm 17:30
@T2 hhmm 1730
@T3 hh:mmXM 5:30PM
@T4 hh:mm:ss 17:30:00
@T5 hhmmss 173000
@T6 hh:mm:ssXM 5:30:00PM
------ Альтернативные разделители ------------
@T1. hh.mm Разделитель - точка
@T1- hh-mm Разделитель - тире
@T3_ hh mmXM Подчеркивание порождает пробелы
@T4' hh,mm,ss Слабое ударение порождает запятые
----------------------------------------------------------------
Шаблоны "по образцу"
================================================================
@p[<][#][x]P[B]
----------------------------------------------------------------
@P Все шаблоны "по образцу" начинаются с разделителя @P и
заканчиваются разделителем P. Регистр обоих разделетелей
должен быть один и тот же.
< Целочисленная позиция. Если в этой позиции ноль, то вы-
вести пробел.
# Целочисленная позиция. В этой позиции вывести цифру, не-
зависимо от ее значения.
x Необязательный символ для вывода. Эти символы будут при-
сутствовать в выводной строке.
p Все шаблоны "по образцу" должны заканчиваться на P. Если
разделитель @p введен на нижнем регистре, то и конечный
разделитель P тоже должен быть в нижнем регистре.
B Если ВСЕ число равно нулю, то вывести пустую строку.
Шаблоны "по образцу" содержат необязательные целочисленные пози-
ции и необязательные символы редактирования. Любой символ кроме
< или # считается символом редактирования, который появится в
форматированной строке-результате. Разделители @P и P чувстви-
тельны к регистру, на котором они введены. Это сделано для того,
чтобы, если скажем, надо ввести символ "Р", то можно использо-
вать разделители "р" и наоборот.
Пример:
Шаблон Значение Результат
@P###-##-####P 215846377 215-84-6377
@P<#/##/##P 103159 10/31/59
@P(###)###-####P 3057854555 (305)785-4555
@P###/###-####P 7854555 000/785-4555
@p<#:##PMp 530 5:30PM
@P<#'<#"P 506 5' 6"
@P<#Ib. <#oz.P 902 91b. 2oz.
@P4##A-#P 112 411A-2
----------------------------------------------------------------
Key-in Template Pictures
================================================================
@K[@][#][<][x][\][?][^][_][¦]K[B]
----------------------------------------------------------------
@K Все key-in template шаблоны начинаются разделителем @K и
завершаюися разделителем K. Регистр обоих "К" должен
быть одним и тем же.
@ Разрешены только буквы на верхнем и нижнем регистрах.
# Разрешены целые числа от 0 до 9.
< У целых чисел выводить лидирующие нули пробелами.
x Представляет необязательные постоянные символы для пока-
за (любые символы, пригодные для вывода на экран). Эти
символы попадают без изменений в результирующую строку.
\ Следующий за \ символ выводить на экран как печатаемый.
Так можно включить в результирующую строку любые символы
форматирования (@,#,<,\,?,^,_,¦) как обычные печатаемые
символы.
? В этой позиции может быть любой символ.
^ В этой позиции разрешены только буквы на верхнем регист-
ре.
- В этой позиции разрешены только буквы на нижнем регистре
| Ограничитель. Только данные введенные до | и печатаемые
символы, введенные до | будут помещены в результирующую
строку.
K Все key-in template шаблоны завершаются символом "K".
Если разделитель @k был введен на нижнем регистре, то и
завершающий k должен быть введен на нижнем регистре.
B Если ВСЕ число рано нулю, то вывести пустую строку.
Key-in шаблоны могут содержать целочисленные позиции ( # < ),
символьные позиции ( @ ^ _ ), места для любых символов ( ? ), и
печатаемые символы. Любой символ, кроме символов форматирования,
рассматривается как печатаемый, который попадает в форматирован-
ную строку-результат. Разделители @K иd K чувствительны к ре-
гистру по той же причине, что и @P и P в шаблонах "по образцу".
Key-in Шаблоны специфичны для полей типа STRING, PSTRING, и
CSTRING для возможности произвольного редактирования и проерки
допустимости поля. Использование key-in шаблонов, содержащих лю-
бые алфавитные индикаторы ( @ ^ _ ) с полями для ввода чисел да-
ет непредсказуемые результаты.
Поскольку использование режима вставки для key-in шаблонов, мо-
жет также привести к непредсказуемым результатам, то key-in шаб-
лоны всегда принимают данные в режиме надпечатки, даже если есть
атрибут INS.
Пример:
Шаблон Введено значение Строка-результат
@K###-##-###K 215846377 215-84-6377
@K####¦-####K 33064 33064
@K####¦-####K 330643597 33064-3597
@K<# ^^^ ##K 10AUG59 10 AUG 59
@K(###)@@@-##\@##K 305abc4555 (305)abc-45@55
@K###/?##-####K 7854555 000/785-4555
@k<#:##^Mk 530P 5:30PM
@K<#' <#"K 506 5' 6"
@K4#_#A-#K 1g12 41glA-2
----------------------------------------------------------------
Строковые шаблоны
================================================================
@Slength
----------------------------------------------------------------
@S Все строковые шаблоны начинаются с @S.
length Определяет количество символов в шаблоне формата.
Строковый шаблон описывает НЕформатированную строку заданной
длины.
Пример:
Name STRING(@S20) !20-символьное поле-строка
АТРИБУТЫ ПЕРЕМЕННЫХ
----------------------------------------------------------------
PRE (префикс метки)
================================================================
PRE(prefix)
----------------------------------------------------------------
prefix Допустимые символы - буквы, цифры от 0 до 9 и символ
подчеркивания. Префикс должен ничинаться с буквы и не
должен быть зарезервированм словом.
Атрибут PRE предусматривает префикс метки для сложных структур
данных. Он используется для того, чтобы различать переменные с
одинаковыми именами в разных структурах. При обращении к пере-
менной исполняемымы операторами, при присвоениях и передаче в
списках параметров, префикс присоединяется к метке двоеточием
(Pre:Метка). PRE можно использовать со следующими структурами
данных:
DETAIL FILE FOOTER
GROUP HEADER OPTION
QUEUE RECORD REPEAT
REPORT SCREEN
Пример:
MasterFile FILE,DRIVER('Clarion'),PRE(Mst) !Declare master
Record RECORD ! file layout
AcctNumber LONG
. .
Detail FILE,DRIVER('Clarion'),PRE(Dtl) !Declare detail
! file layout
Record RECORD
AcctNumber LONG
. .
GROUP,PRE(Mem) !Declare some memory variables
Message STRING(30)
Page LONG
Line LONG
Device STRING(30)
.
CODE
IF Dtl:AcctNumber <> Mst:AcctNumber !Is it a new account
Mem:Message - 'New Account' ! display message
DO MatchMaster ! get new record
.
См. также: Зарезервированные слова
----------------------------------------------------------------
DIM (размерность массива)
================================================================
DIM(измерение,....,измерение)
----------------------------------------------------------------
измерение Числовая константа, которая задает количество элемен-
тов в данном измерении массива.
Атрибут DIM объявляет перемнную-массив. Такая переменная повто-
ряется столько раз, сколько указано в параметрах ИЗМЕРЕНИЕ. Мно-
гомерные массивы можно рассматривать как вложенные одномерные.
Каждое измерение массива имеет соответствующий индекс. Таким об-
разом, обращаясь к переменной - элементу трехмерного массива,
надо указать три индекса. Хотя на число измеренний не накладыва-
ется ограничений, но рамер массива не должен превышать 65,520б.
С атрибутом DIM можно использовать следующие типы данных:
SHORT REAL STRING CSTRING PSTRING
ULONG USHORT SREAL DATE TIME
Индексы однозначно определяют конкретный элемент массива. Список
индексов содержит индексы для каждого ИЗМЕРЕНИЯ массива. В спис-
ке, индексы отделяются друг от друга запятыми, а весь списоу за-
ключается в квадратные скобки ([ ]). Индекс может быть числовой
константой, выражением или функцией. Если надо обратиться ко
всему массиву целиком, то надо использовать метку этого массива
без списка индексов.
Структура GROUP - особый случай. Каждый уровень вложенности до-
бавляет индексы и GROUP и ее переменным. Данные, описанные в
GROUP можно использовать точно так же, как и собственно GROUP.
Пример:
Screen GROUP !Текст на экране
Row GROUP,DIM(25) !25 строк
Pos GROUP,DIM(80) !Две тысячи знакомест
Attr BYTE !Байт атрибута
Char BYTE !Собственно символ
. . . !Завершаем все три группы
В предыдущей группе:
Screen это 4,000байтная GROUP
Row[1] это 160байтная GROUP
Pos[1,1] это 2хбайтная GROUP
Attr[1,1] это BYTE
Char[1,1] это BYTE
Month STRING(10),DIM(12) !Размерность для месяца - 12
CODE
CLEAR(Month) !Весь массив заполнить пробелами
Month[1] = 'January' !Заполнить массив названиями
Month[2] = 'February'
MonthE3] = 'March'
См. также: MAXIMUM
----------------------------------------------------------------
Массивы как параметры процедур и функций
================================================================
Массив можно передать в PROCEDURE или FUNCTION. Прототип, опи-
санный в MAP-структуре должен описывать тип данных "массив" как
параметр-переменную ("передается по адресу") с пустым списком
индексов. Вызывающий оператор может передать массив в ROCEDURE
или FUNCTION.
Пример:
PROGRAM
MAP
MainProc
AddCount(*LONG[,],*LONG[,]) !Передаем 2 двумерных
. !масива типа LONG
CODE
MainProc
MainProc PROCEDURE
TotalCount LONG,DIM(10,10)
CurrentCnt LONG,DIM(10,10)
CODE
AddCount(TotalCount,CurrentCnt)!Вызывая процедуру, переда-
!ем ей массивы
AddCount PROCEDURE(Tot,Cur) !Процедуре нужны два массива
CODE
LOOP I# = 1 TO MAXIMUM(Tot,1) !Цикл по первому индексу
LOOP J# = 1 TO MAXIMUM(Tot,2)!Цикл по второму индексу
Tot[I#,J#l += Cur[I#,J#] ! увеличить TotalCount на
. . ! CurrentCnt
CLEAR(Cur) !Очистить массив CurrentCnt
RETURN
См. также: DIM, Прототипы процедур и функций, MAXIMUM
----------------------------------------------------------------
EXTERNAL (переменная описана извне)
================================================================
EXTERNAL
----------------------------------------------------------------
Атрибут EXTERNAL указывает на то, что переменная, которой он
присвоен, описана во внешней библиотеке. Таким образом, перемен-
ная с атрибутом EXTERNAL определена и может использоваться кла-
рионовским кодом, но под нее не будет выделена память. Память
для такой переменной выделяется самой внешней библиотекой. Этот
атрибут позволяет Clarion-программам иметь доступ к полям, опи-
санным как PUBLIC во внешних библиотеках.
EXTERNAL допустим только для переменных, описанных ВНЕ структур
FILE, QUEUE или GROUP.
Пример:
PROGRAM
MAP
MODULE('External.Obj')
AddCount,PASCAL!External library with PASCAL
. . ! calling convention
TotalCount LONG,EXTERNAL !Variable declared in external library
См. также: NAME
----------------------------------------------------------------
NAME (указать внешнее имя)
================================================================
NAME([ ¦constant ¦])
¦variable ¦
----------------------------------------------------------------
constant Строковая константа.
variable Метка STRING-переменной, описанной в области описания
глобальных данных или в области описания данных моду-
ля-члена.
Атрибут NAME задает "внешнее" имя. Он полностью независим от ат-
рибута EXTERNAL - между ними не требуется никакой связи, хотя
оба этих атрибута могут быть у одной и той же переменной.
Атрибут NAME можно использовать в прототипах процедур и функций,
применять к FILE, KEY, INDEX, MEMO, любому полю, описанному в
FILE или QUEUE структурах, или к любому полю вне структуры. Ат-
рибут NAME имеет различные свойства, в зависимости от того, где
он использован.
NAME(константа) можно задать в прототипах процедур или функций.
Константа - это внешнее имя, используемое компоновщиком для
идентификации процедуры или функции из внешней библиотеки.
Атрибуты NAME(константа) или NAME(переменная) в описании FILE
задает ДОСовскую спецификацию полного имени файла. Если констан-
та или переменная не содержит диск и путь, то подразумеваются
текущие диск и каталог. Если опущено расширение файла, то подра-
зумевается расширение, стандартное для данного файлового драйве-
ра. Некоторые файловые драйверы требуют, чтобы KEYи, INDEXы, или
MEMO-поля были в отдельных файлах. Таким образом, NAME можно
применить к описаниям KEY, INDEX или MEMO. Атрибут NAME без кон-
станты или переменной, ссылается на метку того описательного
оператора, к которому он был применен (включая префикс, если та-
ковой указан).
NAME(константа) может применятся к любому полю, описанному в
структуре RECORD. Это позволяет использовать имена полей, не на-
рушающих ограничений на имена, накладываемые отдельными файловы-
ми драйверами.
NAME(константа) можно применять к любому полю в структуре QUEUE.
Так достигается возможность динамических сортировок во время ис-
полнения.
NAME(константа) можно также применять к любой переменной, опи-
санной вне какой-либо структуры. Это дает возможность компонов-
щику по внешнему имени идентифицировать переменную, описанную во
внешней библиотеке. Если переменная имеет еще атрибут EXTERNAL,
то она описана, и память под нее выделяется самой внешней библи-
отекой. Без атрибута EXTERNAL, такая переменная описывается, и
память под нее выделяется в кларионовской программе, и она явля-
ется внешней по отношению ко внешней библиотеке.
Пример:
PROGRAM
MAP
MODULE('External.Obj')
AddCount(LONG),LONG,C,NAME('_AddCount')
!C function named ' AddCount,
. .
Cust FILE,PRE(Cus),NAME(CustName) !Filename in CustName variable
CustKey KEY('Name'),NAME('c:\data\cust.idx')
!Declare key,cust.idx
Record RECORD
Name STRING(20),NAME !Default NAME to 'Cus:Name'
. !End file declaration
SortOue QUEUE,PRE(Que)
Fieldl STRING(10),NAME('FirstField') !QUEUE SORT NAME
Field2 LONG,NAME('SecondField') !QUEUE SORT NAME
.
CurrentCnt LONG,EXTERNAL,NAME('Cur') !Field declared public in
! external library as 'Cur'
TotalCnt LONG,NAME('Tot') !Field declared external
!in external library as 'Tot'
См. также: прототипы процедур и функций, FILE, KEY, INDEX,
QUEUE, EXTERNAL
----------------------------------------------------------------
OVER (разделяет место в памяти)
================================================================
OVER(переменная)
----------------------------------------------------------------
переменная Метка переменной, которая уже занимает память, под-
лежащую разделу.
Атрибут OVER позволяет ссылаться на один и тот же участок памяти
двумя разными путями. Поле, описанное с атрибутом OVER, должно
быть НЕ больше, чем переменная, поверх которой она накладывается
(хотя, конечно, она может быть меньше).
(SPA. Для тех кому это трудно понять сразу, как мне было в свое
время, скажу что этот механизм аналогичен паскалевским записям с
вариантами)
Поле в структуре GROUP НЕ может быть описано поверх переменной,
которая находится ВНЕ этой структуры GROUP. Также, нельзя опи-
сать поле поверх перемнной, которая является частью списка пара-
метров процедуры или функции.
Пример:
CustNote FILE,PRE(Csn) !Declare CustNote file
Notes MEMO(2000) !The memo field
Record RECORD
CustID LONG
. .
CsnMemoRow STRING(IO),DIM(200),OVER(Csn:Notes) !Csn:Notes
!можно рассматривать как одно
!целое или блоками по 10 байт
См. также: DIM
ДИРЕКТИВЫ КОМПИЛЯТОРА
----------------------------------------------------------------
EQUATE (назначить метку)
================================================================
¦ label ¦
метка EQUATE(¦constant ¦)
¦ picture ¦
----------------------------------------------------------------
метка Метка исполняемого оператора. Используется для
присвоения оператору еще одной метки.
constant Числовая или символьная константа. Используется
для описания сокращенного названия содержимого
константы, и позволяет легко изменять и находить
эту константу.
picture Элемент шаблона. Дает сокращенное имя шаблону. Тем
не менее, форматтеры экранов и отчетов в кларио-
новском редакторе не распознают назначенные метки
как разрешенные шаблоны.
Директива EQUATE не занимает память во время исполнения. Она ис-
пользуется для присвоения метки другой мекте или константе. Мет-
ка директивы EQUATE не может быть такой же, как ее параметр.
Пример:
Init EQUATE(SetUpProg) !Обзовем процедуру по другому
Off EQUATE(0) !Off означает нуль
On EQUATE(1) !On означает один
Pi EQUATE(3.1415927) !Значение числа ПИ
EnterMsg EQUATE('Press Ctrl-Enter to SAVE')
SocSecPic EQUATE(@P###-##-##IfltP) !Формат номера карточки
!социального страхован.
См. также: Зарезервированные слова
----------------------------------------------------------------
SIZE (размер памяти в байтах)
================================================================
¦ label ¦
SIZE(¦constant ¦)
¦ picture ¦
----------------------------------------------------------------
метка Метка ранее описанной переменной.
constant Числовая или символьная константа.
picture Элемент шаблона.
SIZE заставляет компилятор сообщить количество памяти (в байтах)
выделенной для хранения параметра.
Пример:
SavRec STRING(1),DIM(SIZE(Cus:Record)
!Строк столько же, каков размер записи
StringVar STRING(SIZE('Clarion Software, Inc.'))
!Строка должна быть достаточной для этой
!константы длины
LOOP I# = 1 TO SIZE(ParseString)
!Цикл по все символам строки
PicLen = SIZE(@P(###)###-####P) !Сохраняем размер шаблона
Знаете ли Вы, что Polymorphism, полиморфизм в объектно-ориентированном программировании - это способность объекта выбирать правильный метод в зависимости от типа данных, полученных в сообщении.