к оглавлению

КЛАРИОH. Справочное руководство

ГЛАВА 3 - Описание переменных

Операторы описания.......................................... 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, полиморфизм в объектно-ориентированном программировании - это способность объекта выбирать правильный метод в зависимости от типа данных, полученных в сообщении.

НОВОСТИ ФОРУМА

Форум Рыцари теории эфира


Рыцари теории эфира
 10.11.2021 - 12:37: ПЕРСОНАЛИИ - Personalias -> WHO IS WHO - КТО ЕСТЬ КТО - Карим_Хайдаров.
10.11.2021 - 12:36: СОВЕСТЬ - Conscience -> РАСЧЕЛОВЕЧИВАНИЕ ЧЕЛОВЕКА. КОМУ ЭТО НАДО? - Карим_Хайдаров.
10.11.2021 - 12:36: ВОСПИТАНИЕ, ПРОСВЕЩЕНИЕ, ОБРАЗОВАНИЕ - Upbringing, Inlightening, Education -> Просвещение от д.м.н. Александра Алексеевича Редько - Карим_Хайдаров.
10.11.2021 - 12:35: ЭКОЛОГИЯ - Ecology -> Биологическая безопасность населения - Карим_Хайдаров.
10.11.2021 - 12:34: ВОЙНА, ПОЛИТИКА И НАУКА - War, Politics and Science -> Проблема государственного терроризма - Карим_Хайдаров.
10.11.2021 - 12:34: ВОЙНА, ПОЛИТИКА И НАУКА - War, Politics and Science -> ПРАВОСУДИЯ.НЕТ - Карим_Хайдаров.
10.11.2021 - 12:34: ВОСПИТАНИЕ, ПРОСВЕЩЕНИЕ, ОБРАЗОВАНИЕ - Upbringing, Inlightening, Education -> Просвещение от Вадима Глогера, США - Карим_Хайдаров.
10.11.2021 - 09:18: НОВЫЕ ТЕХНОЛОГИИ - New Technologies -> Волновая генетика Петра Гаряева, 5G-контроль и управление - Карим_Хайдаров.
10.11.2021 - 09:18: ЭКОЛОГИЯ - Ecology -> ЭКОЛОГИЯ ДЛЯ ВСЕХ - Карим_Хайдаров.
10.11.2021 - 09:16: ЭКОЛОГИЯ - Ecology -> ПРОБЛЕМЫ МЕДИЦИНЫ - Карим_Хайдаров.
10.11.2021 - 09:15: ВОСПИТАНИЕ, ПРОСВЕЩЕНИЕ, ОБРАЗОВАНИЕ - Upbringing, Inlightening, Education -> Просвещение от Екатерины Коваленко - Карим_Хайдаров.
10.11.2021 - 09:13: ВОСПИТАНИЕ, ПРОСВЕЩЕНИЕ, ОБРАЗОВАНИЕ - Upbringing, Inlightening, Education -> Просвещение от Вильгельма Варкентина - Карим_Хайдаров.
Bourabai Research - Технологии XXI века Bourabai Research Institution