1. 20 Jul, 2019 4 commits
    • Eric Myhre's avatar
      Add generateKindStruct.EmitNodeMethodMapIterator. · 41aed25d
      Eric Myhre authored
      A bit fun; wish there was a way to compress that block of ifdefs about
      optional vs nullable stuff, but so far nothing clearer has emerged.
      
      Added ErrIteratorOverread while at it.  Should refactoring other node
      types to use it too, I suppose.  But perhaps we'll just accumlate those
      todos for a while, since there's already one other error refactor with
      a chain of blocks in front of it.
      41aed25d
    • Eric Myhre's avatar
      Add Node.IsUndefined, ipld.Undef and ipld.Null. · 6802ea10
      Eric Myhre authored
      The comment in the ipld.Node type about IsUndefined has been there
      quite a while; today we're finally using it.
      
      With this set of changes, the generated code for structs now compiles
      successfully again: the Undef and Null thunks are both used there.
      6802ea10
    • Eric Myhre's avatar
      Core of generateKindStruct. · 6898ed22
      Eric Myhre authored
      Generates the struct itself (including the variations of pointers
      and/or extra fields necessary),
      
      There are several major TODOs outstanding; and the generated code
      doesn't *quite* compile due to several missing references, namely:
      
      - ipld.ErrNoSuchField
      - ipld.Nil
      - ipld.Undefined
      
      The other issues remaining:
      
      - The reason ErrNoSuchField is missing is because it needs to be
      decided where an error like that should go.  Is it meaningfully
      distinct from a general "key absent" error, like a map can return?
      If it is indeed a distinct thing, does it go in the schema package,
      or will that just make things annoying until the end of time since
      every occurence-site-sibling error is in the ipld main package?
      
      - We need to think about typed nil / typed undefined.  I suspect they
      are an idea to be avoided (but doing so means using the NodeBuilder()
      method on the nil or undefined values from a struct will *not* "DTRT",
      which may be problematic; this can in turn be avoided by "knowing"
      you're working on a typed node, but, erm.  It turns into a question of
      which of these things is less annoying).
      
      - We'll need to backtrack up to the main ipld.Node interface and add
      that 'IsUndefined() bool' method now!  (Or, take a radical approach of
      using a magic const for that.  But... no, that doesn't sound fun.)
      
      - Haven't even touched the NodeBuilder yet.  (And the typeGenerator
      interface needs to have those bits broken down, as well, so that we can
      do good stuff with error path codesharing as with funcs for Node.)
      
      - Haven't filled in MapIterator.  But that's probably just easy chug.
      
      Lots to do, in short.  I just need a checkpoint.
      
      Note how we've had this on the clipboard for a while already, heh --
      the info_test.go file and TestUnderstandingStructMemoryLayout have been
      aimed at this; notice how any extra bool fields are generated at the
      bottom of the emitted struct.  Many yaks have been shaved in the
      meanwhile, and yet look at how many we have to go.  Isn't this fun?
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      6898ed22
    • Eric Myhre's avatar
      Extract some error path generation. · 83bbe5e1
      Eric Myhre authored
      This isn't a net negative size diff yet, but it certainly will have
      that effect momentarily when we add a generator for another kind.
      More importantly, it reduces the set of functions in the real
      generator file to *just* the relevant ones.
      
      We'll almost certainly extend this to cover the NodeBuilder half of
      things as well, later; I just haven't gotten there yet.
      83bbe5e1
  2. 15 Jul, 2019 1 commit
    • Eric Myhre's avatar
      Cut gordian knot. · ff43f7af
      Eric Myhre authored
      I'm solving the decorum problem by making "temporary" builder methods for the
      schema.Type values as necessary.  This will allow the gengo package to use
      them freely for now.  When we're done with all this, I want to restrict building
      of schema.Type values to a single method in the schema package which takes the
      "ast" types -- the ones we're hoping to codegen (!) -- and do lots of checks
      and cross-linking; the temporary builder methods will do *none*, and *of course*
      they can't take the "ast" types yet since they don't exist yet.
      
      Boom, cycle broken.
      
      Also: fix generateStringKind from taking a TypeName redundantly.
      ff43f7af
  3. 13 Jul, 2019 1 commit
    • Eric Myhre's avatar
      Move minima/thunks to own file in gen. · fbc10cb8
      Eric Myhre authored
      This was triggered by an experiment about generating even more 'minima'
      like this, such as a batch of helper structs which would hold all the
      common "no, you can't do operation X on something of kind Y" methods.
      However, that diff isn't here; and is probably going to turn out to be
      abandoned, because after trying it out, I found that it was pretty hard
      to do good error messages (which... was pretty central to the point)
      with that approach.  So, more on those attempts later.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      fbc10cb8
  4. 10 Jul, 2019 1 commit
  5. 01 Jul, 2019 2 commits
    • Eric Myhre's avatar
      Drop what remains of typed/declaration. · 231d4e87
      Eric Myhre authored
      What was left in this last file was mostly docs; and while some of
      that text might be good, we can either write it fresh or come
      dredge it out of history when we re-build something like this package.
      
      Fix the few remaining references to declaration by switching them
      to refer to the reified equivalents in the schema package (which is
      what all those references should have been anyway).
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      231d4e87
    • Eric Myhre's avatar
      Move typed/gen -> schema/gen/go. · 3c5d00d4
      Eric Myhre authored
      Dropped older PoC/draft codegen code at the same time; that
      was a stale idea and the draft that followed it is already
      clearly shaping up better.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      3c5d00d4
  6. 25 Jun, 2019 1 commit
    • Eric Myhre's avatar
      Move codegen demo output to ignored dir. · 853e4a7c
      Eric Myhre authored
      The underscore makes it ignored by the go tools;
      the gitignore does, well, git.
      
      At some point this should probably grow up to have more complete
      tooling and test suites around it, but for early iteration,
      I pretty much have one window open to the generated output file,
      and I'm just running it to see if it compiles, and while this probably
      won't last for long, it's enough to get exploratory work done.
      853e4a7c
  7. 20 Apr, 2019 1 commit
    • Eric Myhre's avatar
      New take on schema codegen. · 52033884
      Eric Myhre authored
      The previous code was lots of switches; I think it's safe enough to
      say that wasn't going to scale or compose very easily.
      This new take is based on some interfaces and a wee dusting of
      polymorphism.
      
      The abstraction *won't* hold: we'll drill through it in many places,
      and there will still be type switches up the wazoo by the end -- see
      the comments already scattered about regarding maps and enums and such.
      But that's okay; a few interfaces will still help; at the very least
      it makes things a bit more structurally self-documenting.
      
      Strings (and one particular representation and node implementation of
      them) are all that's included here, but so far so good.
      
      The comment above, and the one in the code about "triple cross
      product", probably waggle towards what's going to be the trickiest
      part of this: codegen needs to take into account a *lot* of choices.
      Making the code for this maintainable is going to be nontrivial!
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      52033884