afficher >><< masquer ]
SAMPI - Editeur structuré
1. Le Problème et la Proposition
2. Le Langage Primitif de Représentation Textuelle
2.1. Présentation de la Syntaxe Concrète
2.2. Notations
2.3. Exemple de structuration des données
2.4. Exemple de structuration des traitements
2.5. Exemple de structurations connexes
3. Le Langage Complété pour la Structuration des Textes
3.1. Présentation de la Syntaxe Complétée
3.2. Etude quantitative de l'évolution des programmes
3.3. L'édition syntaxique
3.4. étude de cas : le langage LTR3 et l'atelier ENTREPRISE
4. L'Enrichissement du Langage par de Nouveaux Concepts
4.1. Présentation de la Syntaxe Abstraite
4.2. Les difficultés
4.3. Compléter la Syntaxe
5. La Formalisation des Solutions Techniques
5.1. L'évaluation fonctionnelle
5.2. La structuration par les objets
5.3. Modèle sémantique comparé de l'évaluateur
5.4. Comparaison critique
5.5. Construction de la Syntaxe Abstraite
6. Les Comparaisons avec d'autres Approches
7. Les Perspectives
8. Les Editeurs
8.0. brisé sur la barrière de la complexité (une fois de plus)
8.1. L'éditeur ligne : Manuel de l'utilisateur
8.2. L'éditeur page : Guide de l'utilisateur
9. Les Aspects d'Implantation
9.1. Contexte d'évaluation
9.2. La Syntaxe Abstraite : Manuel du concepteur
9.3. L'éditeur page : Guide de l'implanteur
Références
Rubrique Perl-Javascript
P1. Syntaxe de l'éditeur structuré
P2. Fonction wsText
P3. Fonction defText
P4. Fonctions useText - evalText
P5. Fonction refText
P6. Fonction attrText

Rubrique Perl-Javascript

Pour les inconditionnels, cette section présente les fonctions Perl et Javascript qui implémentent la syntaxe présentée.

1. Syntaxe de l'éditeur structuré

2. Fonction wsText

3. Fonction defText

4. Fonctions useText - evalText

5. Fonction refText

6. Fonction attrText

1. Syntaxe de l'éditeur structuré

Définition de texte : def

Un « texte » :
(def nom env rep)
est représenté par :
/#( nom : rep env /#)
env est une liste d'attributs déclarés pour le « texte » nom de la forme :
/# attr1 = rep1
/# attr2 = rep2
...

La forme générale d'un « texte » sera donc :
/#( nom : rep /# attr1 = rep1 /# attr2 = rep2 ... /#)

Utilisation de texte : use

Une utilisation de « texte » :
(use nom)
est représentée dans une valeur de représentation par :
[# nom ]

Une utilisation sélective d'un attribut de « texte », rapportée à un attribut déclaré :
/# attr = cas ? rep1 : rep2
est représentée par :
[# attr = casUse ]
et est évaluée :
rep1 : si casUse = cas
rep2 : si casUsecas

Une utilisation optionnelle d'un « texte » est représentée par :
[? nom : rep ?]
et est évaluée :
rep : si nom(vide) (plus précisément si [#nom] ≠ (vide))
(vide) : si nom = (vide)

Exemple

Dans l'environnement :
/#(decl:local [?deux:(?][#un][?deux:,[#deux])?];/#)
/#(decl1:[#decl]/#un=$x/#)
/#(decl2:[#decl]/#un=$x/#deux=$y/#)
on évalue :
[#decl1] s'évalue : local $x;
[#decl2] s'évalue : local ($x,$y);