resolve_omp_metadirective (gfc_code *code, gfc_namespace *ns)
{
gfc_omp_variant *variant = code->ext.omp_variants;
+ gfc_omp_variant *prev_variant = variant;
while (variant)
{
as the 'otherwise' clause should always match. */
if (variant == code->ext.omp_variants && !variant->next)
break;
- if (variant == code->ext.omp_variants)
- code->ext.omp_variants = variant->next;
gfc_omp_variant *tmp = variant;
- variant = variant->next;
+ if (variant == code->ext.omp_variants)
+ variant = prev_variant = code->ext.omp_variants = variant->next;
+ else
+ variant = prev_variant->next = variant->next;
gfc_free_omp_set_selector_list (tmp->selectors);
free (tmp);
}
else
- variant = variant->next;
+ {
+ prev_variant = variant;
+ variant = variant->next;
+ }
}
/* Replace metadirective by its body if only 'nothing' remains. */
if (!code->ext.omp_variants->next && code->ext.omp_variants->stmt == ST_NONE)
--- /dev/null
+! { dg-do compile }
+! { dg-additional-options "-Wall" }
+
+! PR fortran/122570
+
+ SUBROUTINE INITAL
+ implicit none (type, external)
+ integer :: j, n
+ n = 5
+!$omp metadirective &
+!$omp& when(user={condition(.true.)}: target teams &
+!$omp& distribute parallel do) &
+!$omp& when(user={condition(.false.)}: target teams &
+!$omp& distribute parallel do)
+ DO J=1,N
+ END DO
+ END SUBROUTINE
+
+ SUBROUTINE CALC3
+ implicit none (type, external)
+ integer :: i, m
+ m = 99
+!$omp metadirective
+!$omp& when(user={condition(.false.)}:
+!$omp& simd)
+ DO 301 I=1,M
+ 301 CONTINUE
+ 300 CONTINUE ! { dg-warning "Label 300 at .1. defined but not used \\\[-Wunused-label\\\]" }
+ END SUBROUTINE