a68_error (p, "clause does not yield a value");
}
+/* Diagnose for invalid module text. */
+
+static void
+expected_module_text (NODE_T *p)
+{
+ a68_error (p, "expected module text in module definition");
+}
+
/* Diagnose for missing symbol. */
static void
/* Single module declaration. */
reduce (p, NO_NOTE, NO_TICK,
MODULE_DECLARATION, MODULE_SYMBOL, DEFINING_MODULE_INDICANT, EQUALS_SYMBOL, MODULE_TEXT, STOP);
- reduce (p, strange_tokens, NO_TICK,
+ reduce (p, expected_module_text, NO_TICK,
MODULE_DECLARATION, MODULE_SYMBOL, DEFINING_MODULE_INDICANT, EQUALS_SYMBOL, -MODULE_TEXT, STOP);
#if 0
}
else if (IS (p, PUBLIC_SYMBOL))
{
- /* These should have been removed by a68_bottom_up_coalesce_pub. */
+ /* These should have been removed by a68_bottom_up_coalesce_pub and
+ by a68_extract_indicants. */
+ /* XXX get rid of this. */
gcc_unreachable ();
}
else if (a68_is_one_of (p, DEFINING_INDICANT, DEFINING_IDENTIFIER, DEFINING_OPERATOR, STOP))
do
{
FORWARD (q);
- detect_redefined_keyword (q, MODE_DECLARATION);
- if (IS (q, BOLD_TAG))
+ if (q != NO_NODE)
{
- extract_revelation (q, false /* is_public */);
- FORWARD (q);
- }
- else if (a68_whether (q, PUBLIC_SYMBOL, BOLD_TAG, STOP))
- {
- extract_revelation (q, true /* is_public */);
- FORWARD (q);
- FORWARD (q);
+ detect_redefined_keyword (q, MODULE_DECLARATION);
+ if (IS (q, BOLD_TAG))
+ {
+ extract_revelation (q, false /* is_public */);
+ FORWARD (q);
+ }
+ else if (a68_whether (q, PUBLIC_SYMBOL, BOLD_TAG, STOP))
+ {
+ NODE_T *pub_node = q;
+ extract_revelation (NEXT (pub_node), true /* is_public */);
+ /* XXX get rid of this crap. */
+ PREVIOUS (NEXT (pub_node)) = PREVIOUS (pub_node);
+ if (PREVIOUS (pub_node) != NO_NODE)
+ NEXT (PREVIOUS (pub_node)) = NEXT (pub_node);
+ FORWARD (q);
+ }
}
}
while (q != NO_NODE && IS (q, COMMA_SYMBOL));
EXPORTED (tag) = true;
FORWARD (q);
ATTRIBUTE (q) = EQUALS_SYMBOL; /* XXX why not ALT_EQUALS_SYMBOL */
- q = skip_module_text (NEXT (q));
- FORWARD (q);
+ if (NEXT (q) != NO_NODE && IS (NEXT (q), ACCESS_SYMBOL))
+ {
+ a68_error (NEXT (q),
+ "nested access clauses not allowed in module texts");
+ siga = false;
+ }
+ else
+ {
+ q = skip_module_text (NEXT (q));
+ FORWARD (q);
+ }
}
else
siga = false;
/* Make branch of
- ACCESS REVELATION [DEF_SYMBOL]
+ ACCESS REVELATIONS [DEF_SYMBOL]
or
- ACCESS REVELATION ENCLOSED_CLAUSE. */
+ ACCESS REVELATIONS ENCLOSED_CLAUSE. */
static void
top_down_access (NODE_T *p)
a68_make_sub (q, end_p, ALT_ACCESS_SYMBOL);
}
}
+ else if (IS (end_p, ACCESS_SYMBOL))
+ {
+ top_down_access (end_p);
+ a68_make_sub (q, end_p, ACCESS_SYMBOL);
+ }
else
a68_make_sub (q, end_p, ACCESS_SYMBOL);
}
--- /dev/null
+module Foo = { dg-error "expected module text" }
+ access Bar access Baz access Quux { dg-error "nested" }
+def
+ pub int bar = foo + baz;
+ skip
+fed
--- /dev/null
+{ dg-modules "module-foo module-bar" }
+{ dg-options "-fmodules-map-file=$srcdir/algol68/execute/modules/Modules20.map" }
+
+access Foo
+ access Bar (assert (foo = 10); assert (bar = 20))