Here we give a list of things which are de ned/allowed in Turbo Pascal, but which are not
supported by Free Pascal. Where possible, we indicate the reason.
     
     - Duplicate case labels are permitted in Turbo Pascal, but not in Free Pascal. This is
     actually a bug in Turbo Pascal, and so support for it will not be implemented in Free
     Pascal.
     
- In Turbo Pascal, parameter lists of previously de ned functions and procedures did
     not  have  to  match  exactly.  In  Free  Pascal,  they  must.  The  reason  for  this  is  the
     function overloading mechanism of Free Pascal. However, the -M (see page 5.1.5) option
     overcomes this restriction.
                                                                            
                                                                            
     
- The Turbo Pascal variables MEM, MEMW, MEML and PORT for memory and port access
     are not available in the system unit. This is due to the operating system. Under dos,
     the extender unit (GO32.PPU) implements the mem constuct. Under linux, the ports
     unit implements such a construct for the Ports variable.
     
- Turbo Pascal allows you to create procedure and variable names using words that are
     not permitted in that role in Free Pascal. This is because there are certain words that
     are reserved in Free Pascal (and Delphi) that are not reserved in Turbo Pascal, such as:
     PROTECTED, PUBLIC, PUBLISHED, TRY, FINALLY, EXCEPT, RAISE. Using the -Mtp
     switch will solve this problem if you want to compile Turbo Pascal code that uses these
     words (chapter B, page 489 for a list of all reserved words).
     
- The Turbo Pascal reserved words FAR, NEAR are ignored. This is because their purpose
     was limited to a 16-bit environment and Free Pascal is a 32-bit/64-bit compiler.
     
- The Turbo Pascal INTERRUPT directive will work only on the Free Pascal dos target.
     Other operating systems do not allow handling of interrupts by user programs.
     
- By default the Free Pascal compiler uses AT&T assembler syntax. This is mainly because
     Free  Pascal  uses  gnu as.  However,  other  assembler  forms  are  available.  For  more
     information, see the Programmers guide.
     
- Turbo Pascal's Turbo Vision is available in Free Pascal under the name of FreeVision,
     which should be almost 100% compatible with Turbo Vision.
     
- Turbo Pascal's 'overlay' unit is not available. It also isn't necessary, since Free Pascal
     is a 32/64-bit compiler, so program size shouldn't be an issue.
     
- The command line parameters of the compiler are di erent.
     
- Compiler switches and directives are mostly the same, but some extra exist.
     
- Units are not binary compatible. That means that you cannot use a .tpu unit  le,
     produced by Turbo Pascal, in a Free Pascal project.
     
- The  Free  Pascal  TextRec structure  (for  internal  description  of   les)  is  not  binary
     compatible with TP or Delphi.
     
- Sets are by default 4 bytes in Free Pascal; this means that some typecasts which were
     possible in Turbo Pascal are no longer possible in Free Pascal. However, there is a
     switch to set the set size, see Programmers guide for more information.
     
- A  le is opened for output only (using fmOutput) when it is opened with Rewrite. In
     order to be able to read from it, it should be reset with Reset.
                                                                            
                                                                            
     
- Turbo Pascal destructors allowed parameters. This is not permitted in Free Pascal: by
     default, in Free Pascal, Destructors cannot have parameters. This restriction can be
     removed by using the -So switch.
     
- Turbo Pascal permits more than one destructor for an object. In Free Pascal, there can
     be only one destructor. This restriction can also be removed by using the -So switch.
     
- The order in which expressions are evaluated is not necessarily the same. In the following
     expression:
                                                                            
                                                                            
     
     it is not guaranteed that g(2) will be evaluated before f(3).
      
- In Free Pascal, you need to use the address @ operator when assigning procedural
     variables.