Thoughts about D
Michael V. Franklin
slavo5150 at yahoo.com
Mon Dec 4 01:01:47 UTC 2017
On Monday, 4 December 2017 at 00:25:53 UTC, Michael V. Franklin
wrote:
> A better solution would be to do what Iain said:
>
>> Try compiling a simple "hello world" with an empty object.d
>> file. Then inspect what the compiler does. Does it error and
>> exit, or does it ICE? What can be done to prevent that from
>> happening?
>
>> When you reach the point that there's no way but to declare a
>> symbol or function, add that to object.d and then move onto
>> the next error or ICE. Repeat until you can compile and link
>> your program.
>
>> Next, try something a little more complex, such as define a
>> struct and use it. Then again address all problems that you
>> encounter with that.
Here's an illustration:
object.d
----------------------------
module object;
alias immutable(char)[] string;
struct ModuleInfo { }
main.d
-----------------------------
module main;
long sys_write(long arg1, in void* arg2, long arg3)
{
long result;
asm
{
mov RAX, 1;
mov RDI, arg1;
mov RSI, arg2;
mov RDX, arg3;
syscall;
}
return result;
}
void write(in string text)
{
sys_write(2, text.ptr, text.length);
}
extern(C) void main()
{
write("Hello\n");
}
.$> dmd -defaultlib= -debuglib= -conf= main.d -of=main
/usr/bin/ld: main.o: relocation R_X86_64_32 against
`.rodata.str1.1' can not be used when making a shared object;
recompile with -fPIC
/usr/bin/ld: final link failed: Nonrepresentable section on output
I didn't compile with -shared. What's going on here?
.$> dmd -defaultlib= -debuglib= -conf= main.d -of=main -fPIC
main.o:(.text.d_dso_init[.data.d_dso_rec]+0x22): undefined
reference to `_d_dso_registry'
Again, not sure why the compiler's generated code for that?
Would it help for me to file bugzilla issues for things like
this? The reason I haven't thus far, is that this is just a
symptom of a larger issue. It needs a development strategy to be
solved holistically.
Mike
More information about the Digitalmars-d
mailing list