Bonjour,

J'utilise une structure contenant, pour chaque année, une liste de mois (qui est elle-même une structure contenant une liste de noms de fichiers), comme suit :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
TYPE MOIS
	CHARACTER (len=2)				:: Numero_Mois
	CHARACTER (len=19), DIMENSION(:), POINTER	:: Noms_Fichiers ! Liste des fichiers (sessions) du mois
END TYPE
 
TYPE ANNEE
	CHARACTER (len=4)			:: Numero_Annee
	TYPE(MOIS), DIMENSION(:), POINTER	:: Mois ! Liste des mois avec des mesures
END TYPE
Je ne connais pas à l'avance le nombre de mois qui vont être enregistrés pour une année, tout comme je ne sais pas combien de fichiers peuvent appartenir à un mois (cela varie fortement en fonction des années et des mois). D'où la nécessité de l'allocation dynamique donc...


Dans mon module, j'utilise une première fonction allouant la place nécessaire à l'enregistrement de données dans une variable de type ANNEE. J'aimerais que cette fonction renvoie donc cette variable, afin de l'utiliser en entrée d'une autre fonction, qui va effectuer des calculs dessus.

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
 
MODULE Mon_module
IMPLICIT NONE
 
TYPE MOIS
	CHARACTER (len=2)				:: Numero_Mois
	CHARACTER (len=19), DIMENSION(:), POINTER	:: Noms_Fichiers ! Liste des fichiers (sessions) du mois
END TYPE
 
TYPE ANNEE
	CHARACTER (len=4)			:: Numero_Annee
	TYPE(MOIS), DIMENSION(:), POINTER	:: Mois ! Liste des mois avec des mesures
END TYPE
 
CONTAINS
 
 
SUBROUTINE Main
	IMPLICIT NONE
	TYPE(ANNEE), DIMENSION(:), ALLOCATABLE	:: Data
 
	CALL Enregistrement_donnees(Data)
 
        PRINT *,Data
 
	CALL Traitement_donnees(Data)
 
END SUBROUTINE Main
 
 
END MODULE


Problème : impossible de récupérer ce que contient la variable de type ANNEE, avec ce message d'erreur :

PRINT *,Data
1
Error: Data transfer element at (1) cannot have POINTER components

Je ne comprends pas vraiment ce que cela signifie. J'ai eu beau chercher sur internet, les structures dynamiques existent bien et fonctionnent parfaitement, que ce soit avec une subroutine ou une fonction. Est-ce que quelqu'un verrait ce qui cloche ici svp ?


Merci d'avance pour votre aide.