Содержание
- Type information
- Contents
- Type information
- Architecture
- Definition types
- base definition (TDef)
- file definition (TFileDef)
- formal definition (TFormalDef)
- forward definition (TForwardDef)
- error definition (TErrorDef)
- pointer definition (TPointerDef)
- object definition (TObjectDef)
- class reference definition (TClassRefDef)
- array definition (TArrayDef)
- record definition (TRecordDef)
- ordinal definition (TOrdDef)
- float definition (TFloatDef)
- abstract procedure definition (tabstractprocdef)
- procedural variable definition (TProcVarDef)
- procedure definition (TProcDef)
- string definition (TStringDef)
- enumeration definition (TEnumDef)
- set definition (TSetDef)
- Definition interface
- Сообщения и коды ошибок
Type information
Contents
Type information
Architecture
(last updated for fpc version 1.0.x)
A type declaration , which is the basis for the symbol table, since inherently everything comes down to a type after parsing is a special structure with two principal fields, which point to a symbol table entry which is the type name, and the actual definition which gives the information on other symbols in the type, the size of the type and other such information.
Definition types
(last updated for fpc version 1.0.x)
Definitions represent the type information for all possible symbols which can be encountered by the parser. The definition types are associated with symbols in the symbol table, and are used by the parsing process (among other things) to perform type checking.
The current possible definition types are enumerated in TDefType and can have one of the following symbolic values:
deftype of TDef object | Description |
---|---|
AbstractDef | |
ArrayDef | array type definition |
RecordDef | record type definition |
PointerDef | pointer type definition |
OrdDef | ordinal (numeric value) type definition |
StringDef | string type definition |
EnumDef | enumeration type definition |
ProcDef | procedure type definition |
ObjectDef | object or class type definition |
ErrorDef | error definition (empty, used for error recovery) |
FileDef | file type definition |
FormalDef | |
SetDef | set type definition |
ProcVarDef | procedure variable type definition |
FloatDef | floating point type definition |
ClassrefDef | |
ForwardDef |
base definition (TDef)
All type definitions are based on this object. Therefore all derived object all posess the fields in this object in addition to their own private fields.
file definition (TFileDef)
The file definition can occur in only some rare instances, when a file of type is parsed, a file definition of that type will be created. Furthermore, internally, a definition for a Text file type and untyped File type are created when the system unit is loaded. These types are always defined when compiling any unit or program.
formal definition (TFormalDef)
forward definition (TForwardDef)
The forward definition is created, when a type is declared before an actual definition exists. This is the case, when, for example type PMyObject = TMyObject, while TMyObject has yet to be defined.
error definition (TErrorDef)
This definition is actually an empty definition entry. When the parser encounters an error when parsing a definition instead of putting nothing in the type for a symbol, it puts this entry. This avoids illegal memory accesses later in parsing.
pointer definition (TPointerDef)
The pointer definition is used for distinguishing between different types of pointers in the compiler, and are created at each typename parsing construct found.
object definition (TObjectDef)
The object definition is created each time an object declaration is found in the type declaration section.
Object Options(TObjectOptions) | Description |
---|---|
oo_is_class | This is a delphi styled class declaration, and not a Turbo Pascal object. |
oo_is_forward | This flag is set to indicate that the object has been declared in a type section, but there is no implementation yet. |
oo_has_virtual | This object / class contains virtual methods |
oo_has_private | This object / class contains private fields or methods |
oo_has_protected | This object / class contains protected fields or methods |
oo_has_constructor | This object / class has a constructor method |
oo_has_destructor | This object / class has a destructor method |
oo_has_vmt | This object / class has a virtual method table |
oo_has_msgstr | This object / class contains one or more message handlers |
oo_has_msgint | This object / class contains one or more message handlers |
oo_has_abstract | This object / class contains one or more abstract methods |
oo_can_have_published | the class has runtime type information, i.e. you can publish properties |
oo_cpp_class | the object/class uses an C++ compatible class layout |
oo_interface | this class is a delphi styled interface |
class reference definition (TClassRefDef)
array definition (TArrayDef)
This definition is created when an array type declaration is parsed. It contains all the information necessary for array type checking and code generation.
record definition (TRecordDef)
The record definition entry is created each time a record type declaration is parsed. It contains the symbol table to the elements in the record.
ordinal definition (TOrdDef)
This type definition is the one used for all ordinal values such as char, bytes and other numeric integer type values. Some of the predefined type definitions are automatically created and loaded when the compiler starts. Others are created at compile time, when declared.
Base ordinal type (TBaseType) | Description |
---|---|
uauto | user defined ordinal type definition |
uvoid | Represents a void return value or node |
uchar | ASCII character (1 byte) |
u8bit | unsigned 8-bit value |
u16bit | unsigned 16-bit value |
u32bit | unsigned 32-bit value |
s16bit | signed 16-bit value |
s32bit | signed 32-bit value |
bool8bit | boolean 8-bit value |
bool16bit | boolean 16-bit value |
bool32bit | boolean 32-bit value |
u64bit | unsigned 64-bit value (not fully supported/tested) |
s64bit | signed 64-bit value |
uwidechar | Currently not supported and unused |
float definition (TFloatDef)
This type definition is the one used for all floating point values such as SINGLE, DOUBLE. Some of the predefined type definitions are automatically created and loaded when the compiler starts.
Base floating point type (TFloatType) | Description |
---|---|
s32real | IEEE Single precision floating point value |
s64real | IEEE Double precision floating point value |
s80real | Extended precision floating point value (cpu-specific, usually maps to double) |
s64comp | 63-bit signed value, using 1 bit for sign indication |
f16bit | Unsupported |
f32bit | Unsupported |
abstract procedure definition (tabstractprocdef)
This is the base of all routine type definitions. This object is abstract, and is not directly used in a useful way. The derived object of this object are used for the actual parsing process.
Procedure options (TProcTypeOption) | Description |
---|---|
poType_ProgInit | Routine is the program entry point (defined as ‘main’ in the compiler). |
poType_UnitInit | Routine is the unit initialization code |
(defined as unitname_init in the compiler
poType_UnitFinalize Routine is the unit exit code
(defined as unitname_finalize in the compiler)
poType_Constructor Routine is an object or class constructor poType_Destructor Routine is an object or class destructor poType_Operator Procedure is an operator
call options (TProcCallOptions) | Description |
---|---|
pocall_clearstack | The routine caller clears the stack upon return |
pocall_leftright | Send parameters to routine from left to right |
pocall_cdecl | Passing parameters is done using the GCC alignment scheme, passing parameter values is directly copied into the stack space |
pocall_register | unused (Send parameters via registers) |
pocall_stdcall | Passing parameters is done using GCC alignment scheme, standard GCC registers are saved |
pocall_safecall | Standard GCC registers are saved |
pocall_palmsssyscall | This is a special syscall macro for embedded system |
pocall_system | unused |
pocall_inline | Routine is an inline assembler macro (not a true call) |
pocall_internproc | System unit code generator helper routine |
pocall_internconst | System unit code generator helper macro routine |
routine options (TProcOptions) | Description |
---|---|
po_classmethod | This is a class method |
po_virtualmethod | This is a virtual method |
po_abstractmethod | This is an abstract method |
po_staticmethod | This is a static method |
po_overridingmethod | This is an overriden method (with po_virtual flag usually) |
po_methodpointer | This is a method pointer (not a normal routine pointer) |
po_containsself | self is passed explicitly as a parameter to the method |
po_interrupt | This routine is an interrupt handler |
po_iocheck | IO checking should be done after a call to the procedure |
po_assembler | The routine is in assembler |
po_msgstr | method for string message handling |
po_msgint | method for int message handling |
po_exports | Routine has export directive |
po_external | Routine is external (in other object or lib) |
po_savestdregs | Routine entry should save all registers used by GCC |
po_saveregisters | Routine entry should save all registers |
po_overload | Routine is declared as being overloaded |
procedural variable definition (TProcVarDef)
This definition is created when a procedure variable type is declared. It gives information on the type of a procedure, and is used when assigning and directly calling a routine through a pointer.
procedure definition (TProcDef)
When a procedure head is parsed, the definition of the routine is created. Thereafter, other fields containing information on the definition of the routine are populated as required.
string definition (TStringDef)
This definition represents all string types as well as derived types. Some of the default string type definitions are loaded when the compiler starts up. Others are created at compile time as they are declared with a specific length type.
String type (TStringType) | Description |
---|---|
st_default | Depends on current compiler switches, can either be a st_ShortString or st_AnsiString |
st_shortstring | short string (length byte followed by actual ASCII characters (1 byte/char)) |
st_longstring | long string (length longint followed by actual ASCII characters (1 byte/char)) |
st_ansistring | long string garbage collected (pointer to a length, reference count followed by actual ASCII characters (1 byte/char)) |
st_widestring | long string garbage collected (pointer to a length, reference count followed by actual unicode characters (1 word/char (utf16))) |
enumeration definition (TEnumDef)
An enumeration definition is created each time an enumeration is declared and parsed. Each element in the enumeration will be added to the enumeration symtable and if $SCOPEDENUMS directive is off then to the unit symtable also.
set definition (TSetDef)
This definition is created when a set type construct is parsed (set of declaration).
set type (TSetType) | Description |
---|---|
NormSet | Normal set of up to 256 elements (32 byte storage space required) |
SmallSet | Small set of up to 32 elements (4 byte storage space) |
VarSet | Variable number of element set (storage size is dependent on number of elements) (currently unused and unsupported) |
Definition interface
(last updated for fpc version 1.0.x)
Источник
Сообщения и коды ошибок
- Out of memory (выход за границы памяти) Компилятору не хватает памяти. Имеется ряд возможных решений этой проблемы:
- Если в опции COMPILE/DESTINATION установлено значение MEMORY, замените эту опцию на DISK.
- Если в опции OPTIONS/COMPILER/LINK установлено значение MEMORY, замените эту опцию на DISK.
- Если Вы используете постоянно помещенные в память (резидентные) обслуживающие программы, такие как WINDOWS, SIDEKICK, NORTON
удалите их из памяти. - Если Вы используете интегрированную среду TURBO.EXE, то попробуйте воспользоваться компилятором ТРС.ЕХЕ, он занимает меньше памяти.
- Если ни одна из рекомендаций не помогает, то, возможно, Ваша программа просто слишком велика, чтобы компилировать ее в таком объеме памяти. В этом случае Вы должны разбить её на два или более модулей.
- Ваш исходный файл закончился перед последним END основного раздела
Источник
В этом разделе описаны все ошибки, которые могут случиться при проверке типов.
Сообщение |
Описание |
---|---|
Error: Type mismatch |
Это может произойти во многих случаях: •Назначенная вами переменная отличается от типа, который используется в выражении •Вы вызываете функцию или процедуру с параметрами, которые несовместимы с параметрами в объявлении функции или процедуры |
Error: Incompatible types: got «Сообщ1» expected «Сообщ2» |
Невозможно преобразование между двумя типами. Ещё одна причина – типы объявлены в разных объявлениях: Var A1 : Array[1..10] Of Integer; |
Error: Type mismatch between «Сообщ1» and «Сообщ2» |
Типы не являются эквивалентными. |
Error: Type identifier expected |
Идентификатор не является типом, или вы забыли указать идентификатор type. |
Error: Variable identifier expected |
Это случается, если вы помещаете константу в процедуру (такую как Inc или Dec), в то время как процедура требует переменной. Для таких процедур в качестве параметров можно помещать только переменные. |
Error: Integer expression expected, but got «Сообщение» |
Компилятор ожидает выражения типа integer, но получает другой тип. |
Error: Boolean expression expected, but got «Сообщение» |
Выражение должно быть типа boolean. Оно должно возвращать True или False. |
Error: Ordinal expression expected |
Выражение должно быть порядкового типа, то есть максимум типа Longint. Эта ошибка случается, например, если вы указали второй параметр процедуры Inc или Dec, который не соответствует порядковому типу. |
Error: pointer type expected, but got «Сообщение» |
Переменная или выражения не являются указателем. Это случается, если вы помещаете переменную, которая не является указателем, в New или Dispose. |
Error: class type expected, but got «Сообщение» |
Переменная или выражение не являются типом class. Это обычно случается, если 1.Родительский класс в объявлении класса не является классом 2.Обработчик исключения (On) cсодержит идентификатор типа, который не является классом. |
Error: Can’t evaluate constant expression |
Эта ошибка может случиться, если границы объявленного вами массива не обозначены порядковыми константами. |
Error: Set elements are not compatible |
Вы пытаетесь выполнить операцию с двумя множествами, в то время как типы элементов этих множеств не являются одинаковыми. Базовые типы множеств должны быть одинаковыми при объединении. |
Error: Operation not implemented for sets |
Некоторые бинарные операторы не определены для множеств. Это операторы: div, mod, **, >= и <=. Последние два могут быть определены для множеств в будущих версиях. |
Warning: Automatic type conversion from floating type to COMP which is an integer type |
Обнаружено явное преобразование типов из real в comp. s encountered. Поскольку comp – это 64-битное целое число, то это может вызвать ошибку. |
Hint: use DIV instead to get an integer result |
Если подсказки включены, то целочисленное деление с оператором ‘/‘ приведёт к этому сообщению, потому что результатом будет вещественный тип. |
Error: string types doesn’t match, because of $V+ mode |
Если выполняется компиляция в режиме {$V+}, то строка, передаваемая вами в качестве параметра, должна быть точно такого же типа, как параметр процедуры. |
Error: succ or pred on enums with assignments not possible |
Если вы объявили перечисляемый тип в стиле С, например, так: Tenum = (a,b,e:=5); То вы не сможете использовать функции Succ или Pred с этим перечислением. |
Error: Can’t read or write variables of this type |
Вы пытаетесь прочитать или записать переменную из файла или в файл текстового типа, который не поддерживает тип переменной. Только целочисленные типы, вещественные, pchars и strings можно читать из файла или записывать в текстовый файл. Логические переменные можно только записывать в текстовый файл. |
Error: Can’t use readln or writeln on typed file |
readln и writeln можно использовать только с текстовыми файлами. |
Error: Can’t use read or write on untyped file. |
read и write допускаются только для текстовых или типизированных файлов. |
Error: Type conflict between set elements |
Это означает, что не менее одного элемента множества имеют неправильный тип. |
Warning: lo/hi(dword/qword) returns the upper/lower word/dword |
Free Pascal поддерживает перегруженную версию lo/hi для longint/dword/int64/qword, которые возвращают наименьшее/наибольшее (результат типа слово/двойное слово) значение аргумента. Turbo Pascal позволяет использовать 16-битные lo/hi, которые возвращают биты 0..7 для lo и биты 8..15 для hi. Если вы хотите получить поведение, аналогичное Turbo Pascal, вы должны использовать приведение типов к word или integer. |
Error: Integer or real expression expected |
Первый аргумент для str должен быть типа real или integer. |
Error: Wrong type «Сообщение» in array constructor |
Вы пытаетесь использовать тип в конструкторе массива, который недопустим. |
Error: Incompatible type for arg no. Сообщ1: Got «Сообщ2», expected «Сообщ3» |
Вы пытаетесь передать неправильный тип в указанный параметр. |
Error: Method (variable) and Procedure (variable) are not compatible |
Вы не можете связать метод с процедурной переменной или процедуру с указателем на метод. |
Error: Illegal constant passed to internal math function |
Аргумент-константа, переданный в функцию ln или sqrt выходит за пределы диапазона для этой функции. |
Error: Can’t take the address of constant expressions |
Невозможно получить адрес выражения-константы, потому что оно не записывается в память. Вы можете попробовать сделать типизированную константу. Эта ошибка может также появиться, если вы пытаетесь поместить свойство в параметр var. |
Error: Argument can’t be assigned to |
Только выражение, которое может быть в левой части присваивания, может быть передано как вызов по ссылке аргумента. Примечание: Свойства могут использоваться в левой части присваивания, тем не менее, они не могут использоваться как аргументы. |
Error: Can’t assign local procedure/function to procedure variable |
Не допускается присваивать локальные процедуры/функции процедурным переменным, потому что соглашение о вызовах локальных процедур/функций отличаются. Вы можете только присвоить локальную процедуру/функцию пустому указателю. |
Error: Can’t assign values to an address |
Не допускается присваивать значение адресу переменной, константы, процедуры или функции. Вы можете попытаться выполнить компиляцию с опцией -So, если идентификатор является процедурной переменной. |
Error: Can’t assign values to const variable |
Не допускается присваивать значение переменной, которая объявлена как константа. Обычно параметр объявляется как константа. Чтобы иметь возможность изменять значение, передавайте параметр по значению или параметр по ссылке (используя var). |
Error: Array type required |
Если вы хотите получить доступ к переменной, используя индекс ‘[<x>]‘, то тип должен быть массивом. В режиме FPC указатель также допускается. |
Error: interface type expected, but got «»Сообщение» |
Компилятор ожидал для нумератора имя типа интерфейса, но получил нечто другое. Следующий код приведёт к этой ошибке: Type |
Hint: Mixing signed expressions and longwords gives a 64bit result |
Если вы делите (или вычисляете модуль) выражения со знаком с типом longword (или наоборот), или если вы имеете переполнение и/или включена проверка диапазона и используется арифметическое выражение (+, -, *, div, mod), в котором оба числа со знаком и появляется longwords, то всё это вычисляется как 64-битная арифметическая операция, которая медленнее, чем обычная 32-битная. Вы можете избежать этого при помощи преобразования типа одного из операндов в подходящий для результата и другого операнда. |
Warning: Mixing signed expressions and cardinals here may cause a range check error |
Если вы используете бинарный оператор (and, or, xor) и один из операндов — это longword, в то время как другой – это выражение со знаком, то, если проверка диапазона включена, вы можете получить ошибку проверки диапазона, потому что в этом случае оба операнда преобразуются в longword перед выполнением операции. Вы можете избежать этого при помощи преобразования типа одного из операндов в подходящий для результата и другого операнда. |
Error: Typecast has different size (Сообщ1 -> Сообщ2) in assignment |
Преобразование типа при отличающихся размерах не допускается, когда переменная используется в присваивании. |
Error: enums with assignments can’t be used as array index |
Если вы объявили перечисляемый тип, который имеет С-подобные присваивания, как показано ниже: Tenum = (a,b,e:=5); Вы не можете использовать его как индекс массива. |
Error: Class or Object types «Сообщ1» and «Сообщ2» are not related |
Выборка из одного класса в другой, в то время как класс/объект не являются связанными. Вероятно, это ошибка ввода. |
Warning: Class types «arg1» and «arg2» are not related |
Выборка из одного класса в другой, в то время как класс/объект не являются связанными. Вероятно, это ошибка ввода. |
Error: Class or interface type expected, but got «arg1» |
Компилятор ожидал имя класса или интерфейса, но получил другой тип или идентификатор. |
Error: Type «Сообщение» is not completely defined |
Эта ошибка случается, если тип не завершён, например, тип pointer, который указывает на неопределённый тип. |
Warning: String literal has more characters than short string length |
Размер строки-константы, которая связана с shortstring, больше максимального размера для shortstring (255 символов). |
Warning: Comparison is always false due to range of values |
Это сравнение беззнакового значения и константы со знаком, которая меньше нуля. По причине преобразования оператор всегда будет возвращать FALSE. Выполните явное преобразование константы в правильный диапазон, чтобы избежать этой проблемы. |
Warning: Comparison is always true due to range of values |
Это сравнение беззнакового значения и константы со знаком, которая меньше нуля. По причине преобразования оператор всегда будет возвращать TRUE. Выполните явное преобразование константы в правильный диапазон, чтобы избежать этой проблемы. |
Warning: Constructing a class «Сообщ1» with abstract method «Сообщ2» |
Например, создаваемый класс содержит неисполняемые абстрактные методы. Имеется вероятность, что случится ошибка времени исполнения 211 в коде, если эта процедура будет когда-либо вызвана. Все абстрактные методы должны быть перегружаемыми. |
Hint: The left operand of the IN operator should be byte sized |
Левый операнд в операторе IN не является порядковым или перечислением, который помещается в 8 бит. Это может привести к ошибке проверки диапазона. На текущий момент оператор in поддерживает левый оператор только в пределах байта. В случае с перечислениями, размер элемента перечисления может изменяться опциями {$PACKENUM} или {$Zn}. |
Warning: Type size mismatch, possible loss of data / range check error |
Это случается, когда меньшему типу присваивается значение, большее, чем исходный тип. Это означает, что может произойти ошибка проверки диапазона или уменьшение значения. |
Hint: Type size mismatch, possible loss of data / range check error |
Это случается, когда меньшему типу присваивается значение, большее, чем исходный тип. Это означает, что может произойти ошибка проверки диапазона или уменьшение значения. |
Error: The address of an abstract method can’t be taken |
Не найдено тело абстрактного метода, поэтому адрес абстрактного метода не может быть назначен. |
Error: Assignments to formal parameters and open arrays are not possible |
Вы пытаетесь присвоить значение формальному параметру (нетипизированный var, const или out), или открытому массиву. |
Error: Constant Expression expected |
Компилятор ожидал выражение-константу, но получил выражение- переменную. |
Error: Operation «Сообщ1» not supported for types «Сообщ2» and «Сообщ3» |
Операция не допускается для указанных типов. |
Error: Illegal type conversion: «Сообщ1» to «Сообщ2» |
Когда выполняете преобразование типов, вы должны понимать, что размеры переменной и типа назначения одинаковы. |
Hint: Conversion between ordinals and pointers is not portable |
Если вы преобразуете тип pointer в longint (или наоборот), то код не будет компилироваться на машинах, использующих 64-разрядную адресацию. |
Warning: Conversion between ordinals and pointers is not portable |
Если вы преобразуете тип pointer в порядковый тип с другим размером (или наоборот), то могут возникнуть проблемы. Это предупреждение помогает в поиске 32-битного специального кода, где cardinal/longint используются для преобразования указателей в порядковые типы. Решением проблемы является использование вместо этого типов ptrint/ptruint. |
Error: Can’t determine which overloaded function to call |
Вы вызываете перегруженную функцию с параметром, который не связан с каким-либо объявленным списком параметров, например, когда вы имеете объявленную функцию с параметрами word и longint, а затем вызываете её с параметром типа integer. |
Error: Illegal counter variable |
Переменная для цикла for должна быть порядкового типа. Переменные циклов не могут быть вещественными числами или строками. |
Warning: Converting constant real value to double for C variable argument, add explicit typecast to prevent this. |
В C значения вещественных констант по умолчанию имеют тип double. Из этих соображений, когда вы передаёте вещественную константу в функцию С в качестве параметра, компилятор FPC по умолчанию преобразует её в тип double. Если вы хотите контролировать этот процесс, добавьте для константы явное преобразование в нужный тип. |
Error: Class or COM interface type expected, but got «Сообщение» |
Некоторые операторы, такие как AS, применяются только для классов или COM-интерфейсов. |
Error: Constant packed arrays are not yet supported |
Вы не можете объявить битовый (упакованный) массив как типизированную константу. |
Error: Incompatible type for arg no. Сообщ1: Got «Сообщ2» expected «(Bit)Packed Array» |
Компилятор ожидает битовый (упакованный) массив как указанный параметр. |
Error: Incompatible type for Сообщение no. Сообщ1: Got «Сообщ2» expected «»(not packed) Array» |
Компилятор ожидает регулярный (то есть НЕ упакованный) массив как указанный параметр. |
Error: Elements of packed arrays cannot be of a type which need to be initialised |
Поддержка упакованных массивов, которым необходима инициализация (таких как ansistrings, или записей, содержащих ansistrings), пока не реализована. |
Error: Constant packed records and objects are not yet supported |
Вы не можете объявить битовый (упакованный) массив как типизированную константу в данное время. |
Warning: Arithmetic «Сообщение» on untyped pointer is unportable to {$T+}, suggest typecast |
Сложение/вычитание из нетипизированных указателей может работать по разному в {$T+}. Используёте преобразование типов для типизированных указателей. |
Error: Can’t take address of a subroutine marked as local |
Нельзя получить адрес подпрограммы, помеченной как локальная. |
Error: Can’t export subroutine marked as local from a unit |
Подпрограмма, помеченная как локальная, не может быть экспортирована из модуля. |
Error: Type is not automatable: «Сообщение» |
Только byte, integer, longint, smallint, currency, single, double, ansistring, widestring, tdatetime, variant, olevariant, wordbool и все интерфейсы являются automatable. |
Hint: Converting the operands to «Сообщение» before doing the add could prevent overflow errors. |
Сложение двух типов может вызвать ошибку переполнения. Обычно вы конвертируете результат в больший тип. Вы должны предотвращать такие ошибки, преобразуя операнды в этот тип перед сложением. |
Hint: Converting the operands to «Сообщение» before doing the subtract could prevent overflow errors. |
Вычитание между двумя типами может вызвать ошибку переполнения. Обычно вы конвертируете результат в больший тип. Вы должны предотвращать такие ошибки, преобразуя операнды в этот тип перед вычитанием. |
Hint: Converting the operands to «Сообщение» before doing the multiply could prevent overflow errors. |
Умножение между двумя типами может вызвать ошибку переполнения. Обычно вы конвертируете результат в больший тип. Вы должны предотвращать такие ошибки, преобразуя операнды в этот тип перед умножением. |
Warning: Converting pointers to signed integers may result in wrong comparison results and range errors, use an unsigned |
Виртуальное адресное пространство на виртуальных машинах располагается от $00000000 до $ffffffff. Многие операционные системы позволяют выделять память с адресами выше $80000000. Например, как WINDOWS, так и LINUX, допускают использование указателей в диапазоне от $0000000 до $bfffffff. Если вы преобразуете типы со знаком, это может вызвать ошибки переполнения и проверки диапазона, но также $80000000 < $7fffffff. Это может вызвать случайную ошибку в коде, подобно этому: «if p>q». |
Error: Interface type Сообщение has no valid GUID |
Если применяется оператор as для интерфейса или класса, то интерфейс (то есть правый операнд оператора as) должен иметь правильный GUID. |
Error: Invalid selector name |
Селектор Objective-C не может быть пустым, он должен быть правильным идентификатором или одинарным двоеточием, а если он содержит менее одного двоеточия, он также должен быть завершён. |
Error: Expected Objective-C method, but got Сообщение |
Селектор может быть создан только для методов Objective-C, не для любых других процедур/функций/методов. |
Error: Expected Objective-C method or constant method name |
Селектор может быть создан только для методов Objective-C, при задании имени используются строковые константы или идентификатор метода Objective-C, который является видимым из текущей области видимости. |
Error: No type info available for this type |
Информация о типах не генерируется для некоторых типов, таких как перечисления с пропусками в их диапазоне значений (включая перечисления, нижняя граница которых отлична от нуля). |
Error: Ordinal or string expression expected |
The expression must be an ordinal or string type. |
Error: String expression expected |
The expression must be a string type. |
Warning: Converting 0 to NIL |
Use NIL rather than 0 when initialising a pointer. |
Error: Objective-C protocol type expected, but got ”arg1” |
The compiler expected a protocol type name, but found something else. |
Error: The type ”arg1” is not supported for interaction with the Objective-C runtime |
Objective-C makes extensive use of run time type information (RTTI). This format is defined by the maintainers of the run time and can therefore not be adapted to all possible Object Pascal types. In particular, types that depend on reference counting by the compiler (such as ansistrings and certain kinds of interfaces) cannot be used as fields of Objective-C classes, cannot be directly passed to Objective-C methods, and cannot be encoded using objc_encode. |
Error: Class or objcclass type expected, but got ”arg1” |
It is only possible to create class reference types of class and objcclass |
Error: Objcclass type expected |
The compiler expected an objcclass type |
Warning: Coerced univ parameter type in procedural variable may cause crash or memory corruption: arg1 to arg2 |
univ parameters are implicitly compatible with all types of the same size, also in procedural variable definitions. That means that the following code is legal, because single and longint have the same size: {$mode macpas} Type TIntProc = procedure (l: univ longint); procedure test(s: single); begin writeln(s); end; var p: TIntProc; begin p:=test; p(4); end. This code may however crash on platforms that pass integers in registers and floating point values on the stack, because then the stack will be unbalanced. Note that this warning will not flagg all potentially dangerous situations. when test returns. |
Error: Type parameters of specializations of generics cannot reference the currently specialized type |
Recursive specializations of generics like Type MyType = specialize MyGeneric<MyType>; are not possible. |
Error: Type parameters are not allowed on non-generic class/record/object procedure or function |
Type parameters are only allowed for methods of generic classes, records or objects |
Error: Generic declaration of ”arg1” differs from previous declaration |
Generic declaration does not match the previous declaration |
Error: Helper type expected |
The compiler expected a class helper type. |
Error: Record type expected |
The compiler expected a record type. |
Error: Derived class helper must extend a subclass of ”arg1” or the class itself |
If a class helper inherits from another class helper the extended class must extend either the same class as the parent class helper or a subclass of it |
Error: Derived record helper must extend ”arg1” |
If a record helper inherits from another record helper it must extend the same record that the parent record helper extended. |
СООБЩЕНИЯ КОМПИЛЯТОРА ОБ ОШИБКАХ
§ Если в меню Options?Linker?Link Buffer, установлен параметр Memory, переключите его в значение Disk.
§ Возможно программа слишком велика, чтобы компилироваться в таком объеме памяти. Следует разбить ее на два или более модуля.
§ несоответствующее количество begin и end (не забудьте, что оператор case также заканчивается словом end);
§ включаемый файл заканчивается в середине раздела операторов. Каждый раздел операторов должен целиком помещаться в одном файле;
§ незаконченный комментарий.
§ несовместимые типы переменной и выражения в операторе присваивания;
§ несовместимые типы фактического и формального параметров в обращении к процедуре или функции;
§ тип выражения, несовместимый с типом индекса при индексировании массива;
§ несовместимые типы операндов в выражении.
§ Идентификатору функции можно присваивать значения только внутри раздела операторов данной функции.
§ Объектный файл .obj определяет идентификаторы PUBLIC, которые не находятся в сегменте CODE.
§ Идентификатор обозначает абсолютную переменную.
§ Идентификатор обозначает процедуру или функцию типа inline.
§ Файл .com содержит ссылки с размерами в байтах на перемещаемые идентификаторы. Такая ошибка происходит в случае, если вы используете операторы HIGH и DOWN с перемещаемыми идентификаторами или если вы ссылаетесь в директивах DB на перемещаемые идентификаторы.
§ Операнд ссылается на перемещаемый идентификатор, который не был определен в сегменте CODE или в сегменте DATA.
§ Операнд ссылается на процедуру EXTRN или функцию EXTRN со смещением, например CALL SortProc+8.
§ Процедуры или функции были описаны с помощью описания forward, но их определение не найдено.
§ Вы пытаетесь осуществить приведение типа выражения, когда разрешается только ссылка на переменную, процедуру или функцию.
§ Вы пытаетесь присвоить константу вне диапазона переменной.
§ Вы пытаетесь передать константу вне диапазона в качестве параметра процедуре или функции.
Размер локальных переменных, описанных в программе или функции, не может превышать 64 Кбайт.
Сообщения и коды ошибок
- Out of memory (выход за границы памяти)
- Если в опции COMPILE/DESTINATION установлено значение MEMORY, замените эту опцию на DISK.
- Если в опции OPTIONS/COMPILER/LINK установлено значение MEMORY, замените эту опцию на DISK.
- Если Вы используете постоянно помещенные в память (резидентные) обслуживающие программы, такие как WINDOWS, SIDEKICK, NORTON
удалите их из памяти. - Если Вы используете интегрированную среду TURBO.EXE, то попробуйте воспользоваться компилятором ТРС.ЕХЕ, он занимает меньше памяти.
- Если ни одна из рекомендаций не помогает, то, возможно, Ваша программа просто слишком велика, чтобы компилировать ее в таком объеме памяти. В этом случае Вы должны разбить её на два или более модулей.
- Indentifier expected (не указан идентификатор). Этот идентификатор не был описан.
- Unknow indentifier (неизвестный идентификатор). Этот идентификатор не был описан.
- Duplicate indentifier (двойной идентификатор). Попытка дважды описать один и тот же идентификатор.
- Syntax error (синтаксическая ошибка). В исходном тексте найден неверный символ. Возможно, Вы забыли заключить в кавычки строковую константу.
- Error in real constant (ошибка в вещественной константе).
- Error in integer constant (ошибка в целой константе). Учтите, что после целых действительных чисел, превышающих диапазон представления целых чисел (-2147483648…+2147483647), должны ставиться точка и нуль, например 12345678912.0.
- String constant exceeds line (строковая константа превышает допустимые размеры). Вероятно, Вы забыли поставить апостроф в конце строковой константы.
- Too many nested files (слишком много вложенных файлов). Компилятор допускает не более пяти вложенных исходных файлов.
- Unexpected end of file (не найден конец файла).
Вы могли получить это сообщение об ошибке по одной из следующих причин:- Ваш исходный файл закончился перед последним END основного раздела< операторов. Вероятно, в Вашей программе неодинаковое количество операторов BEGIN и END.
- Включаемый файл заканчивается в середине раздела операторов. Каждый
раздел операторов должен целиком помещаться в одном файле. - Вы не закончили комментарий.
- Line to long (слишком длинная строка). Максимальная длина строки, обрабатываемой компилятором, равна 126 символам (обратите внимание: редактор среды может обрабатывать до 249
символов в строке). - Type identifier expected (здесь нужен идентификатор типа). Не указан тип
идентификатора. - Too many open files (слишком много открытых файлов). Если появляется эта ошибка, то это означает, что конфигурационный файл CONFIG.SYS операционной системы не включает параметр FILES=XX или этот параметр указывает слишком мало файлов. Увеличьте число файлов до нужного значения, например, до 20.
- Invalid file name (неверное имя файла). Имя файла не верно или указан несуществующий путь.
- File not found (файл не найден). Файл не был найден в просмотренных
каталогах. - Disk full (диск заполнен). Удалите некоторые файлы или воспользуйтесь
новым диском. - Invalid compiler directive (неправильная директива компилятора). Неверная буква в директиве компилятора, один из параметров директивы компилятора неверный, или Вы пользуетесь глобальной директивой компилятора, когда компиляция тела программы уже началась.
- Too many files (слишком много файлов). В компиляции программы или программного модуля участвуют слишком много файлов. Попытайтесь не использовать так много файлов, например, объединяя включаемые файлы.
- Undefined type in pointer definition (неопределенный тип в объявлении указателя). Попытка объявить типизированный указатель, связанный с необъявленным типом данных.
- Variable identifier expected (отсутствует идентификатор переменной). На
этом месте должен быть идентификатор переменной. - Error in type (ошибка в объявлении типа). Объявление типа не может начинаться с этого символа.
- Structure too lage (слишком большая структура). Максимально допустимый размер любого структурированного типа -65520 байт.
- Set base type of range (базовый тип множества нарушает границы). Базовый тип множества должен представлять собой тип-диапазон с границами в пределах от 0 до 255 или перечисляемый тип с не более чем 256 значениями.
- File components may not be files (компонентами файла не могут быть файлы). Конструкции типа файл файлов не допускаются.
- Invalid string length (неверная длина строки). Длина строки должна находиться в диапазоне от 1 до 225.
- Type mismatch (несоответствие типов). Это сообщение может быть вызвано
следующими причинами:- Несовместимые типы переменной и выражения в операторе присваивания.
- Несовместимые типы фактического и формального параметров в обращении к процедуре или функции.
- Тип выражения несовместим с типом индекса при индексировании массива.
- Несовместимые типы операндов в выражении.
- Invalid subrange base type (неправильный базовый тип для типа-диапазона).Допустимыми базовыми типами являются все порядковые типы.
- Lower bound greater than upper bound (нижняя граница больше верхней).Описание типа-диапазона содержит неправильные границы.
- Ordinal type expected (нужен порядковый номер). Вещественные, строковые, структурные, процедурные типы и указатели в данном месте программы не допускаются.
- Integer constant expected (нужна целая константа).
- Constant expected (нужна константа).
- Integer or real constant expected (нужна целая или вещественная константа).
- Type identifier expected (нужен идентификатор типа).
- Invalid function result type (неправильный тип результата функции). Правильными типами результата функции являются все простые типы, строковые типы и указатели.
- Label identifier expected (нужен идентификатор метки). Метка не обозначена с помощью идентификатора, как это требуется из контекста программы.
- BEGIN expected (нужен BEGIN).
- END expected (нужен END).
- Integer expression expected (нужно выражение типа INTEGER).
- Ordinal expression expected (нужно выражение перечисляемого типа). Предшествующее выражение должно иметь перечисляемый тип.
- Boolean expression expected (нужно выражение типа BOOLEAN). Предшествующее выражение должно иметь тип BOOLEAN.
- Operand types do not match operator (типы операндов не соответствуют операции). Данная операция не может быть применена к указанным операндам, например, ‘A’ div ‘2’.
- Error in expression (ошибка в выражении). Данный символ не может участвовать в выражении указанным образом. Возможно, Вы забыли указать операцию между двумя операндами.
- Illegal assignment (неверное присваивание). Файлам и не типизированным переменным нельзя присваивать значения. Идентификатору функции можно присвоить значение только внутри раздела операторов данной функции.
- Field identifier expected (нужен идентификатор поля). Попытка использовать запись целиком в том месте, где требуется ссылка на какое-либо поле записи.
- Object file too large (объектный файл слишком большой). Турбо-Паскаль не может компоновать файлы .obj больше 64 Кбайт.
- Undefined external (неопределенная внешняя процедура). Внешняя процедура или функция не имеет соответствующего определения PUBLIC в объектном файле. Убедитесь, что вы указали все объектные файлы в директивах (SL filename} и проверьте написание идентификаторов процедуры или функции в файле .asm.
- Invalid object file record (неправильная запись объектного файла). Файл .obj содержит неверную объектную запись. Убедитесь, что данный файл является действительно файлом .obj
- Code segment too large (сегмент кода слишком большой). Максимальный размер кода программы или программного модуля равняется 65520 байт. Если вы компилируете программный модуль, разбейте его на два или более программных модуля.
- Data segment too large (сегмент данных слишком велик). Максимальный размер сегмента данных программы равен 65520 байт, включая данные, используемые программными модулями. Если вам нужно большее количество глобальных данных, опишите большие структуры с помощью указателей и выделяйте для них память с помощью процедуры NEW.
- DO expected (нужен оператор DO).
- Invalid PUBLIC definition (неверное определение PUBLIC). Возможные причины сообщения:
- Данный идентификатор получил тип PUBLIC, с помощью соответствующей директивы языка ассемблер, но не соответствует описанию EXTERNAL в программе или программном модуле Паскаля.
- Две или более директивы PUBLIC языка ассемблер определяют один и тот же идентификатор.
- Файлы .obj определяют символы PUBLIC, не находящиеся в сегменте CODE.
- Invalid EXTRN definition (неправильное определение EXTRN). Возможные причины сообщения:
- Программа на ассемблере ссылается с помощью директивы ETRN на идентификатор, который не описан в программе на Паскале и не был описан в интерфейсных секциях используемых программных модулей.
- Ассемблерная программа ссылается на идентификатор, обозначающий абсолютную переменную (т.е. определённую словом ABSOLUTE).
- Ассемблерная программа ссылается на идентификатор процедуры или функции типа INLINE.
- Too many EXTRN definition (слишком много определений типа EXTRN).Турбо-Паскаль не может обрабатывать файлы .obj при более чем 256 определениях EXTRN.
- OF expected (требуется OF).
- INTERFACE expected (требуется интерфейсная секция).
- Invalid relocatable reference (недействительная перемещаемая ссылка). Возможные причины сообщения:
- Файл .obj содержит данные и перемещаемые ссылки в сегментах, отличных от CODE. Например, Вы пытаетесь описать инициализированные переменные в сегменте DATA.
- Файл .com содержит ссылки с размерами в байтах на перемещаемые символы. Такая ошибка происходит в случае, если Вы используете, операторы HIGH и DOWN с перемещаемыми символами или если Вы ссылаетесь в директивах DB на перемещаемые символы.
- Операнд ссылается на перемещаемый символ, который не был определен в сегменте CODE или в сегменте DATA.
- Операнд ссылается на процедуру EXTRN или функцию EXTRN со сдвигом, например, CALL SortProc +8.
- THEN expected (требуется THEN).
- TO or DOWNTO expected (требуется ТО или DOWNTO).
- Undefined forward (неопределенное опережающее описание). Возможные причины сообщения:
- Были описаны процедура или функция в интерфейсной секции программного модуля, но их определение отсутствует в секции реализации.
- Процедуры или функции были описаны с помощью опережающего описания, но их определение не найдено.
- Too many procedures (слишком много процедур). Турбо-Паскаль не допускает более 512 процедур или функций в одном модуле. Если Вы компилируете программу, то поместите некоторые процедуры или функции в модули. Если Вы компилируете модуль, то разбейте его на два или несколько модулей.
- Invalid typecast (неверное преобразование типа). Возможные причины сообщения:
- Попытка разместить в памяти, занимаемой некоторой переменной, значение выражения другого типа в случае, когда размер размещаемого значения не равен размеру переменной.
- Вы пытаетесь осуществить преобразование типа выражения, когда разрешается только ссылка на переменную, процедуру или функцию.
- Division by zero (деление на ноль). Предшествующая операция пытается выполнить деление на ноль.
- Invalid file type (неверный файловый тип). Данный файловый тип не обслуживается процедурой обработки файлов. Например, процедура READLN используется для типизированного файла, или процедура SEEK -для текстового файла.
- Cannot Read or Write variables of this type (нет возможности считать или записать переменные данного типа). Нарушены следующие ограничения:
- Процедуры READ и READLN могут считывать переменные символьного, целого, действительного и строкового типа.
- Процедуры WRITE и WRITELN могут выводить переменные символьного, целого, действительного, логического и строкового типа.
- Pointer variable expected (нужно использовать переменную-указатель). Предыдущая переменная должна быть указателем.
- String variable expected (нужна строковая переменная). Предшествующая переменная должна иметь строковый тип.
- String expression expected (нужно выражение строкового типа). Предшествующее выражение должно иметь строковый тип.
- Unit not found (программный модуль не найден). Один или несколько программных модулей, используемых данным модулем, не указаны в предложении USES.
- Unit name mismatch (несоответствие имен программных модулей). Имя программного модуля, найденное в файле .tpu, не соответствует имени, указанному в предложении USES.
- Unit version mismatch (несоответствие версий программных модулей). Один или несколько программных модулей, используемых данной программой, были изменены после их компиляции. Воспользуйтесь опцией COMPILE/MAKE или COMPILE/BUILD в интегрированной интерактивной среде или опциями /М или /В в компиляторе ТРС, что позволит автоматически скомпилировать программные модули, нуждающиеся в перекомпиляции.
- Duplicate unit name (повторное имя программного модуля). Вы уже указали этот программный модуль в операторе USES.
- Unit file format error (ошибка формата файла модуля). Файл .tpu является недействительным. Убедитесь, что это действительно файл .tpu.
- Implementation expected (отсутствует исполняемая часть модуля).
- Constant and case types do not match (типы констант и тип выражения оператора CASE не соответствуют друг другу). Тип константы оператора CASE не совместим с выражением в операторе варианта.
- Record variable expected (нужна переменная типа запись). Предшествующая переменная должна иметь тип запись.
- Constant out of range (константа нарушает границы). Возможные причины сообщения:
- Вы пытаетесь указать индекс массива, выходящий за его границы.
- Вы пытаетесь присвоить переменной значение, выходящее за границы, допустимые для типа этой переменной.
- Вы пытаетесь передать в качестве фактического параметра процедуре или функции константу, выходящую за границы, допустимые для типа соответствующего формального параметра.
- File variable expected (нужна файловая переменная). Предшествующая переменная должна иметь файловый тип.
- Pointer expression expected (нужно выражение типа указатель).
Предшествующее выражение должно иметь тип указателя. - Integer or real expression expected (нужно выражение типа REAL или INTEGER). Предшествующее выражение должно иметь тип (REAL или INTEGER)
- Label not within current block (метка не находится внутри текущего блока). Оператор GOTO не может ссылаться на метку, находящуюся вне текущего блока.
- Label already defined (метка уже определена). Данная метка уже помечает оператор.
- Undefined label in processing statement part (неопределенная метка в предшествующем разделе операторов). Данная метка была описана, и на неё осуществлялась ссылка в предшествующем разделе операторов, но она не указана в тексте программы.
- Invalid @ argument (недействительный аргумент операции @).Действительными аргументами являются идентификаторы переменных, процедур и функций.
- Unit expected (нужно кодовое слово UNIT).
- «;» expected (нужно указать «;» ).
- «:» expected (нужно указать «:» .
- «,» expected (нужно указать «,» ).
- «(» expected (нужно указать «(» ).
- «)» expected (нужно указать «)» ).
- «=» expected (нужно указать «=» ).
- «:=» expected (нужно указать «:=» ).
- «[» or «(.» expected (нужно «[» или «(.»).
- «]» or «.)» expected (нужно «]» или «.)»).
- «.» expected (нужно «.»).
- «..» expected (нужно «..»).
- Too many variables (слишком много переменных). Возможные причины сообщения:
- Общий размер глобальных переменных, описанных в программе или программном модуле, не может превышать 64 Кбайт.
- Размер локальных переменных, описанных в программе или функции, не может превышать 64 Кбайт.
- Invalid FOR control variable (неправильная управляющая переменная оператора FOR). Управляющая переменная оператора FOR должна быть переменной перечисляемого типа, определенной в разделе описаний текущей программы.
- Integer variable expected (нужна переменная целого типа) предшествующая переменная должна иметь целый тип. )
- Files are not allowed here (здесь не допускаются файлы). Типизированная константа не может иметь файловый тип.
- String length mismatch (несоответствие длины). Длина строковой константы не соответствует количеству элементов символьного массива.
- Invalid ordering of fields (неверный порядок полей). Поля в константе типа запись должны записываться в порядке их описания.
- String constant expected (нужна константа строкового типа).
- Integer or real variable expected (нужна переменная типа INTEGER или REAL). Предшествующая переменная должна иметь целый или вещественный тип.
- Ordinal variable expected (нужна переменная порядкового типа). Предшествующая переменная должна иметь порядковый тип.
- INLINE error (ошибка в операторе INLINE). Оператор «<» не допускается в сочетании с перемещаемыми ссылками на переменные. Такие ссылки всегда имеют размер в слово.
- Character expression expected (предшествующее выражение должно иметь символьный тип).
- Too many relocation items (слишком много перемещаемых элементов).Размер таблицы перемещения файла .ехе превышает 64К, что является верхним пределом в Турбо-Паскале. Если вы обнаружили эту ошибку, то это значит, что программа просто слишком велика для обработки компоновщиком Турбо-Паскаля. Возможно также, что она слишком велика для выполнения в PC DOS. В таком случае нужно выделить в программе основной раздел, который выполнял бы обращение к двум или более вспомогательным разделам с помощью процедуры EXEC из модуля DOS.
- Not enough memory to run program (недостаточно памяти для выполнения программы). Недостаточно памяти для выполнения программы из среды Турбо-Паскаля. Попытайтесь воспользоваться рекомендациями, связанными с ошибкой 1. Если это не поможет, то скопируйте свою программу на диск, выйдите из среды и запустите программу средствами ДОС.
- Cannot find EXE file (невозможно найти файл .ехе). по какой-то причине файл .ехе сгенерированный ранее компилятором, исчез.
- Cannot run a unit (модуль выполнить нельзя). Вы не можете выполнить программный модуль. Чтобы проверить его, напишите программу, использующую этот программный модуль.
- Compilation aborted (компиляция прервана). Компиляция была прервана с помощью CTRL-BREAK.
- CASE constant out of range (константа CASE нарушает допустимые границы). Целочисленные константы оператора CASE должны находиться в диапазоне от -32768 до 32767.
- Error in statement (ошибка в операторе). Данный символ не может быть первым символом в операторе.
- Cannot call an interrupt procedure (невозможно вызвать процедуру прерывания). Вы не можете непосредственно вызвать процедуру прерывания.
- Must have an 8087 to compile this (для компиляции необходимо наличие сопроцессора 8087). Для компиляции программ и программных модулей в режиме {$N+} необходим сопроцессор 8087. Используйте программную эмуляцию сопроцессора с помощью директивы {$N+.E+}.
- Must be in 8087 mode to compile this (для компиляции необходим режим 8087). Данная программа может быть скомпилирована только в режиме {$N+}. В состоянии {$N-} операции с типами SINGLE, DOUBLE, EXTENDED и СОМР не допускаются.
- Target address not found (указанный адрес не найден). Команда COMPILER/FIND ERROR в среде Турбо-Паскаля или опция /F в командной строке компилятора ТРС.ЕХЕ не обнаружила оператор, соответствующий заданному адресу.
- Include files are not allowed here (здесь не допускаются включаемые файлы). Раздел операторов должен целиком размещаться в одном файле.
- TMP file format error (ошибка формата файла .ТМР). Файл .ТМР является недействительным. Убедитесь, что этот файл является в действительности файлом .ТМР.
- NIL expected (нужен NIL).
- Invalid qualifier (неверный идентификатор). Возможные причины сообщения:
- Вы пытаетесь индексировать переменную, которая не является массивом.
- Вы пытаетесь указать поля в переменной, которая не является записью.
- Вы пытаетесь использовать в качестве указателя переменную, которая не является указателем.
- Invalid variable reference (недействительная ссылка на переменную). Предыдущая конструкция удовлетворяет синтаксису ссылки на переменную, но она не указывает адрес памяти. Наиболее вероятно, что Вы вызываете функцию-указатель, но забываете поставить знак ? после неё.
- Too many symbols (слишком много символов). Программа или программный модуль содержат более 64 Кбайт символов. Если Вы компилируете программу с директивой {$D+},xo попробуйте отключить эту директиву или разбейте программу на несколько модулей.
- Statement part too large (слишком большой раздел операторов). Турбо-Паскаль ограничивает размер раздела операторов примерно до 24 Кбайт. Если Вы обнаружили эту ошибку, поместите части раздела операторов в одну или несколько процедур и вообще сделайте Вашу программу более структурированной.
- Module has no debug information (в модуле нет отладочной информации). Ошибка периода выполнения обнаружена в модуле (программе), который не имеет отладочной информации, и по этой причине Турбо-Паскаль не может указать соответствующий оператор. Перекомпилируйте модуль с включенной опцией {$D+} или воспользуйтесь опцией COMPILER/FIND ERROR, чтобы найти эту ошибку.
- Files must be var parameters (файлы должны передаваться как параметры-переменные). Вы пытаетесь передать процедуре или функции параметр-значение файлового типа. Параметры файлового типа должны быть параметрами-переменными.
- Too many conditional symbols (слишком много условных символов). Не хватает памяти для определения условных символов (слов, управляющих командами условной компиляции). Попытайтесь удалить некоторые символы или уменьшить их длину.
- Misplaced conditional directive (пропущена условная директива). Компилятор обнаружил директиву {$ELSE} или {$ENDIF} без соответствующих директив {$IFDEF}, {$IENDEF} или {$IFOPT}.
- ENDIF directive missing (пропущена директива ENDIF). Исходный файл закончился внутри конструкции условной компиляции. В исходном файле должно быть равное количество директив {$IFxxx} и {$ENDIF}.
- Error in initial conditional defines (ошибка в условных определениях).
Исходные условия компиляции, указанные в опции
OPTIONS/COMPILER/CONDITIONAL DEFINES являются недействительными. В Турбо-Паскале разрешается не указывать условия компиляции; если же приведено несколько условий, они должны разделяться точкой с запятой. - Header does not match previous definition (заголовок не соответствует
предыдущему определению). Возможные причины сообщения:- Заголовок процедуры или функции, указанный в интерфейсной секции, не соответствует заголовку в исполняемой части.
- Заголовок процедуры или функции, указанный с помощью опережающего описания (FORWARD), не соответствует заголовку найденной далее одноименной процедуры или функции.
- Critical disk error (критическая ошибка диска). Во время компиляции
произошла критическая ошибка диска (например, дисковод находится в
состоянии «не готов»). - Cannot evaluate this expression (нельзя вычислить данное выражение). В
выражении-константе или в отладочном выражении Вы пытаетесь
использовать неподдерживаемые средства, например в описании константы
пытаетесь использовать функцию SIN или вызвать в отладочном выражении
определенную пользователем функцию. - Expression incorrectly terminated (некорректное завершение выражения).
Контекстуально в данном месте программы должен быть конец выражения
или оператора. - Invalid format specifier (неверный спецификатор формата). Используется
неверный спецификатор формата или числовой аргумент спецификатора
формата выходит за допустимые границы. - Invalid indirect reference (недопустимая косвенная ссылка). Оператор пытается осуществить недопустимую косвенную ссылку. Например, Вы используете абсолютную переменную, базовая переменная которой в текущем модуле неизвестна, или используете программу типа INLINE , в которой делается ссылка на переменную, неопределенную в текущем модуле.
- Structured variable are not allowed here (здесь нельзя использовать переменную структурного типа). Делается попытка выполнить надпеременной структурного типа неподдерживаемую операцию. Например, Вы пытаетесь перемножить две записи.
- Cannot evaluate without System unit (нельзя вычислить выражение без модуля SYSTEM). Чтобы отладчик смог вычислить выражение, в файле TURBO.TPL должен содержаться модуль SYSTEM.
- Cannot access this symbol (нет доступа к данному символу). Как только вы скомпилируете программу, все множество её символов станет доступным. Однако к отдельным символам (например, к переменным) нельзя получить доступ, пока Вы не запустите программу.
- Invalid floating-point operation (недопустимая операция с плавающей запятой). При операции с плавающей запятой произошло переполнение или деление на ноль.
- Cannot compile overlay to memory (нельзя выполнить компиляцию оверлеев в память). Программа, использующая оверлеи, должна компилироваться на диск.
- Procedure or function variable expected (должна использоваться переменная процедурного типа). В этом контексте оператор получения адреса @ может использоваться только с переменной процедурного типа.
- Invalid procedure or function reference (недопустимая ссылка на процедуру или функцию). Возможные причины сообщения:Попытка вызова процедуры в выражении.Процедура или функция, использующая в качестве параметра вызов другой процедуры или функции, должна компилироваться в состоянии {$F+} и не
может описываться с помощью ключевых слов INLINE или INTERRUPT . - Cannot overlay this unit (этот модуль не может использоваться в качестве оверлейного). Попытка использовать в качестве оверлейного модуль, который не был скомпилирован с директивой {$О+}.
- File not found (не найден файл). Ошибка генерируется процедурами RESET, APPEND, RENAME, или ERASE, если имя, присвоенное файловой переменной, указывает несуществующий файл.
- Path not found (путь не найден). Ошибка генерируется
процедурами:
• RESET, REWRITE, APPEND или ERASE, если имя,
присвоенное файловой переменной, является недействительным
или указывает на несуществующий подкаталог.
• CHDIR, MKDIR или RMDIR, если путь является
недействительным или указывает на несуществующий
подкаталог. - Too many open files (слишком много открытых файлов). Ошибка генерируется процедурами RESET, REWRITE или APPEND, если программа имеет слишком много открытых файлов. Операционная система ДОС не позволяет использовать более 15 открытых файлов для каждого процесса. Если Вы получили данное сообщение при наличии менее 15 открытых файлов, это может означать, что файл CONFIG.SYS не содержит параметр FILES = xxx или этот параметр задает слишком мало файлов. Увеличьте параметр FILES = xxx до какого-либо подходящего значения, например, до 20.
- File access defined (отказано в доступе к файлу). Данная ошибка генерируется процедурой:
• RESET или APPEND, когда имя, присвоенное файловой
переменной, указывает каталог или файл, доступный только для
чтения, в то время как параметр FILEMODE файловой
переменной содержит указание на запись данных.
• REWRITE, если каталог заполнен или если имя, присвоенное
файловой переменной, задает каталог или существующий файл,
доступный только для чтения.
• RENAME, если имя присвоенное файловой переменной,
указывает каталог или если новое имя указывает существующий
файл.
• ERASE, если имя, присвоенное файловой переменной, указывает
каталог или файл, доступный только для чтения.
• MKDIR, если файл с тем же именем уже существует в каталоге, в
котором создается подкаталог, и в этом каталоге нет места для
подкаталога или путь к каталогу содержит имя логического
устройства.
• RMDIR, если каталог не является пустым, если путь не
определяет каталог или если путь задает корневой каталог.
• READ или BLOCKREAD в случае типизированного или
нетипизированного файла, если файл не открыт для чтения.
• WRITE или BLOCKWRITE для типизированного или
нетипизированного файла, если этот файл не открыт для записи. - Invalid file handle (недопустимый файловый канал). Данная ошибка генерируется, когда системному вызову ДОС передается недопустимый файловый канал. Эта ошибка не должна возникать в правильно работающей программе. Её появление является свидетельством того, что файловая переменная каким-либо образом испорчена.
- Invalid file access code (недействительный код доступа к файлам). Ошибка генерируется процедурами RESET или APPEND, если значение параметра FILEMODE в файловой переменной не является допустимым.
- Invalid drive number (недопустимый номер дисковода). Ошибка генерируется процедурой GETDIR, если номер дисковода не является допустимым.
- Cannot remove current directory (нельзя удалить текущий каталог). Ошибка генерируется процедурой RMDIR, если путь указывает текущий каталог.
- Cannot rename across drives (нельзя при переименовании указывать разные дисководы). Генерируется процедурой RENAME, если оба файла не находятся на одном и том же диске.
- Disk read error (ошибка чтения с диска). Генерируется
процедурой READ в типизированном файле, если Вы пытаетесь
осуществить считывание после конца файла. - Disk write error (ошибка записи на диск). Ошибка генерируется процедурами CLOSE, WRITE, WRITELN, FLUSH, если диск заполнен.
- File not assigned (файлу не присвоено имя), ошибка генерируется процедурами RESET REWRITE , APPEND, RENAME и ERASE в случае, если файловой переменной не было присвоено имя файла с помощью обращения к процедуре ASSIGN.
- File not open (файл не открыт). Ошибка генерируется процедурами CLOSE, READ, WRITE, SEEK, EOF, FILEPOS, FILESIZE, FLUSH, BLOCKREAD, BLOCKWRITE, если файл не открыт.
- File not open for input (файл не открыт для ввода).ошибка генерируется процедурами READ, READLN, EOF, EOLN, SEEKEOF, или SEEKEOLN в текстовом файле, если файл не открыт для ввода.
- File not open for output (файл не открыт для вывода). Ошибка генерируется процедурами WRITE или WRITELN в текстовом файле, если файл не открыт для вывода.
- Invalid numeric format (неверный числовой формат). Ошибка генерируется процедурами READ или READLN, если числовое значение, считанное из текстового файла, не соответствует правильному числовому формату.
- Disk is write protected (диск защищен от записи).
- Unknown unit (неизвестный модуль).
- Drive not ready (дисковод находится в состоянии «не готов»).
- Unknown command (неопознанная команда).
- CRC error in data (ошибка в исходных Данных).
- Bad drive requiest structure length (при обращении к диску указана неверная длина структуры).
- Disk seek error (ошибка при операции установки головок на диске).
- Unknown media type (неизвестный тип носителя).
- Sector not found (сектор не найден).
- Printer out of paper (закончилась бумага на принтере)
- Device write fault (ошибка при записи на устройство).
- Device read fault (ошибка при чтении с устройства).
- Hardware failure (сбой аппаратуры).
- Division by zero (деление на нуль).
- Range check error (ошибка при проверке границ). Ошибка генерируется операторами, скомпилированными в состоянии {$R+}, при возникновении одной из следующих ситуаций:
- Индексное выражение массива находилось вне допустимого диапазона.
- Была осуществлена попытка присвоить переменной значение, находящееся вне диапазона переменной.
- Была осуществлена попытка передать значение, находящееся вне допустимого диапазона, в качестве параметра процедуре или функции.
- Stack overflow error (переполнение стека). Эта ошибка генерируется при входе в процедуру или функцию, скомпилированную в режиме {$8+}, если нет достаточной области для размещения локальных переменных программы. Увеличьте размер стека, используя директиву компилятора {$М}.
-
Heap overflow error (переполнение кучи). Эта ошибка
генерируется процедурами NEW или GETMEM в случае, если в
куче не хватает памяти требуемого размера. - Invalid pointer operation (недействительная операция с указателем). Эта ошибка генерируется процедурами DISPOSE или FREEMEM, когда указатель имеет значение NIL или содержит адрес, лежащий за пределами динамически распределяемой области памяти.
- Floating point overflow (переполнение при операции с плавающей запятой).
- Floating point underflow (исчезновение порядка при операции с плавающей запятой). Эта ошибка генерируется только в том случае, если используется сопроцессор 8087/80287/80387 с управляющим словом, которое демаскирует ошибку исчезновения порядка. По умолчанию исчезновение порядка приводит к возвращению результата, равного нулю.
-
Invalid floating point operation (недопустимая операция с плавающей запятой). Возможные причины сообщения:
- Аргумент функции TRUNC или ROUND не может быть
преобразован в целое число, находящееся внутри диапазона типа
LONGINT (от -2147483648 до +2147483647). - Отрицательный аргумент функции SQRT (извлечение квадратного корня).
- Аргумент функции LN (логарифм) равен нулю или имеет отрицательное значение.
- Произошло переполнение стека сопроцессора.
- Аргумент функции TRUNC или ROUND не может быть
- Overlay manager not installed (не установлена подсистема управления оверлеем). Ваша программа- вызывает оверлейную процедуру или функцию, а подсистема управления оверлеем не инициализирована. Вероятнее всего в программе отсутствует обращение к процедуре OVRINIT или обращение к этой процедуре завершилось с ошибкой. Нужно иметь в виду, что если в каком-либо из оверлейных модулей содержится раздел инициализации, то в программе необходимо создать дополнительный или использовать имеющийся неоверлейный модуль, вызывающий процедуру OVRINIT в своем разделе инициализации, и указать этот модуль в предложении USES перед любым из оверлейных модулей.
- Overlay file read error (ошибка чтения оверлейного файла). Когда подсистема управления оверлеем пыталась считать оверлей из оверлейного файла, произошла ошибка чтения.
Компилятору не хватает памяти. Имеется ряд возможных решений этой проблемы:
Ошибки, возникающие во время выполнения программы
Некоторые ошибки, обнаруженные во время выполнения программы, приводят к появлению на экране сообщения вида Runtime error nnn at xxxx:yyyy (ошибка времени выполнения nnn по адресу ххххгуууу), после чего программа завершает свою работу.
Ошибки времени выполнения делятся на две категории: ошибки ввода-вывода (коды ошибок с 1 до 199) и грубые ошибки (коды ошибок с 200 до 255).
Ошибки ввода-вывода вызывают завершение выполнения программы в случае, если оператор ввода-вывода был скомпилирован в режиме {$!+}. В режиме {$!-} продолжается выполнение программы, а ошибка возвращается функцией IORESULT. Коды ошибок 1-99 соответствуют кодам ошибок ДОС. 100-149 — ошибкам ввода вывода, 150-199 — критическим ошибкам, а 200-255 — фатальным ошибкам.
Ошибки DOS:
Ошибки ввода-вывода:
Если один из операторов компилируется с директивой {$!+}, то ошибка ввода-вывода приводит к прекращению выполнения программы. В состоянии {$!-} программа продолжает выполняться, а ошибка возвращается функцией IORESULT.
Критические ошибки:
Фатальные ошибки:
Грубые ошибки всегда приводят к немедленной остановке программы.
Сообщение компилятора об ошибках
Если
ошибка возникает при компиляции внутри
TP,
Турбо Паскаль активизирует окно
редактирования и помещает курсор на
место ошибки в исходной программе.
Если
ошибка возникает при использовании
командно-строчного компилятора, Турбо
Паскаль выдает сообщение об ошибке,
выводит на экран исходную строку
программы с ошибкой и ее номер; символ
^ в выдаваемой исходной строке указывает
местоположение ошибки. Ошибки
подразделяются на:
-
ошибки
при компилировании программы; -
ошибки
на уровне DOS; -
ошибки
ввода-вывода.
Ошибки при компилировании
1
Out of memory (Выход за пределы памяти)
Данная
ошибка появляется, если компилятор
израсходовал всю доступную ему память.
Возможно, ваша программа или программный
модуль слишком велики, чтобы компилировать
их в таком объеме памяти. В этом случае
программу или программный модуль
необходимо разбить на два или более
программных модуля.
2
Identifier expected (Ожидается идентификатор)
В этом месте должен
находиться идентификатор.
3
Unknown Identifier (Неизвестный идентификатор)
Этот идентификатор
не был описан.
4
Duplicate Identifier (Повторение идентификатора)
5
Syntax error (Синтаксическая ошибка)
В исходном тексте
найден недопустимый символ. Возможно,
не заключена в кавычки строковая
константа.
6
Error in real constant (Ошибка в константе
вещественного типа)
Ошибка в синтаксисе
константы вещественного типа.
7
Error In Integer constant (Ошибка
в
константе
целого
типа)
Ошибка
в синтаксисе константы целого типа
(Учтите, что после чисел, превышающих
диапазон представления целых чисел,
должны ставиться точка и нуль, например
12345678912.0.).
8
String constant exceeds line (Строковая константа
превышает размеры строки)
Вероятно, после
строковой константы отсутствует символ
кавычка.
9
Too many nested files (Слишком много вложенных
файлов)
Компилятор допускает
не более 15 вложенных исходных файлов и
не более 4 включаемых файлов.
10
Unexpected end of file (Неожиданный
конец
файла)
Данное сообщение
может появиться по одной из следующих
причин:
В Вашей программе,
вероятнее всего, неодинаковое количество
операторов BEGIN и END.
Включаемый
файл заканчивается в середине раздела
операторов (Каждый раздел операторов
должен целиком помещаться в одном
файле).
В Вашем файле не
закрыты скобки комментария.
11
Line too long (Строка слишком длинная)
Максимальная длина
строки не может превышать 127 символов.
12
Type Identifier expected (Ожидается идентификатор
типа)
В определенном
месте не указан тип идентификатора.
13
Too many open files (Слишком много открытых
файлов)
В
файле CONFIG.SYS не установлен параметр
FILES = N, где N — представляет собой целое
число без знака. Установите в файле
CONFIG.SYS значение параметра FILES = N >= 30.
14
Invalid file name (Недопустимое имя файла)
Имя файла неверно
или указан несуществующий путь.
15
File not found (Файл
не
найден)
Файл
не найден ни в одном из каталогов,
предназначенных для хранения файлов
данного типа.
16
Disk full (Диск заполнен)
Удалите
с диска ненужные Вам файлы (например
файлы с расширением .ВАК или .ТМР) или
попробуйте сохранить текст программы
на другом диске, который имеет достаточный
объем свободной памяти.
17
Invalid compiler directive (Недопустимая директива
компилятора)
Неверная
буква в директиве компилятора, один из
параметров директивы компилятора
неверный или Вы пользуетесь глобальной
директивой компилятора, когда компиляция
тела программы уже началась.
18
Too many files (Слишком много файлов)
В
компиляции программы или программного
модуля участвует слишком много файлов.
Попытайтесь не использовать так много
файлов, например, объединяя включаемые
файлы.
19
Undefined type la pointer definition (Неопределенный
тип в описании указателя)
Вы
пытаетесь объявить типизированный
указатель, связанный с ранее необъявленным
типом данных.
20
Variable Identifier expected (Ожидается идентификатор
переменной)
В указанном курсором
месте ожидается идентификатор переменной.
21
Error in type (Ошибка в определения типа)
Определение типа
не может начинаться с этого символа.
22
Structure too large (Слишком длинная структура)
Максимально
допустимый размер любого структурированного
типа — 65520 байтов.
23
Set base type of range (Количество элементов в
множестве превышает допустимое значение)
Базовый
тип множества должен представлять собой
интервальный или перечисляемый тип
данных с не более чем 256 значениями.
24
File components may not be files or objects (Компоненты
файла
не
могут
быть
файлами
или
объектами)
Тип
компонентов файла не может быть объектным
типом, файловым типом или любым другим
структурированным типом, содержащим
компоненты типа файла или объекта.
25Invalid
string length (Неверная длина строки)
Длина описываемой
строки должна находиться в пределах
от 1 до 255.
26
Type mismatch (Несоответствие типов)
Причины, вызвавшие
появление данного сообщения, могут быть
следующими:
Несовместимы типы
переменной и выражения в операторе
присваивания.
Несовместимые
типы фактического и формального
параметров в обращении к процедуре или
функции.
Тип выражения
несовместимый с типом индекса при
индексировании массива.
Несовместимые
типы операндов в выражении.
27
Invalid subrange base type (Неправильный базовый
тип для интервала)
28Lower
bound greater than upper bound (Нижний
граница
превышает
верхнюю)
При
описании интервального типа данных Вы
объявили нижнюю границу диапазона
больше верхней.
29
Ordinal type expected (Ожидается перечисляемый
тип)
Вещественные,
строковые, структурные и ссылочные типы
в данном случае не допускаются.
30
Integer constant expected (Ожидается константа
целого типа)
31
Constant expected (Ожидается константа)
32
Integer or real constant expected (Ожидается константа
целого или вещественного типа)
33Pointer
type Identifier expected (Ожидается идентификатор
типа указатель)
Указанный курсором
идентификатор не является указателем.
34
Invalid function result type (Недопустимый тип
результата функция)
Правильными типами
результата функции являются все простые,
строковые и ссылочные типы.
35
Label Identifier expected (Ожидается идентификатор
метки)
Обнаружена ссылка
на метку, не описанную в разделе LABEL.
36
BEGIN expected (Ожидается оператор BEGIN)
37
END expected (Ожидается оператор END)
38
Integer expression expected (Ожидается выражение
целого типа)
39
Ordinal expression expected (Ожидается выражение
перечисляемого типа)
40
Boolean expression expected (Ожидается выражение
логического типа)
41
Operand types do not match operator (Несоответствие
типов
операнду)
Данная
операция не может применяться к операндам
этого типа. Такое сообщение будет
вызвано, например, при попытке выполнить
следующую операцию:’ 9′ DIV ‘G’ .
42
Error in expression (Ошибка
в
выражении)
Данный
идентификатор не может участвовать в
выражении указанным образом.
Возможно, вы забыли
указать операцию между двумя операндами.
43
Illegal assignment (Запрещенное присваивание)
Это сообщение
может появиться по следующим причинам:
-
файлам
и нетипизированным переменным нельзя
присваивать значения; -
идентификатору
функции можно присваивать значения
только внутри раздела операторов данной
функции.
44
Field Identifier expected (Ожидается идентификатор
поля)
Данный идентификатор
не соответствует полю предшествующей
переменной типа RECORD или OBJECT.
45
Object file too large (Объектный файл слишком
большой)
Турбо Паскаль не
может компоновать OBJ-файлы размером
больше чем 64 Кбайта.
46
Undefined external (Не определена внешняя
процедура)
Внешняя процедура
или функция не имеет соответствующего
определения PUBLIC в объектном файле.
Убедитесь, что вы указали все объектные
файлы в директивах {$L <имя ОВJ-файла>),
и проверьте написание идентификаторов
процедуры или функции в файле .ASM.
47
Invalid object file record
(Недопустимая
запись объектного файла)
Файл .OBJ содержит
неверную объектную запись. Убедитесь
в том, что данный файл является
действительно OBJ-файлом.
48
Code segment too large (Сегмент кода слишком
большой)
Максимально
допустимый размер кода программы или
программного модуля ранен 65520 байтам.
Разбейте Вашу программу или программный
модуль на несколько частей.
49
Data segment too large (Сегмент данных слишком
большой)
Максимальный
размер сегмента данных программы равен
65520 байтам, включая данные, описываемые
используемыми программными модулями.
Если нужно большее количество глобальных
данных, опишите большие структуры с
помощью указателей и выделяйте для них
память динамически с помощью процедуры
New.
50
DO expected (Ожидается оператор DO)
51
Invalid PUBLIC definition (Недопустимое
определение
PUBLIC)
Появление этого
сообщения возможно но следующим причинам:
-
Данный
идентификатор получил тип PUBLIC с помощью
соответствующей директивы языка
ассемблер, но не соответствует описанию
EXTERNAL в программе или программном модуле. -
Две
или более директивы PUBLIC на языке
ассемблера определяют один и тот же
идентификатор. -
OBJ-файл
определяет идентификатор PUBLIC вне
сегмента CODE.
52
Invalid EXTRN definition (Неправильное определение
EXTRN)
Появление этого
сообщения возможно по следующим причинам:
Из Ассемблера была
осуществлена ссылка с помощью директивы
EXTRN на идентификатор, который не был
описан в тексте Паскаль-программы.
Идентификатор
обозначает абсолютную переменную.
Идентификатор
обозначает процедуру или функцию типа
INLINE.
53
Too many EXTRN definition (Слишком много определений
типа EXTRN)
Турбо
Паскаль не может обрабатывать файлы
.OBJ при более чем 256 определениях EXTRN.
54
OF expected (Ожидается
оператор
OF)
55
INTERFACE expected (Ожидается
оператор
INTERFACE)
56
Invalid relocatable reference (Недопустимая
перемещаемая
ссылка)
Появление этого
сообщения возможно по следующим причинам:
-
OBJ-файл
содержит данные и перемещаемые ссылки
в сегментах, отличных от CODE, например,
при попытке описать инициализированные
переменные в сегменте DATA. -
ORJ-файл
содержит ссылки с размерами в байтах
на перемещаемые символы. Такая ошибка
происходит в случае использования
операторов HIGH и DOWN с перемещаемыми
символами или, если Вы ссылаетесь в
директивах DB на перемещаемые символы. -
Операнд
ссылается на перемещаемый символ,
который не был определен в сегментах
CODE или DATA. -
Операнд
ссылается на процедуру EXTRN или функцию
EXTRN со смещением, например CALL SortProc+8.
Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #
- #