1. 15 Jul, 2019 2 commits
    • Eric Myhre's avatar
      Drop code of an incorrect attempt at Validate(). · d912ea30
      Eric Myhre authored
      Comments added addressing some of the root issues of why, and how to
      try again more correctly next time.  (At least one open question
      has been found that might take a few days to resolve.)
      
      This commit happens now because they code being removed refered to
      `schema.Type.ReprKind()` a lot, and that's the real issue I'm focused
      on at the moment -- that's also going away in the next commit or so.
      There's significantly more subtlety to the type-vs-representation
      duality than the existence of such a method could accurately describe.
      d912ea30
    • Eric Myhre's avatar
      Legacy reference fix in docs string. · ecfee940
      Eric Myhre authored
      ecfee940
  2. 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
  3. 11 Jul, 2019 1 commit
  4. 10 Jul, 2019 13 commits
  5. 07 Jul, 2019 1 commit
  6. 02 Jul, 2019 1 commit
  7. 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
  8. 25 Jun, 2019 10 commits
    • Eric Myhre's avatar
      6c932cbf
    • Eric Myhre's avatar
      Refactor of type/schema code. · 122c5338
      Eric Myhre authored
      - `typed.Node` -> now lives in the `impl/typed` package, more like
      other nodes.
      
      - Most of the other essential parts of reasoning about types moved
      to `schema` package.  ("typed.Type" seemed like a nasty stutter.)
      
      - `typed.Universe` renamed to `schema.TypeSystem`.
      
      - Current `Validate` method moved to `schema` package, but see new
      comments about potential future homes of that code, and its
      aspirational relationship to `typed.Node`.
      
      Conspicuously *not* yet refactored or moved in this comment:
      
      - The `typed/declaration` package -- though it will shortly be scrapped
      and later reappear as `schema/ast`.  The dream is that it would be
      neatest of all if we could generate it by codegen; but we'll see.
      (This would seem to imply we'll have to make sufficient exported
      methods for creating the `schema.Type` values... while we also want
      to make those immutable.  We'll... see.)
      
      - The `typed/gen` package is also untouched in this commit, but
      should similarly move shortly.  The codegen really ought to be built
      against the `schema.Type` reified interfaces.
      
      Overall, this drops the sheer nesting depths of packages a fair bit,
      which seems likely to be a good smell.
      122c5338
    • Eric Myhre's avatar
      Drop schema-schema and examples ipldsch files. · 5e963cc8
      Eric Myhre authored
      These are now going to go live in the ipld/specs repo.
      
      (And @vmx has done the git-fu to even keep their history intact over
      in their new home, which is awesome.)
      
      Onward!
      5e963cc8
    • Eric Myhre's avatar
      Merge branch 'schema-fixups' · 0692e3b8
      Eric Myhre authored
      0692e3b8
    • Rod Vagg's avatar
      schema fixups · 54ac969f
      Rod Vagg authored
      Cherry-picked by eric with several changes.
      
      - The fixups of missing bits of schema-schema are a fair cop.
      
      - Several critical typos in the example.ipldsch.json file are fixed.
      
      - I tweaked the syntax for aliases in the example file; we've had the
        idea since this was originally posted of putting representational
        concerns that are clearly associated with a field inline with the
        fields for convenience, but in parens to distinguish that they're
        indeed representation concerns rather than type/cardinality concerns,
        so this is the expression of that idea.
      
      - I actually walked back the removal of representation blocks in the
        json.  There's probably valid considerations to be made on that, but
        it deserves separate handling.  (Disconcertingly, I actually added
        two *new* representation blocks that seem to previously have been
        missing due to typos.)
      
      Any new errors are presumably mine.
      
      Original: https://github.com/ipld/go-ipld-prime/pull/10
      54ac969f
    • 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
    • Eric Myhre's avatar
      Comments about future needs on nodebuilder. · 11bf0d4e
      Eric Myhre authored
      In thinking about how to make a 'bind' (aka, reflect and atlases) Node
      implementation, some interesting stuff comes up: despite being all
      one concrete Node implementation, it needs specialization (for the
      reflect.Value bound inside, specifically); and 'bind' nodes don't
      *necessarily* have a schema and a typed.Node associated with them,
      so the existing comments about specializing using Type info don't
      actually apply.  So!  What do?
      
      These comments are a tad hypothetical (and have been on my uncommitted
      working tree for a while, so hopefully they're not *too* stale; I just
      want to get them in history somewhere rather than keep dancing my
      patches around them)... but there's almost certainly something to
      address somewhere in this area.
      11bf0d4e
    • Eric Myhre's avatar
      Merge pull request #12 from ipld/selectors · 2fd79241
      Eric Myhre authored
      Begin Selector implementation!
      2fd79241
    • Eric Myhre's avatar
      Merge branch 'more-doc-fix' · 44cd9a8e
      Eric Myhre authored
      44cd9a8e
    • Eric Myhre's avatar
      Fix doc (another inverted bool) · 8569c0a4
      Eric Myhre authored
      Noticed while reviewing the parent commit, so double thanks for that one...!
      8569c0a4
  9. 23 Jun, 2019 1 commit
  10. 17 Jun, 2019 1 commit
    • Matthias Beyer's avatar
      Fix doc · cc0a3f90
      Matthias Beyer authored
      The iteration can stop if the `Done()` method returns true, not false.
      cc0a3f90
  11. 29 Apr, 2019 1 commit
    • Eric Myhre's avatar
      Selector implementation! · cd9283dd
      Eric Myhre authored
      This is a draft.  There's a LOT of hard design choices which are not
      yet completely settled here.
      
      Corresponding updates to the ipld/specs repo will be coming soon:
      these implementations match a very recursive concept of selectors.
      (https://github.com/ipld/specs/pull/116 is roughly this.)
      
      There's so many things to go over, here.
      
      - selectors at all
      - selectFields is kind of a special case of unions
      - selectPath as a concept is gone; is a degenerate case of selectFields
      - we've added some new methods to help narrow down search spaces
      - we have serial selector spec parsers...!  (very hand-rolled.)
      - the idea of always reporting candidates vs definite match parents
        is dropped for now; it requires a different algo with different
        performance characteristics, so, we'll do it as such -- later.
      - we ended up with unions being *in*!  They're going to be used
        internally by a bunch of other things -- see comment blocks in
        the code about that (tl;dr recursives imply a need of unions).
      
      More docs will be coming in future commits; this is just a checkpoint
      of the progress.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      cd9283dd
  12. 20 Apr, 2019 5 commits
    • Eric Myhre's avatar
      Merge branch 'schema-work' · f2d59579
      Eric Myhre authored
      f2d59579
    • 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
    • Eric Myhre's avatar
      1ec2ec37
    • Eric Myhre's avatar
      typed: some comments about schema docs. · da641404
      Eric Myhre authored
      (n.b. like a couple other things I'm about to finally commit, this has
      been a floating diff in my working copy for a while already now;
      it might be a slightly stale understanding of something; but it's
      a part of history now, anyway, whether or not we move on from it.)
      da641404
    • Eric Myhre's avatar
      typed: Commit some long-stale partial diffs. · f5b24ad8
      Eric Myhre authored
      (These have been on my working copy for *months*, waiting to get some
      sliver of time to get back to working on this half of the project...)
      
      So, back in the last time period I was working on schemas, it seemed
      plausible to try to get some self-bootstrapping amount of codegen to
      help me write the whole declaration package itself.  This has not
      held up, lol.
      
      The long end of line comment is my updated feelings about this:
      the main reason self-hosting even during bootstrap would've been nice
      is for map order consistency.  But... we don't... need that.  Per se.
      
      This commit will be merge-ignored momentarily; gonna pick up on
      schema work again starting from a somewhat different angle of attack.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      f5b24ad8
  13. 06 Apr, 2019 1 commit