Annotation of rpl/LIMITATIONS, revision 1.53
1.1 bertrand 1: RESTRICTIONS
2: Only sequential formatted files are supported.
3:
1.52 bertrand 4: Créer une librpl.so pour pouvoir créer des programmes utilisant motif !
1.49 bertrand 5:
1.1 bertrand 6: Économisons notre mépris eut égard au nombre de nécessiteux.
7: Chateaubriand.
8:
1.47 bertrand 9: Regarder les d_ep_division_par_zero pour coller un undef à la place.
10:
1.53 ! bertrand 11: ->TAG TAG-> DTAG
! 12: ->UNIT UNIT-> DUNIT
! 13:
1.37 bertrand 14: Convertir avec le nouveau système de la gestion de la mémoire :
15: - READ FLOW (longueur_effective ligne 2815)
16: rpl/src/'`instructions_w1-conv.c
17: instructions_w1-conv.c: In function ‘librpl_instruction_write’:
18: instructions_w1-conv.c:1603: warning: ‘ios’ may be used uninitialized in this
19: function
20: instructions_w1-conv.c:431: warning: ‘chaine’ may be used uninitialized in this
21: function
22:
1.32 bertrand 23: Traiter SIGTERM
1.33 bertrand 24: RUN
1.36 bertrand 25: Ajouter MULTICAST (pour les sockets)
1.37 bertrand 26: Rajouter le test des dépassements pour INCR et DECR
1.33 bertrand 27:
1.36 bertrand 28: Ajouter TeXmacs
1.18 bertrand 29:
1.1 bertrand 30: Dessiner les niveaux sur les graphes
31: { "main" { "default" } { "automatic" 10 } } axes redraw
32: Ne fonctionne pas...
33:
1.48 bertrand 34: -> I:integer scalar, J:integer scalar << >>
35:
1.1 bertrand 36: // Teste les interfaces d'entrée et de sortie d'une fonction. Une fonction
37: // peut avoir plusieurs interfaces.
1.42 bertrand 38:
1.48 bertrand 39: constrained FONCTION
40: interface STANDARD
41: integer scalar, generic, real scalar
1.42 bertrand 42: returns
1.48 bertrand 43: real scalar
44: or
45: integer scalar
1.42 bertrand 46: requires
1.48 bertrand 47: VARIABLE FONCTION2
1.42 bertrand 48: end
49:
1.48 bertrand 50: interface SPECIFIQUE
51: scalar, ...
1.42 bertrand 52: returns
1.48 bertrand 53: scalar
1.42 bertrand 54: requires
55: end
56: provides
1.15 bertrand 57: <<
58: >>
59:
1.42 bertrand 60: Ajouter un champs dans RPN et ADR pour pointer vers une liste.
61:
62: Types :
63: generic
64: scalar (integer/real/complex)
65: vector (integer/real/complex)
66: matrix (integer/real/complex)
67: table
68: list
69: binary
70: name
71: string
72: algebraic
73: expression
74: file
75: socket
76: library
77: process
78: sql
79: mutex
80: semaphore
81:
1.1 bertrand 82: Traiter les expressions et les noms dans les fichiers. Rajouter un
83: type de format pour les binaires non formatés (LOGICAL)
84:
85: IMPORT -> installe à chaud de nouvelles définitions. Écrase les anciennes
86: si nécessaire.
87:
88: Prévoir un drapeau pour tester les interfaces (34)
89: -> désarmé : test des interfaces
90: -> armé : on ne teste rien
91:
92: colorspec pour les couleurs des graphiques de gnuplot
93:
94: TRIGGER attaché à un objet (fonction appelée dès la modification de l'objet)
95: -> vérification de contrainte...
96:
97: Decomposition de Hessenberg dgehrd, zgehrd; dorghr, zunghr for computing P
98: dgehd2.f+dgebal.f
99:
100: Pseudo inverse dgelss, zgelss
101:
102: Tables dans interface_tex
103:
1.8 bertrand 104: Fichiers à accès direct -> entretenir une table en mémoire (hsearch())
1.1 bertrand 105: Les enregistrements sont de la forme :
106: [Position enregistrement suivant][enregistrement]
107: ADDNODE
108: DELNODE
109:
110: { arguments } << programme >> << interruption >> SUBMIT
111: arg1 ... argn n << programme >> << interruption >> SUBMIT
1.28 bertrand 112:
113: rpl -b (batch) 32 (nombre de threads)
1.1 bertrand 114:
115: FOREIGN (pour les variables)
116:
1.27 bertrand 117: Côté esclave
118: foreign -> X Y Z << >>
119: FVARLOCK
120: FVARUNLOCK
121:
122: Côté maître
1.28 bertrand 123: foreign -> X Y Z << >> (il faut savoir si on est sur le mêtre ou sur un esclave)
1.27 bertrand 124:
1.18 bertrand 125: FOREIGN permet à un esclave d'accéder à une variable partagée
126: du maître.
127:
1.1 bertrand 128: ADDNOTE envoie les variables de niveau 0 au noeud client.
129: SUBMIT envoie l'adresse de création des variables 'foreign' au client
130: // Maître
131: << foreign 1 -> X
132: <<
133: << foreign -> X << 'X' incr >> >> << >> submit
134: >>
135: >>
136:
137: ================================================================================
138:
139: Compilation -> faire un exécutable qui appelle rpl par rpl -S
140:
141: Verification des erreurs mémoire dans le cas d'erreur avant l'appel au
142: séquenceur dans rpl.c
143:
144: Coller un fichier ~/.rpl qui contient les valeurs par défaut des drapeaux
145:
146: 'a(3)+a(3,4)' ne doit pas provoquer d'erreur si a est du type liste ou table.
147: Si a est une liste ou une table : une seule dimension possible !
148:
149: [[ 1 2 ]]3 est valide !
150:
151: Evaluation symbolique des fonction ?
152:
153: SQL sur des données binaires
154:
155: La manière standard de faire est d'utiliser des wchar_t pour représenter les
156: caractères (à distinguer des bytes).
157: Il y a plein de choses dans la bibliothèque standard :
158: - mbtowc et compagnie, et aussi mbrtowc et compagnie, une variante
159: probablement identique dans ton cas
160: - fgetwc, fputwc, fwprintf etc. pour les entrées-sorties
161: - wcs*() qui remplace les fonctions en str*()
162:
163: Vérifier la cohérence des arguments de OPEN
164:
165: TO DO
166: File support : SEEK, SUPPRESS, REWRITE
167:
168: Mettre des tableaux dans les formats binaires
169:
170: Fichier en accès direct -> 12 {} puis entretenir un fichier d'index.
171: Fichiers flow
172:
173: SLOPEFIELD
174:
175: Simplification des expressions : convertir la notation polonaise en
176: arbre.
177:
178: Problème d'indentation de
179: select
180: case then end <- sur la même ligne
CVSweb interface <joel.bertrand@systella.fr>