Section courante

A propos

Section administrative du site

Particularité d'Apple Pascal

Voici les différentes particularité de l'Apple Pascal.

Identificateurs

Le caractère de soulignement est autorisé dans les identificateurs; cependant, le compilateur l'ignore. Par conséquent, les identificateurs :

  1. FIG_LEAF
  2. FIGLEAF

sont équivalents. (Le clavier Apple n'a pas le caractère de soulignement, mais certains terminaux externes en ont.)

Instructions CASE

En Pascal Standard, s'il n'y a pas d'étiquette de cas égale à la valeur du sélecteur de cas, le résultat de l'instruction de cas n'est pas défini. Dans Apple Pascal, si aucune étiquette de cas ne correspond à la valeur du sélecteur de cas, l'instruction suivante exécutée est l'instruction suivant l'instruction de cas.

Commentaires

Le compilateur Apple Pascal reconnaît tout texte apparaissant entre les symboles (* et *) ou les symboles { et } comme un commentaire. Le texte apparaissant entre ces symboles est ignoré par le compilateur sauf si le premier caractère du commentaire est un signe dollars, auquel cas le commentaire est interprété comme une option du compilateur. Si le début du commentaire est délimité par le symbole (*, la fin du commentaire doit être délimitée par le symbole correspondant *), plutôt que par le symbole }. Lorsque le commentaire commence par le symbole {, le commentaire continue jusqu'à ce que le symbole correspondant } apparaisse. Cette fonctionnalité vous permet de "commenter" une section d'un programme contenant elle-même des commentaires. Il s'applique uniquement aux terminaux externes, puisque le seul délimiteur de commentaire disponible sur Apple est la paire (* et *). Un exemple de la façon dont les deux types de délimiteurs de commentaires sont utilisés sur un terminal externe :

  1. { XCP := XCP + 1; (* Ajustement pour les cas spéciales ... *) } 

Le compilateur ne garde pas trace des commentaires imbriqués. Lorsqu'un symbole de commentaire est rencontré, le texte est analysé à la recherche du symbole de commentaire correspondant. Le texte suivant entraînera une erreur de syntaxe :

  1. (* CECI EST UN COMMENTAIRE (* Commentaire imbriqué *) FIN DU PREMIER COMMENTAIRE *)
  2. (*                                                    ↑erreur ici. *)

GOTO

L'Apple Pascal a une forme plus limitée de déclaration GOTO que le Pascal Standard. La destination de l'instruction GOTO doit être dans la même procédure que l'instruction GOTO elle-même (en considérant le programme principal comme une procédure). Le compilateur considère qu'une instruction GOTO est illégale sauf si l'option du compilateur (*$G+*) est utilisée.

Entêtes de programme

Bien que le compilateur Apple Pascal autorise la présence d'une liste de paramètres de fichier après l'identificateur de programme (comme dans le Pascal Standard), ces paramètres sont ignorés par le compilateur et n'ont aucun effet sur le programme en cours de compilation.

Limites de taille

Voici une liste des limitations de taille maximale imposées à l'utilisateur par l'implémentation actuelle d'Apple Pascal :

Comparaisons étendues

L'Apple Pascal permet des comparaisons = et <> de tableaux exactement du même type et de structures d'enregistrement exactement du même type. Il peut être fait sans indice (dans le cas des tableaux) ni identificateurs de champ (dans le cas des enregistrements). Par exemple, compte tenu des déclarations :

  1. VAR A: ARRAY[0..10] OF INTEGER;
  2.     B: ARRAY[0..10] OF INTEGER;

alors la déclaration suivante est légale :

  1. IF A=B THEN ...

et l'instruction suivant THEN sera exécutée si chaque élément de A est égal à l'élément correspondant de B.

Procédures et fonctions en tant que paramètres

L'Apple Pascal ne permet pas qu'un PROCEDURE ou FUNCTION soit déclarée comme paramètre formel dans la liste de paramètres d'une autre PROCEDURE ou FUNCTION.

Types d'enregistrements

Il existe deux restrictions sur les déclarations de type d'enregistrement qui sont différentes de la syntaxe Pascal Standard :

La fonction ORD

La fonction ORD acceptera un paramètre de type POINTER et retournera la valeur numérique du pointeur.

Lorsque la fonction ORD reçoit une valeur BOOLEAN en tant que paramètre réel, le résultat n'est pas toujours 0 ou 1. Il est très peu probable qu'un programme de travail rencontre un jour cette situation, car il y a peu de raisons de prendre la fonction ORD d'une valeur BOOLEAN.



Dernière mise à jour : Dimanche, le 28 mars 2021