--- rpl/LIMITATIONS 2013/03/27 09:14:50 1.129 +++ rpl/LIMITATIONS 2016/11/17 14:58:30 1.182 @@ -1,13 +1,52 @@ RESTRICTIONS - Only formatted and flow files are supported. -Corriger les dépassements dans NEG. -Mettre le drapeau de debug dans la pile système pour pouvoir sauter -les fonctions appelées lors d'un HALT/CONT. +TOKENIZE ne fonctionne pas avec des chaînes qui comportent un \t. + +rpl_arguments rend rplexternals.h non réentrant. + +Rajouter un type pour les entier, réels et complexes longs +123~ -> entier long INL +123_ +123.34E2_53 + +123.34E2~53 -> flottant long (avec sa précision) RLL +(123.42E~253, 14~) -> complexe long CXL + +Mettre un allocateur dans lib$motif +(tableau avec une liste chaînée des éléments disponibles, si liste vide, on +réalloue et on maintient la liste triée.) + +Vérifier les __CATCH_SYSTEM_ERROR__ dans rplexternals.h + +Ne passe pas sur une socket. +{ "STAT" 0 { { } { 5 55 } { 4 51 } { 3 50 } { 3 51 } { 3 50 } { 17 78 } { 4 52 +} { 3 50 } { 3 50 } } # 257B521B6513F2h } +Idem avec une table. + + +{ 'source' 'deplacement' 'origine' } record +-> création d'un type 'record' +Record { 'source' 'deplacement' 'origine' } + +{ 'nom' } record 'structure' sto +L'évaluation de structure crée une nouvelle structure <[]> contenant un pointeur +vers le type 'record' (arbre). + +Accès : structure 'nom' get + +Mettre l'indicateur de debug dans une pile pour ne pas debugguer les fonctions +appelées. + Réduire le nombre de pipes entre deux processus. +Remonter une erreur de format en cas de lecture sur un fichier ou une socket +formatée ou non formatée. + +Virer mutex_sections_critiques _avant_ l'exécution de AT_EXIT. +Faut-il tuer les processus fils avant l'exécution de AT_EXIT ? +ABORT ne lance pas ATEXIT. -{ <[ 2 { "character*(*)" } ]> } = { <[ "character*(*)" "character*(*)" ]> } -{ <[ 2 { <[ "character*(*)" "standard*(*)" ]> } ]> } = +{ <[ { "character*(*)" } 2 ]> } = { <[ "character*(*)" "character*(*)" ]> } +{ <[ { <[ "character*(*)" "standard*(*)" ]> 2 } ]> } = { <[ <[ "character*(*)" "standard*(*)" ]> <[ "character*(*)" "standard*(*)" ]> ]> } @@ -17,14 +56,6 @@ Ajouter la translitération dans l'écri À FAIRE : SOCKET DE TYPE FLOW (LENGTH*(*) ET LENGTH*(N)) -Pour OpenVMS : -Trouver les includes pour : -syslog.h -sys/select.h -sys/un.h -regex.h -termios.h - Ajouter une évaluation des listes. 3 'D(4)' sto/save @@ -45,39 +76,40 @@ Chateaubriand. Translitération des fichiers (avec un pointeur sur la localisation du fichier dans la structure du fichier). +Traiter BACKSPACE pour les fichiers non formatés. Fichiers non formatés : restent à coder pour les écritures : - * 0010 00 00 vecteur integer*1 (dimensions integer*1) - * 0010 01 00 vecteur integer*1 (dimensions integer*2) - * 0010 10 00 vecteur integer*1 (dimensions integer*4) - * 0010 11 00 vecteur integer*1 (dimensions integer*8) - * 0010 00 01 vecteur integer*2 (dimensions integer*1) - * 0010 01 01 vecteur integer*2 (dimensions integer*2) - * 0010 10 01 vecteur integer*2 (dimensions integer*4) - * 0010 11 01 vecteur integer*2 (dimensions integer*8) - * 0010 00 10 vecteur integer*4 (dimensions integer*1) - * 0010 01 10 vecteur integer*4 (dimensions integer*2) - * 0010 10 10 vecteur integer*4 (dimensions integer*4) - * 0010 11 10 vecteur integer*4 (dimensions integer*8) - * 0010 00 11 vecteur integer*8 (dimensions integer*1) - * 0010 01 11 vecteur integer*8 (dimensions integer*2) - * 0010 10 11 vecteur integer*8 (dimensions integer*4) - * 0010 11 11 vecteur integer*8 (dimensions integer*8) - * 0011 00 00 matrice integer*1 (dimensions integer*1) - * 0011 01 00 matrice integer*1 (dimensions integer*2) - * 0011 10 00 matrice integer*1 (dimensions integer*4) - * 0011 11 00 matrice integer*1 (dimensions integer*8) - * 0011 00 01 matrice integer*2 (dimensions integer*1) - * 0011 01 01 matrice integer*2 (dimensions integer*2) - * 0011 10 01 matrice integer*2 (dimensions integer*4) - * 0011 11 01 matrice integer*2 (dimensions integer*8) - * 0011 00 10 matrice integer*4 (dimensions integer*1) - * 0011 01 10 matrice integer*4 (dimensions integer*2) - * 0011 10 10 matrice integer*4 (dimensions integer*4) - * 0011 11 10 matrice integer*4 (dimensions integer*8) - * 0011 00 11 matrice integer*8 (dimensions integer*1) - * 0011 01 11 matrice integer*8 (dimensions integer*2) - * 0011 10 11 matrice integer*8 (dimensions integer*4) - * 0011 11 11 matrice integer*8 (dimensions integer*8) +/ * 0010 00 00 vecteur integer*1 (dimensions integer*1) +/ * 0010 01 00 vecteur integer*1 (dimensions integer*2) +/ * 0010 10 00 vecteur integer*1 (dimensions integer*4) +/ * 0010 11 00 vecteur integer*1 (dimensions integer*8) +/ * 0010 00 01 vecteur integer*2 (dimensions integer*1) +/ * 0010 01 01 vecteur integer*2 (dimensions integer*2) +/ * 0010 10 01 vecteur integer*2 (dimensions integer*4) +/ * 0010 11 01 vecteur integer*2 (dimensions integer*8) +/ * 0010 00 10 vecteur integer*4 (dimensions integer*1) +/ * 0010 01 10 vecteur integer*4 (dimensions integer*2) +/ * 0010 10 10 vecteur integer*4 (dimensions integer*4) +/ * 0010 11 10 vecteur integer*4 (dimensions integer*8) +/ * 0010 00 11 vecteur integer*8 (dimensions integer*1) +/ * 0010 01 11 vecteur integer*8 (dimensions integer*2) +/ * 0010 10 11 vecteur integer*8 (dimensions integer*4) +/ * 0010 11 11 vecteur integer*8 (dimensions integer*8) +/ * 0011 00 00 matrice integer*1 (dimensions integer*1) +/ * 0011 01 00 matrice integer*1 (dimensions integer*2) +/ * 0011 10 00 matrice integer*1 (dimensions integer*4) +/ * 0011 11 00 matrice integer*1 (dimensions integer*8) +/ * 0011 00 01 matrice integer*2 (dimensions integer*1) +/ * 0011 01 01 matrice integer*2 (dimensions integer*2) +/ * 0011 10 01 matrice integer*2 (dimensions integer*4) +/ * 0011 11 01 matrice integer*2 (dimensions integer*8) +/ * 0011 00 10 matrice integer*4 (dimensions integer*1) +/ * 0011 01 10 matrice integer*4 (dimensions integer*2) +/ * 0011 10 10 matrice integer*4 (dimensions integer*4) +/ * 0011 11 10 matrice integer*4 (dimensions integer*8) +/ * 0011 00 11 matrice integer*8 (dimensions integer*1) +/ * 0011 01 11 matrice integer*8 (dimensions integer*2) +/ * 0011 10 11 matrice integer*8 (dimensions integer*4) +/ * 0011 11 11 matrice integer*8 (dimensions integer*8) * 1001 0 XXX table de longueur XXX * 1001 10 00 table de longueur integer*1 @@ -85,38 +117,38 @@ Fichiers non formatés : restent à code * 1001 10 10 table de longueur integer*4 * 1001 10 11 table de longueur integer*8 * - * 1010 00 10 vecteur real*4 (dimensions integer*1) - * 1010 01 10 vecteur real*4 (dimensions integer*2) - * 1010 10 10 vecteur real*4 (dimensions integer*4) - * 1010 11 10 vecteur real*4 (dimensions integer*8) - * 1010 00 11 vecteur real*8 (dimensions integer*1) - * 1010 01 11 vecteur real*8 (dimensions integer*2) - * 1010 10 11 vecteur real*8 (dimensions integer*4) - * 1010 11 11 vecteur real*8 (dimensions integer*8) - * 1011 00 10 vecteur complex*8 (dimensions integer*1) - * 1011 01 10 vecteur complex*8 (dimensions integer*2) - * 1011 10 10 vecteur complex*8 (dimensions integer*4) - * 1011 11 10 vecteur complex*8 (dimensions integer*8) - * 1011 00 11 vecteur complex*16 (dimensions integer*1) - * 1011 01 11 vecteur complex*16 (dimensions integer*2) - * 1011 10 11 vecteur complex*16 (dimensions integer*4) - * 1011 11 11 vecteur complex*16 (dimensions integer*8) - * 1100 00 10 matrice real*4 (dimensions integer*1) - * 1100 01 10 matrice real*4 (dimensions integer*2) - * 1100 10 10 matrice real*4 (dimensions integer*4) - * 1100 11 10 matrice real*4 (dimensions integer*8) - * 1100 00 11 matrice real*8 (dimensions integer*1) - * 1100 01 11 matrice real*8 (dimensions integer*2) - * 1100 10 11 matrice real*8 (dimensions integer*4) - * 1100 11 11 matrice real*8 (dimensions integer*8) - * 1101 00 10 matrice complex*8 (dimensions integer*1) - * 1101 01 10 matrice complex*8 (dimensions integer*2) - * 1101 10 10 matrice complex*8 (dimensions integer*4) - * 1101 11 10 matrice complex*8 (dimensions integer*8) - * 1101 00 11 matrice complex*16 (dimensions integer*1) - * 1101 01 11 matrice complex*16 (dimensions integer*2) - * 1101 10 11 matrice complex*16 (dimensions integer*4) - * 1101 11 11 matrice complex*16 (dimensions integer*8) +/ * 1010 00 10 vecteur real*4 (dimensions integer*1) +/ * 1010 01 10 vecteur real*4 (dimensions integer*2) +/ * 1010 10 10 vecteur real*4 (dimensions integer*4) +/ * 1010 11 10 vecteur real*4 (dimensions integer*8) +/ * 1010 00 11 vecteur real*8 (dimensions integer*1) +/ * 1010 01 11 vecteur real*8 (dimensions integer*2) +/ * 1010 10 11 vecteur real*8 (dimensions integer*4) +/ * 1010 11 11 vecteur real*8 (dimensions integer*8) +/ * 1011 00 10 vecteur complex*8 (dimensions integer*1) +/ * 1011 01 10 vecteur complex*8 (dimensions integer*2) +/ * 1011 10 10 vecteur complex*8 (dimensions integer*4) +/ * 1011 11 10 vecteur complex*8 (dimensions integer*8) +/ * 1011 00 11 vecteur complex*16 (dimensions integer*1) +/ * 1011 01 11 vecteur complex*16 (dimensions integer*2) +/ * 1011 10 11 vecteur complex*16 (dimensions integer*4) +/ * 1011 11 11 vecteur complex*16 (dimensions integer*8) +/ * 1100 00 10 matrice real*4 (dimensions integer*1) +/ * 1100 01 10 matrice real*4 (dimensions integer*2) +/ * 1100 10 10 matrice real*4 (dimensions integer*4) +/ * 1100 11 10 matrice real*4 (dimensions integer*8) +/ * 1100 00 11 matrice real*8 (dimensions integer*1) +/ * 1100 01 11 matrice real*8 (dimensions integer*2) +/ * 1100 10 11 matrice real*8 (dimensions integer*4) +/ * 1100 11 11 matrice real*8 (dimensions integer*8) +/ * 1101 00 10 matrice complex*8 (dimensions integer*1) +/ * 1101 01 10 matrice complex*8 (dimensions integer*2) +/ * 1101 10 10 matrice complex*8 (dimensions integer*4) +/ * 1101 11 10 matrice complex*8 (dimensions integer*8) +/ * 1101 00 11 matrice complex*16 (dimensions integer*1) +/ * 1101 01 11 matrice complex*16 (dimensions integer*2) +/ * 1101 10 11 matrice complex*16 (dimensions integer*4) +/ * 1101 11 11 matrice complex*16 (dimensions integer*8) Utiliser clock() et clock_t pour émuler getrusage sous OS/2 @@ -125,15 +157,6 @@ Regarder les d_ep_division_par_zero pour ->TAG TAG-> DTAG ->UNIT UNIT-> DUNIT -Convertir avec le nouveau système de la gestion de la mémoire : -- READ FLOW (longueur_effective ligne 2815) -rpl/src/'`instructions_w1-conv.c -instructions_w1-conv.c: In function ‘librpl_instruction_write’: -instructions_w1-conv.c:1603: warning: ‘ios’ may be used uninitialized in this -function -instructions_w1-conv.c:431: warning: ‘chaine’ may be used uninitialized in this -function - Traiter SIGTERM RUN Ajouter MULTICAST (pour les sockets) @@ -171,31 +194,6 @@ provides << >> -Ajouter un champs dans RPN et ADR pour pointer vers une liste. - -Types : -generic -scalar (integer/real/complex) -vector (integer/real/complex) -matrix (integer/real/complex) -table -list -binary -name -string -algebraic -expression -file -socket -library -process -sql -mutex -semaphore - -Traiter les expressions et les noms dans les fichiers. Rajouter un -type de format pour les binaires non formatés (LOGICAL) - IMPORT -> installe à chaud de nouvelles définitions. Écrase les anciennes si nécessaire. @@ -215,9 +213,7 @@ Pseudo inverse dgelss, zgelss Tables dans interface_tex -Fichiers à accès direct -> entretenir une table en mémoire (hsearch()) -Les enregistrements sont de la forme : -[Position enregistrement suivant][enregistrement] +Pour le fonctionnement en cluster ADDNODE DELNODE @@ -260,8 +256,6 @@ Coller un fichier ~/.rpl qui contient le 'a(3)+a(3,4)' ne doit pas provoquer d'erreur si a est du type liste ou table. Si a est une liste ou une table : une seule dimension possible ! -[[ 1 2 ]]3 est valide ! - Evaluation symbolique des fonction ? SQL sur des données binaires @@ -281,9 +275,6 @@ TO DO Mettre des tableaux dans les formats binaires -Fichier en accès direct -> 12 {} puis entretenir un fichier d'index. -Fichiers flow - SLOPEFIELD Simplification des expressions : convertir la notation polonaise en