Discussion:
Bug in the linker
(too old to reply)
johnny dude
2019-08-21 11:59:15 UTC
Permalink
Hi,

I found a possible bug, ld does not produce an error message: "multiple
definitions" when it is a constructor defined in the structure declaration.

How to reproduce it:
I'm using the gcc:9.2.0 docker, created two files and the result listed
below:

***@44027fc60f45:/# cat a.cpp
#include <iostream>
struct A { int n; A(int n) : n(n + 10) {} };
int a(int n) { return A(n).n; }
extern int b(int n);
int main(int, char**) { std::clog << a(5) << ", " << b(5) << "\n"; }

***@44027fc60f45:/# cat b.cpp
#include <iostream>
struct A { int n; A(int n) : n(n + 100) {} };
int b(int n) { return A(n).n; }

***@44027fc60f45:/# g++ a.cpp b.cpp -o ab && ./ab
15, 15

***@44027fc60f45:/# g++ b.cpp a.cpp -o ba && ./ba
105, 105
***@44027fc60f45:/#
Andreas Schwab
2019-08-21 14:09:33 UTC
Permalink
Post by johnny dude
#include <iostream>
struct A { int n; A(int n) : n(n + 10) {} };
int a(int n) { return A(n).n; }
extern int b(int n);
int main(int, char**) { std::clog << a(5) << ", " << b(5) << "\n"; }
#include <iostream>
struct A { int n; A(int n) : n(n + 100) {} };
int b(int n) { return A(n).n; }
This violates basic.def.odr.

Andreas.
--
Andreas Schwab, ***@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510 2552 DF73 E780 A9DA AEC1
"And now for something completely different."
johnny dude
2019-08-21 16:43:25 UTC
Permalink
Thank you for the quick response.

I understand the violation.

In all other cases ld returns an error of: "multiple definitions".
Including the same code, with the constructor defined outside the struct
declaration.

I thought it might be an implementation detail.
Post by Andreas Schwab
Post by johnny dude
#include <iostream>
struct A { int n; A(int n) : n(n + 10) {} };
int a(int n) { return A(n).n; }
extern int b(int n);
int main(int, char**) { std::clog << a(5) << ", " << b(5) << "\n"; }
#include <iostream>
struct A { int n; A(int n) : n(n + 100) {} };
int b(int n) { return A(n).n; }
This violates basic.def.odr.
Andreas.
--
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510 2552 DF73 E780 A9DA AEC1
"And now for something completely different."
Loading...