<div dir="ltr">Is Makefile format really that hard to understand?<div>It took 15 minutes for me to port the build rules fin Makefile to my build tool. That's definitely less than I spent reading this thread, BTW ;)<br><div class="gmail_extra"><br clear="all"><div><div class="gmail_signature"><br>Konstantin</div></div>
<br><div class="gmail_quote">2015-12-15 20:23 GMT+03:00 Jonathan Blow <span dir="ltr"><<a href="mailto:jon@number-none.com" target="_blank">jon@number-none.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">A porting guide would definitely help, because most of the several hours (and most of the frustration) is just not knowing what to do <span></span>and having to figure it out. If you knew exactly what to do it's 30 minutes or less.<br><br>A one-file solution could just be set up to error if you don't provide the necessary defines ... Which then indicates very clearly to the user exactly what decisions they need to make, and you would it even need to write a porting guide! (I think of documentation as code that is always wrong because it never runs.)<div class="HOEnZb"><div class="h5"><div><br></div><div><br>On Tuesday, December 15, 2015, Behdad Esfahbod <<a href="mailto:behdad.esfahbod@gmail.com" target="_blank">behdad.esfahbod@gmail.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On 15-12-15 02:14 PM, Jonathan Blow wrote:<br>
> Sure, it would be fine to add this; there is also a for-loop in one spot that<br>
> doesn't compile in Visual Studio because it declares an enum inline, so one<br>
> has to move the enum.<br>
<br>
That's fixed already.  Will be in next release (I thought that went into a<br>
release already).<br>
<br>
<br>
> But these things don't matter, they only take a minute to fix. It's trivial.<br>
> Whereas getting the library to build and link for the first time is measured<br>
> in hours.<br>
><br>
> It is a two-orders-of-magnitude difference, which is why I am saying that if<br>
> widespread use of the code is a goal, making it easier to build should be the<br>
> priority.<br>
<br>
But the one-minute manual fixes have to be redone every time you want to<br>
update your copy of harfbuzz, whereas the initial build has to be done once.<br>
So I rather optimize for faster roll-forward than faster initial-build.<br>
<br>
An nmake build system for Windows will be coming soon:<br>
<br>
  <a href="https://github.com/behdad/harfbuzz/pull/164" target="_blank">https://github.com/behdad/harfbuzz/pull/164</a><br>
<br>
A CMake one might happen.  But in general nothing in text layout is easy, so<br>
making the library much easier to build is not going to matter much.  You<br>
still have to study the problem enough to know whether you want freetype,<br>
ucdn, etc; as well as figure out the atomic and mutex implementation.  So a<br>
one-file solution is more often than not going to get something wrong.  That<br>
said, I might give it a try and see how much work it is.  It does make day to<br>
day compiles much slower, so it can't be the default.  Not being default means<br>
that it will either rot or can hide tricky bugs in there.<br>
<br>
Might be easier if we just write a good porting guide instead.<br>
<br>
behdad<br>
<br>
> On Tuesday, December 15, 2015, Behdad Esfahbod <<a>behdad.esfahbod@gmail.com</a><br>
> <mailto:<a>behdad.esfahbod@gmail.com</a>>> wrote:<br>
><br>
>     On 15-12-13 09:33 PM, Jamie Dale wrote:<br>
>     > You'll need a define to stub out getenv for a PS4 build<br>
><br>
>     I'll take a patch to hb-private.hh to do that.<br>
><br>
</blockquote></div>
</div></div><br>_______________________________________________<br>
HarfBuzz mailing list<br>
<a href="mailto:HarfBuzz@lists.freedesktop.org">HarfBuzz@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/harfbuzz" rel="noreferrer" target="_blank">http://lists.freedesktop.org/mailman/listinfo/harfbuzz</a><br>
<br></blockquote></div><br></div></div></div>