aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEd Schonberg <schonberg@adacore.com>2021-12-14 15:44:16 +0100
committerPierre-Marie de Rodat <derodat@adacore.com>2022-05-09 09:27:33 +0000
commitf1231d9a0baab25e0a07b0d6146b91e59ecfadb8 (patch)
tree98c46cf63b1868891eadb818c92566203d3e7ac5
parent28fffc452eedb284d047b83adc7f8772b15bb0f8 (diff)
downloadgcc-f1231d9a0baab25e0a07b0d6146b91e59ecfadb8.zip
gcc-f1231d9a0baab25e0a07b0d6146b91e59ecfadb8.tar.gz
gcc-f1231d9a0baab25e0a07b0d6146b91e59ecfadb8.tar.bz2
[Ada] Fix check for looking for user defined literals
Recall that Has_Possible_Literal_Aspects only comes in if a given node does not have any visible interpretation. If one operand is a literal we assume that there may be a user-defined literal defined for some type to be determined during the downward pass of resolution, but that depends on the existence of some user-defined function or operator that can take that literal as an actual. If analysis did not find such, the call is illegal. I think that the following must be added to Operator_Check to recover the proper error. Note that this breaks current partial implementation of user-defined literals. gcc/ada/ * sem_ch4.adb (Operator_Check): Fix condition.
-rw-r--r--gcc/ada/sem_ch4.adb4
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/ada/sem_ch4.adb b/gcc/ada/sem_ch4.adb
index 68839b3..915a7b4 100644
--- a/gcc/ada/sem_ch4.adb
+++ b/gcc/ada/sem_ch4.adb
@@ -7260,7 +7260,9 @@ package body Sem_Ch4 is
then
return;
- elsif Has_Possible_Literal_Aspects (N) then
+ elsif Present (Entity (N))
+ and then Has_Possible_Literal_Aspects (N)
+ then
return;
-- If we have a logical operator, one of whose operands is