Before Pat announced he was writing an ebook, I was following the articles he wrote on his blog. He has a real knack for making difficult concepts easy to understand using diagrams and simple language. And on top of that, he asks interesting questions. You might think that Ruby internals are a dull topic, but everything I've seen him cover has fascinated me.
Because I've already learned so much from this articles, I was eager to buy this when I saw the announcement in my inbox.
You should move the purchase button higher on the page or put multiple buttons. My immediate assumption was it was not ready yet until I scrooooled way down to find the purchase link.
Hey pat, how do you understand the internal code so well ? I read your free chapter on Ruby's Hash table and I loved every bit of it. It would be great if you can share the process you go through when you read the source code, so maybe I can apply it in the future. By the way, congrats for the release !
The code for MRI is.. idiomatic, but actually pretty easy to read. I last did C full time in the 90s and so am mostly just a 'reader' now but it's not hard to follow, although some of the reasoning behind doing things a certain way in MRI is unfathomable.. ;-)
Exactly, Peter. It's not tremendously hard to read the C code and understand what it is doing (usually), if you're familiar with C syntax. But it was tremendously difficult at times understanding _why_ it was doing what it was doing.
Hey thanks for asking - and yes, in the preface to the book I do explain how I figure this stuff out. But basically I:
- study the C code for a long time
- step through it in GDB a lot
- add printf statements and recompile it to print out debug/trace info
- actually change it to see what would happen if things were written differently.
A lot of hard work! I do the hard work so you don't have to :)
What is the purpose of this book? Is Ruby internal workings not widely known or understood, or is this more about how to reverse engineer a software stack? Did you discover anything that is not documented in Ruby docs?
Yes - Ruby's internal workings are very mysterious to most people. While the C source code behind Ruby is open source, it's hard to read and understand for most people. In Ruby Under a Microscope, I explain how Ruby works internally… without assuming you know anything about C programming.
Why study Ruby internals in the first place? Here are my reasons (from the book's preface):
- By studying how Ruby works internally, you'll get a deeper understanding of the language and become a better Ruby developer.
- You can learn a lot from the Ruby core team. There is some amazing stuff inside of Ruby, and Ruby's implementation might help you while solving your own coding problems.
- It's fun! It's just super-fascinating stuff!
I learned a lot of stuff about Ruby usage that is not documented. You can read more in the book… :)
Ah weird, I always assumed "modern" programming languages were bootstrapped (for all the advantages that it implies), didn't know it's not the case for Ruby. Good to know.
It's just raining amazing Ruby books lately. Last week there was Working With TCP Sockets and now this. I'm having trouble finding time for them all :).
I'm at a point in my Ruby career where I've begun peeking under all the abstractions I use after hitting performance bottlenecks. Performance has even led me to all sorts of new tools like using a SAX XML parser (using the Ox gem) instead of trying to walk the XML DOM in memory with Nokogiri.
It was just for fun. Both SAX APIs are sorta nebulous as it is to someone like me who's been so used to an abundance of tutorials on the tools I regularly use. Ox's SAX API was better, though.
I'd usually agree with a comment like this but in this case, it has so many (useful) color diagrams that while it wouldn't be impossible to put on the Kindle, I don't think you'd get an amazing experience. Could be wrong though!
That's true, but I suspect the vast majority of Kindle users and buyers are stuck on 6" greyscale screens which aren't great for diagrams or code without a lot of care. "Source code looks horrible on the Kindle edition!" is one of the most common complaints I've seen on Kindle books so far, but it's definitely getting better.
FYI My download kit includes a mobi file, and it looks acceptable on the kindle. But yes, in black and white you'll lose a lot of the value of the diagrams I drew.
Because I've already learned so much from this articles, I was eager to buy this when I saw the announcement in my inbox.