1. 17 Jul, 2015 1 commit
  2. 08 Jul, 2015 1 commit
  3. 03 Jul, 2015 3 commits
    • Kenton Varda's avatar
      Merge pull request #223 from mrdomino/no-eproto · cbd18b28
      Kenton Varda authored
      Workaround nonexistent EPROTO on OpenBSD
      cbd18b28
    • Steven Dee's avatar
      Workaround nonexistent EPROTO on OpenBSD · 156efd49
      Steven Dee authored
      Fixes #221.
      156efd49
    • Kenton Varda's avatar
      Refactor how messages are imbued with a capability table. · 5413038b
      Kenton Varda authored
      **The problem**
      
      The methods MessageReader::initCapTable() and MessageBuilder::getCapTable() always felt rather hacky. initCapTable() in particular feels like something that should be handled by the constructor. However, in practice, the cap table is often initialized based on a table encoded within the message itself. That is, an RPC message contains a "payload" which includes both the application-level message structure and a table of capabilities. The cap table has to be processed first, then initCapTable() is called on the overall message, before the application structure can safely be read.
      
      The really weird part about this is that even though the cap table only applies to one branch of the message (the payload), it is set on the *whole* MessageReader. This implies, for example, that it would be impossible to have a message that contains multiple payloads. We haven't had any need for such a thing, but an implemnetation that has such artificial limitations feels very wrong.
      
      MessageBuilder has similar issues going in the opposite direction.
      
      All of this ugliness potentially gets worse when we introduce "membranes". We want a way to intercept capabilities as they are being read from or written to an RPC payload. Currently, the only plausible way to do that is, again, to apply a transformation to all capabilities in the message. In practice it seems like this would work out OK, but it again feels wrong -- we really want to take a single Reader or Builder and "wrap" it so that transformations are applied on capabilities read/written through it.
      
      **The solution**
      
      This change fixes the problem by adding a new pointer to each struct/list Reader/Builder that tracks the current cap table. So, now a Reader or Builder for a particular sub-object can be "imbued" with a cap table without affecting any other existing Readers/Builders pointing into the same message. The cap table is inherited by child Readers/Builders obtained through the original one.
      
      This approach matches up nicely with membranes, which should make their implementation nice and clean.
      
      This change unfortunately means that Readers and Builders are now bigger, possibly with some performance impact.
      5413038b
  4. 28 Jun, 2015 1 commit
  5. 26 Jun, 2015 2 commits
  6. 23 Jun, 2015 3 commits
    • Kenton Varda's avatar
      Fix bug where calling a list setter using a list obtained from a similarly-typed… · 949f7353
      Kenton Varda authored
      Fix bug where calling a list setter using a list obtained from a similarly-typed getter, but where the underlying pointer was null, would write an incorrectly-typed pointer in the destination (specifically, an empty List(Void)). Now it sets an empty list of the correct type.
      949f7353
    • Kenton Varda's avatar
      2ed4b4e7
    • Kenton Varda's avatar
      Fixes #219, with POSSIBLE (but obscure) WIRE FORMAT BREAKAGE. · db7ca960
      Kenton Varda authored
      Unfortunately, the layout algorithm had a bug which caused incorrect layout when declaring a union whose lowest-ordinal field was of type Void and nested in an inner union. That is:
      
          union {
            a :union {
              b @0 :Void
              ...
            }
            ...
          }
      
      In this case, all the fields in the struct after the Void field -- including both unions' discriminants -- would end up misplaced. Although they did not end up overlapping (and therefore the incorrect layout "worked"), the result broke schema evolution rules around "retroactive unionization".
      
      Unfortunately, we must break compatibility with any protocol that happened to contain the above pattern. Luckily, it's a fairly obscure case. Unluckily, Cap'n Proto's own schema format contains such a pattern. Luckily, the use of this pattern was introduced in v0.6.x and therefore has not been in any release build so far.
      db7ca960
  7. 22 Jun, 2015 2 commits
  8. 14 Jun, 2015 1 commit
  9. 12 Jun, 2015 3 commits
  10. 11 Jun, 2015 4 commits
  11. 10 Jun, 2015 1 commit
  12. 09 Jun, 2015 1 commit
  13. 30 May, 2015 1 commit
  14. 29 May, 2015 2 commits
  15. 26 May, 2015 1 commit
    • Kenton Varda's avatar
      sed -r is a GNU extension, apparently, and due to stars aligning, this didn't… · 25be62be
      Kenton Varda authored
      sed -r is a GNU extension, apparently, and due to stars aligning, this didn't break the build, but led to a totally bogus soname on non-GNU systems. Argh.
      
      Apparently most systems (including GNU, undocumentedly) support -E instead, but perhaps the safest thing is to use a basic regular expression. Unfortunately on many systems ? and + are not available in basic regexes, but using * instead happens to work in our case.
      
      Thanks to @neverpanic for catching this.
      
      Fixes #210
      25be62be
  16. 21 May, 2015 1 commit
  17. 20 May, 2015 3 commits
  18. 16 May, 2015 2 commits
  19. 15 May, 2015 1 commit
  20. 10 May, 2015 1 commit
  21. 09 May, 2015 2 commits
  22. 07 May, 2015 2 commits
  23. 06 May, 2015 1 commit