@@ -36,88 +36,90 @@ SHARE
3636%}
3737DECLARE
3838%{
39- char * key;
40- char * name;
39+ char * key;
40+ char * name;
4141%}
4242INITIALIZE
4343%{
44- // Sort-out the key that we are searching for
45- if (metadatakey == NULL || metadatakey[0] == '\0'){
46- key = malloc((strlen(NAME_CURRENT_COMP) + 1) * sizeof(char));
47- strcpy(key, NAME_CURRENT_COMP);
48- } else {
49- key = malloc((strlen(metadatakey) + 1) * sizeof(char));
50- strcpy(key, metadatakey);
51- }
52- int matches = metadata_table_defined(num_metadata, metadata_table, key);
53- if (matches != 1) {
54- // 0 would mean _no_ matches; maybe they metadata name without the component was given?
55- if (matches == 0 && strcmp(key, NAME_CURRENT_COMP)) {
56- free(key);
57- key = malloc((strlen(NAME_CURRENT_COMP) + strlen(metadatakey) + 2) * sizeof(char));
58- sprintf(key, "%s:%s", NAME_CURRENT_COMP, metadatakey);
59- matches = metadata_table_defined(num_metadata, metadata_table, key);
44+ // Sort-out the key that we are searching for
45+ if (metadatakey == NULL || metadatakey[0] == '\0') {
46+ key = malloc ((strlen (NAME_CURRENT_COMP) + 1) * sizeof (char));
47+ strcpy (key, NAME_CURRENT_COMP);
48+ } else {
49+ key = malloc ((strlen (metadatakey) + 1) * sizeof (char));
50+ strcpy (key, metadatakey);
6051 }
61- // there's a bug in metadata_table_defined that returns num_metadata if key == NULL
62- // But since key _isn't_ null, any other result _should_ mean key == A_COMPONENT_NAME
63- // _and_ that component defines _multiple_ METADATA entries.
64- else {
65- printf("%s: There are %d METADATA entries that match %s; please select only one of:\n", NAME_CURRENT_COMP, matches, key);
66- metadata_table_print_component_keys(num_metadata, metadata_table, key);
67- exit(1);
52+ int matches = metadata_table_defined (num_metadata, metadata_table, key);
53+ if (matches != 1) {
54+ // 0 would mean _no_ matches; maybe they metadata name without the component was given?
55+ if (matches == 0 && strcmp (key, NAME_CURRENT_COMP)) {
56+ free (key);
57+ key = malloc ((strlen (NAME_CURRENT_COMP) + strlen (metadatakey) + 2) * sizeof (char));
58+ sprintf (key, "%s:%s", NAME_CURRENT_COMP, metadatakey);
59+ matches = metadata_table_defined (num_metadata, metadata_table, key);
60+ }
61+ // there's a bug in metadata_table_defined that returns num_metadata if key == NULL
62+ // But since key _isn't_ null, any other result _should_ mean key == A_COMPONENT_NAME
63+ // _and_ that component defines _multiple_ METADATA entries.
64+ else {
65+ printf ("%s: There are %d METADATA entries that match %s; please select only one of:\n", NAME_CURRENT_COMP, matches, key);
66+ metadata_table_print_component_keys (num_metadata, metadata_table, key);
67+ exit (1);
68+ }
69+ }
70+ if (metadata_table_defined (num_metadata, metadata_table, key) != 1) {
71+ fprintf (stderr, "%s: No unique metadata defined with key %s\n", NAME_CURRENT_COMP, key);
72+ exit (1);
73+ }
74+
75+ char* name_part = metadata_table_key_literal (key);
76+ if (name_part == NULL) {
77+ #if defined(__MCCODE_VERSION__) && __MCCODE_VERSION__ >= 305000L
78+ // We already restrict that only one key matches.
79+ name_part = metadata_table_name (num_metadata, metadata_table, key);
80+ // is key NAME_CURRENT_COMP or something provided by the user? We don't know
81+ // so we _must_ cycle the key allocation to make this work.
82+ char* new_key = malloc ((strlen (key) + strlen (name_part) + 2) * sizeof (char));
83+ sprintf (new_key, "%s:%s", key, name_part);
84+ free (key);
85+ key = new_key;
86+ #else
87+ printf ("Can not update the key automatically prior to McCode v3.5.0, please fix %s usage or upgrade\n", NAME_CURRENT_COMP);
88+ exit (1);
89+ #endif
6890 }
69- }
70- if (metadata_table_defined(num_metadata, metadata_table, key) != 1) {
71- fprintf(stderr, "%s: No unique metadata defined with key %s\n", NAME_CURRENT_COMP, key);
72- exit(1);
73- }
74-
75- char * name_part = metadata_table_key_literal(key);
76- if (name_part == NULL) {
77- #if defined(__MCCODE_VERSION__) && __MCCODE_VERSION__ >= 305000L
78- // We already restrict that only one key matches.
79- name_part = metadata_table_name(num_metadata, metadata_table, key);
80- // is key NAME_CURRENT_COMP or something provided by the user? We don't know
81- // so we _must_ cycle the key allocation to make this work.
82- char * new_key = malloc((strlen(key) + strlen(name_part) + 2) * sizeof(char));
83- sprintf(new_key, "%s:%s", key, name_part);
84- free(key);
85- key = new_key;
86- #else
87- printf("Can not update the key automatically prior to McCode v3.5.0, please fix %s usage or upgrade\n", NAME_CURRENT_COMP);
88- exit(1);
89- #endif
90- }
9191
92- if (filename == NULL || filename[0] == '\0'){
93- char * comp_part = metadata_table_key_component(key);
94- name = malloc((strlen(comp_part) + strlen(name_part) + 2) * sizeof(char));
95- sprintf(name, "%s_%s", comp_part, name_part);
96- free(comp_part);
97- } else{
98- name = malloc((strlen(filename) + 1) * sizeof(char));
99- strcpy(name, filename);
100- }
101-
102- free(name_part);
92+ if (filename == NULL || filename[0] == '\0') {
93+ char * comp_part = metadata_table_key_component (key);
94+ name = malloc ((strlen (comp_part) + strlen (name_part) + 2) * sizeof (char));
95+ sprintf (name, "%s_%s", comp_part, name_part);
96+ free (comp_part);
97+ } else {
98+ name = malloc ((strlen (filename) + 1) * sizeof (char));
99+ strcpy (name, filename);
100+ }
101+
102+ free (name_part);
103103
104- // Read the file contents and write them to file now.
105- FILE * file_ptr = fopen(name, "w");
106- fprintf(file_ptr, "%s", metadata_table_literal(num_metadata, metadata_table, key));
107- fclose(file_ptr);
104+ // Read the file contents and write them to file now.
105+ FILE * file_ptr = fopen (name, "w");
106+ fprintf (file_ptr, "%s", metadata_table_literal (num_metadata, metadata_table, key));
107+ fclose (file_ptr);
108108%}
109109TRACE
110110%{
111- // Do nothing
111+ // Do nothing
112112%}
113113FINALLY
114114%{
115- // (Optionally) Remove the file now that the runtime is done
116- if (!keep && !remove(name)) {
117- fprintf(stderr, "%s: Could not remove file %s\n", NAME_CURRENT_COMP, name);
118- }
119- if (key) free(key);
120- if (name) free(name);
115+ // (Optionally) Remove the file now that the runtime is done
116+ if (!keep && !remove (name)) {
117+ fprintf (stderr, "%s: Could not remove file %s\n", NAME_CURRENT_COMP, name);
118+ }
119+ if (key)
120+ free (key);
121+ if (name)
122+ free (name);
121123%}
122124MCDISPLAY
123125%{
0 commit comments