Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
riscv-gcc-1
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
riscv-gcc-1
Commits
4daa9c14
Commit
4daa9c14
authored
Apr 17, 1998
by
Jason Merrill
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
redo
From-SVN: r19270
parent
27029020
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
83 deletions
+48
-83
gcc/cp/typeck.c
+48
-83
No files found.
gcc/cp/typeck.c
View file @
4daa9c14
...
...
@@ -877,7 +877,10 @@ comptypes (type1, type2, strict)
NPTRS is the number of pointers we can strip off and keep cool.
This is used to permit (for aggr A, aggr B) A, B* to convert to A*,
but to not permit B** to convert to A**. */
but to not permit B** to convert to A**.
This should go away. Callers should use can_convert or something
similar instead. (jason 17 Apr 1997) */
int
comp_target_types
(
ttl
,
ttr
,
nptrs
)
...
...
@@ -892,12 +895,15 @@ comp_target_types (ttl, ttr, nptrs)
if
(
TREE_CODE
(
ttr
)
!=
TREE_CODE
(
ttl
))
return
0
;
if
(
TREE_CODE
(
ttr
)
==
POINTER_TYPE
)
if
(
TREE_CODE
(
ttr
)
==
POINTER_TYPE
||
(
TREE_CODE
(
ttr
)
==
REFERENCE_TYPE
))
{
int
is_ptr
=
TREE_CODE
(
ttr
)
==
POINTER_TYPE
;
ttl
=
TREE_TYPE
(
ttl
);
ttr
=
TREE_TYPE
(
ttr
);
if
(
nptrs
>
0
)
if
(
nptrs
>
0
&&
is_ptr
)
{
if
(
TREE_CODE
(
ttl
)
==
UNKNOWN_TYPE
||
TREE_CODE
(
ttr
)
==
UNKNOWN_TYPE
)
...
...
@@ -949,27 +955,23 @@ comp_target_types (ttl, ttr, nptrs)
}
}
if
(
TREE_CODE
(
ttr
)
==
REFERENCE_TYPE
)
return
comp_target_types
(
TREE_TYPE
(
ttl
),
TREE_TYPE
(
ttr
),
nptrs
);
if
(
TREE_CODE
(
ttr
)
==
ARRAY_TYPE
)
return
comp_array_types
(
comp_target_types
,
ttl
,
ttr
,
0
);
else
if
(
TREE_CODE
(
ttr
)
==
FUNCTION_TYPE
||
TREE_CODE
(
ttr
)
==
METHOD_TYPE
)
{
if
(
comp_target_types
(
TREE_TYPE
(
ttl
),
TREE_TYPE
(
ttr
),
-
1
))
switch
(
comp_target_parms
(
TYPE_ARG_TYPES
(
ttl
),
TYPE_ARG_TYPES
(
ttr
),
1
))
{
case
0
:
if
(
pedantic
)
{
if
(
comptypes
(
TREE_TYPE
(
ttl
),
TREE_TYPE
(
ttr
),
1
)
==
0
)
return
0
;
case
1
:
return
1
;
case
2
:
return
-
1
;
default:
my_friendly_abort
(
112
);
}
}
else
return
0
;
{
if
(
comp_target_types
(
TREE_TYPE
(
ttl
),
TREE_TYPE
(
ttr
),
-
1
)
==
0
)
return
0
;
}
return
comp_target_parms
(
TYPE_ARG_TYPES
(
ttl
),
TYPE_ARG_TYPES
(
ttr
),
1
);
}
/* for C++ */
else
if
(
TREE_CODE
(
ttr
)
==
OFFSET_TYPE
)
...
...
@@ -1059,9 +1061,9 @@ common_base_type (tt1, tt2)
If either list is empty, we win.
Otherwise, the two lists must be equivalent, element by element.
C++: See comment above about TYPE1, TYPE2
, STRICT
.
If STRICT == 3, it means checking is strict, but do not compare
default parameter values
. */
C++: See comment above about TYPE1, TYPE2.
STRICT is no longer used
. */
int
compparms
(
parms1
,
parms2
,
strict
)
...
...
@@ -1073,34 +1075,16 @@ compparms (parms1, parms2, strict)
/* An unspecified parmlist matches any specified parmlist
whose argument types don't need default promotions. */
if
(
strict
<=
0
&&
t1
==
0
)
return
self_promoting_args_p
(
t2
);
if
(
strict
<
0
&&
t2
==
0
)
return
self_promoting_args_p
(
t1
);
while
(
1
)
{
if
(
t1
==
0
&&
t2
==
0
)
return
1
;
/* If one parmlist is shorter than the other,
they fail to match
, unless STRICT is <= 0
. */
they fail to match. */
if
(
t1
==
0
||
t2
==
0
)
{
if
(
strict
>
0
)
return
0
;
if
(
strict
<
0
)
return
1
;
if
(
strict
==
0
)
return
t1
&&
TREE_PURPOSE
(
t1
);
}
if
(
!
comptypes
(
TREE_VALUE
(
t2
),
TREE_VALUE
(
t1
),
strict
))
{
if
(
strict
>
0
)
return
0
;
if
(
strict
==
0
)
return
t2
==
void_list_node
&&
TREE_PURPOSE
(
t1
);
return
TREE_PURPOSE
(
t1
)
||
TREE_PURPOSE
(
t2
);
}
return
0
;
if
(
!
comptypes
(
TREE_VALUE
(
t2
),
TREE_VALUE
(
t1
),
1
))
return
0
;
t1
=
TREE_CHAIN
(
t1
);
t2
=
TREE_CHAIN
(
t2
);
...
...
@@ -1108,7 +1092,13 @@ compparms (parms1, parms2, strict)
}
/* This really wants return whether or not parameter type lists
would make their owning functions assignment compatible or not. */
would make their owning functions assignment compatible or not.
The return value is like for comp_target_types.
This should go away, possibly with the exception of the empty parmlist
conversion; there are no conversions between function types in C++.
(jason 17 Apr 1997) */
static
int
comp_target_parms
(
parms1
,
parms2
,
strict
)
...
...
@@ -1118,9 +1108,9 @@ comp_target_parms (parms1, parms2, strict)
register
tree
t1
=
parms1
,
t2
=
parms2
;
int
warn_contravariance
=
0
;
/*
A
n unspecified parmlist matches any specified parmlist
whose argument types don't need default promotions.
@@@ see 13.3.3 for a counterexample..
. */
/*
In C, a
n unspecified parmlist matches any specified parmlist
whose argument types don't need default promotions.
This is not
true for C++, but let's do it anyway for unfixed headers
. */
if
(
t1
==
0
&&
t2
!=
0
)
{
...
...
@@ -1147,9 +1137,12 @@ comp_target_parms (parms1, parms2, strict)
}
p1
=
TREE_VALUE
(
t1
);
p2
=
TREE_VALUE
(
t2
);
if
(
p1
==
p2
)
if
(
comptypes
(
p1
,
p2
,
1
)
)
continue
;
if
(
pedantic
)
return
0
;
if
((
TREE_CODE
(
p1
)
==
POINTER_TYPE
&&
TREE_CODE
(
p2
)
==
POINTER_TYPE
)
||
(
TREE_CODE
(
p1
)
==
REFERENCE_TYPE
&&
TREE_CODE
(
p2
)
==
REFERENCE_TYPE
))
...
...
@@ -1170,20 +1163,15 @@ comp_target_parms (parms1, parms2, strict)
}
if
(
IS_AGGR_TYPE
(
TREE_TYPE
(
p1
)))
{
if
(
comptypes
(
p2
,
p1
,
0
)
==
0
)
{
if
(
comptypes
(
p1
,
p2
,
0
)
!=
0
)
warn_contravariance
=
1
;
else
return
0
;
}
continue
;
if
(
comptypes
(
TYPE_MAIN_VARIANT
(
TREE_TYPE
(
p1
)),
TYPE_MAIN_VARIANT
(
TREE_TYPE
(
p2
)),
1
)
==
0
)
return
0
;
}
}
/* Note backwards order due to contravariance. */
if
(
comp_target_types
(
p2
,
p1
,
1
)
=
=
0
)
if
(
comp_target_types
(
p2
,
p1
,
1
)
<
=
0
)
{
if
(
comp_target_types
(
p1
,
p2
,
1
))
if
(
comp_target_types
(
p1
,
p2
,
1
)
>
0
)
{
warn_contravariance
=
1
;
continue
;
...
...
@@ -1191,31 +1179,8 @@ comp_target_parms (parms1, parms2, strict)
if
(
strict
!=
0
)
return
0
;
}
/* Target types are compatible--just make sure that if
we use parameter lists, that they are ok as well. */
if
(
TREE_CODE
(
p1
)
==
FUNCTION_TYPE
||
TREE_CODE
(
p1
)
==
METHOD_TYPE
)
switch
(
comp_target_parms
(
TYPE_ARG_TYPES
(
p1
),
TYPE_ARG_TYPES
(
p2
),
strict
))
{
case
0
:
return
0
;
case
1
:
break
;
case
2
:
warn_contravariance
=
1
;
}
if
(
TREE_PURPOSE
(
t1
)
&&
TREE_PURPOSE
(
t2
))
{
int
cmp
=
simple_cst_equal
(
TREE_PURPOSE
(
t1
),
TREE_PURPOSE
(
t2
));
if
(
cmp
<
0
)
my_friendly_abort
(
114
);
if
(
cmp
==
0
)
return
0
;
}
}
return
1
+
warn_contravariance
;
return
warn_contravariance
?
-
1
:
1
;
}
/* Return 1 if PARMS specifies a fixed number of parameters
...
...
@@ -6876,7 +6841,7 @@ convert_for_assignment (type, rhs, errtype, fndecl, parmnum)
{
tree
ttl
=
TYPE_PTRMEMFUNC_FN_TYPE
(
type
);
tree
ttr
=
(
TREE_CODE
(
rhstype
)
==
POINTER_TYPE
?
rhstype
:
TYPE_PTRMEMFUNC_FN_TYPE
(
type
));
:
TYPE_PTRMEMFUNC_FN_TYPE
(
rhs
type
));
int
ctt
=
comp_target_types
(
ttl
,
ttr
,
1
);
if
(
ctt
<
0
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment