<div dir="ltr">On Fri, Sep 13, 2013 at 4:56 PM, Nick Kledzik <span dir="ltr"><<a href="mailto:kledzik@apple.com" target="_blank">kledzik@apple.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote">

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><br><div><div class="im"><div>On Sep 13, 2013, at 4:40 PM, Rui Ueyama <<a href="mailto:ruiu@google.com" target="_blank">ruiu@google.com</a>> wrote:</div>

<blockquote type="cite"><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

I know we are using SimpleFile for GOT/PLT atoms, for example, and I doubt that's a good design. These atoms are not read from any files but produced by the linker after the core liking is done so semantically they don't belong to any file. A SimpleFile is used only as a dummy value because it's mandatory. We might be able to simplify the thing by making an optional thing optional.</div>

<div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

<br></div><blockquote class="gmail_quote" style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">

<div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">So I'd want to make _file field optional for the atom. What do you guys<br>

think?<br></blockquote></div>I dont think we do this.<br></blockquote><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

<br></div><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

Can you elaborate?</div><div style="font-family:Helvetica;font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px">

<br></div></blockquote></div>In the darwin linker (also atom based), the file() method is optional.  And that has been a big source of (crasher) bugs.  Because to be truly optional, every place in the linker that access the file() method must be prepared for it to return NULL and do something.  That is a pain to get right.</div>

<div><br></div><div>Having a dummy file with some useful name (e.g. “GOT pass”) simplifies all clients (don’t need to check if file exists), and makes error messages more useful.</div></div></blockquote><div><br></div><div>

Atom::atom() is defined to return a reference to File, so it cannot return NULL. How does the Darwin linker made it optional? Your point makes sense though.</div></div></div></div>