1: RESTRICTIONS
2: Only sequential formatted files are supported.
3:
4: Économisons notre mépris eut égard au nombre de nécessiteux.
5: Chateaubriand.
6:
7: Libérer la mémoire (arbre des variables) à la fin d'un processus et d'un thread
8: Convertir avec le nouveau système de la gestion de la mémoire :
9: - CLUSR
10: - MEM
11: - PRUSR
12: - VARS
13:
14: - READ FLOW (longueur_effective ligne 2815)
15: rpl/src/'`instructions_w1-conv.c
16: instructions_w1-conv.c: In function ‘librpl_instruction_write’:
17: instructions_w1-conv.c:1603: warning: ‘ios’ may be used uninitialized in this
18: function
19: instructions_w1-conv.c:431: warning: ‘chaine’ may be used uninitialized in this
20: function
21:
22: interruptions-conv.c: In function ‘librpl_liberation_threads’:
23: interruptions-conv.c:806: error: ‘struct_processus’ has no member named
24: ‘nombre_variables’
25: interruptions-conv.c:809: error: ‘struct_processus’ has no member named
26: ‘s_liste_variables’
27: interruptions-conv.c:811: error: ‘struct_processus’ has no member named
28: ‘s_liste_variables’
29: interruptions-conv.c:815: error: ‘struct_processus’ has no member named
30: ‘s_liste_variables’
31: interruptions-conv.c:818: error: ‘struct_processus’ has no member named
32: ‘s_liste_variables’
33: interruptions-conv.c:821: error: ‘struct_processus’ has no member named
34: ‘s_liste_variables’
35: interruptions-conv.c:824: error: ‘struct_processus’ has no member named
36: ‘s_liste_variables’
37:
38:
39: optimisation-conv.c: In function ‘librpl_sequenceur_optimise’:
40: optimisation-conv.c:75: error: ‘struct_processus’ has no member named
41: ‘nombre_variables’
42: optimisation-conv.c:77: error: ‘struct_processus’ has no member named
43: ‘s_liste_variables’
44: optimisation-conv.c:82: error: ‘struct_processus’ has no member named
45: ‘s_liste_variables’
46: optimisation-conv.c:133: error: ‘struct_processus’ has no member named
47: ‘s_liste_variables’
48: optimisation-conv.c:136: error: ‘struct_processus’ has no member named
49: ‘s_liste_variables’
50: optimisation-conv.c:151: error: ‘struct_processus’ has no member named
51: ‘s_liste_variables’
52: optimisation-conv.c:216: error: ‘struct_processus’ has no member named
53: ‘s_liste_variables’
54: optimisation-conv.c:234: error: ‘struct_processus’ has no member named
55: ‘s_liste_variables’
56:
57:
58: rpl-conv.c: In function ‘librpl_rplinit’:
59: rpl-conv.c:3219: error: ‘struct_processus’ has no member named
60: ‘nombre_variables’
61: rpl-conv.c:3222: error: ‘struct_processus’ has no member named
62: ‘s_liste_variables’
63: rpl-conv.c:3223: error: ‘struct_processus’ has no member named
64: ‘s_liste_variables’
65: rpl-conv.c:3226: error: ‘struct_processus’ has no member named
66: ‘s_liste_variables’
67:
68:
69: Traiter SIGTERM
70: RUN
71: Ajouter MULTICAST (pour les sockets)
72: Rajouter le test des dépassements pour INCR et DECR
73:
74: 4.1 -> nouvelle gestion des variables
75:
76: Ajouter TeXmacs
77: Ajouter giac$fonction
78:
79: Dessiner les niveaux sur les graphes
80: { "main" { "default" } { "automatic" 10 } } axes redraw
81: Ne fonctionne pas...
82:
83: // Teste les interfaces d'entrée et de sortie d'une fonction. Une fonction
84: // peut avoir plusieurs interfaces.
85: FONCTION
86: <<
87: INTERFACE
88: ALTERN
89: RESULT
90: REQUIRES
91: END
92: END
93: >>
94:
95: fonction
96: INTERFACE
97: generic
98: integer scalar
99: real matrix
100: complex vector
101: table
102: list
103: binary
104: name
105: string
106: algebraic
107: expression
108: file
109: socket
110: library
111: process
112: sql
113: mutex
114: semaphore
115: CONSTRAINED
116: 4 pick size 6 pick size same
117: RESULT
118: type
119: END
120:
121: INTERFACE
122: integer
123: real matrix
124: integer/real/complex vector
125: table
126: list
127: RESULT
128: type
129: END
130: REQUIRES
131: variables globales ou définitions
132: PROVIDES
133: <<
134: >>
135:
136: Traiter les expressions et les noms dans les fichiers. Rajouter un
137: type de format pour les binaires non formatés (LOGICAL)
138:
139: IMPORT -> installe à chaud de nouvelles définitions. Écrase les anciennes
140: si nécessaire.
141:
142: Prévoir un drapeau pour tester les interfaces (34)
143: -> désarmé : test des interfaces
144: -> armé : on ne teste rien
145:
146: colorspec pour les couleurs des graphiques de gnuplot
147:
148: TRIGGER attaché à un objet (fonction appelée dès la modification de l'objet)
149: -> vérification de contrainte...
150:
151: Decomposition de Hessenberg dgehrd, zgehrd; dorghr, zunghr for computing P
152: dgehd2.f+dgebal.f
153:
154: Pseudo inverse dgelss, zgelss
155:
156: Tables dans interface_tex
157:
158: Fichiers à accès direct -> entretenir une table en mémoire (hsearch())
159: Les enregistrements sont de la forme :
160: [Position enregistrement suivant][enregistrement]
161: ADDNODE
162: DELNODE
163:
164: { arguments } << programme >> << interruption >> SUBMIT
165: arg1 ... argn n << programme >> << interruption >> SUBMIT
166:
167: rpl -b (batch) 32 (nombre de threads)
168:
169: FOREIGN (pour les variables)
170:
171: Côté esclave
172: foreign -> X Y Z << >>
173: FVARLOCK
174: FVARUNLOCK
175:
176: Côté maître
177: foreign -> X Y Z << >> (il faut savoir si on est sur le mêtre ou sur un esclave)
178:
179: FOREIGN permet à un esclave d'accéder à une variable partagée
180: du maître.
181:
182: ADDNOTE envoie les variables de niveau 0 au noeud client.
183: SUBMIT envoie l'adresse de création des variables 'foreign' au client
184: // Maître
185: << foreign 1 -> X
186: <<
187: << foreign -> X << 'X' incr >> >> << >> submit
188: >>
189: >>
190:
191: ================================================================================
192:
193: Compilation -> faire un exécutable qui appelle rpl par rpl -S
194:
195: Verification des erreurs mémoire dans le cas d'erreur avant l'appel au
196: séquenceur dans rpl.c
197:
198: Coller un fichier ~/.rpl qui contient les valeurs par défaut des drapeaux
199:
200: 'a(3)+a(3,4)' ne doit pas provoquer d'erreur si a est du type liste ou table.
201: Si a est une liste ou une table : une seule dimension possible !
202:
203: [[ 1 2 ]]3 est valide !
204:
205: Evaluation symbolique des fonction ?
206:
207: SQL sur des données binaires
208:
209: La manière standard de faire est d'utiliser des wchar_t pour représenter les
210: caractères (à distinguer des bytes).
211: Il y a plein de choses dans la bibliothèque standard :
212: - mbtowc et compagnie, et aussi mbrtowc et compagnie, une variante
213: probablement identique dans ton cas
214: - fgetwc, fputwc, fwprintf etc. pour les entrées-sorties
215: - wcs*() qui remplace les fonctions en str*()
216:
217: Vérifier la cohérence des arguments de OPEN
218:
219: TO DO
220: File support : SEEK, SUPPRESS, REWRITE
221:
222: Mettre des tableaux dans les formats binaires
223:
224: Fichier en accès direct -> 12 {} puis entretenir un fichier d'index.
225: Fichiers flow
226:
227: SLOPEFIELD
228:
229: Simplification des expressions : convertir la notation polonaise en
230: arbre.
231:
232: Problème d'indentation de
233: select
234: case then end <- sur la même ligne
CVSweb interface <joel.bertrand@systella.fr>