1. 10 Jul, 2019 6 commits
    • Eric Myhre's avatar
      Finish ErrWrongKind; add typed.Node.Representation · ecad4261
      Eric Myhre authored
      typed.Node.Representation(), which returns another Node, should address
      most of the infelicies we've found so far in trying to plan nice code
      that works over the schema layer.
      
      Also added in this comment: ipld.ReprKindSet, primarily for use in the
      ErrWrongKind error.  It comes up often enough we might as well formalize
      the thing.
      ecad4261
    • Eric Myhre's avatar
      An earlier draft of an error type. · 1a53233c
      Eric Myhre authored
      It's high time we got started on well-typed errors; and this type name
      is already hinted at by the codegen outputs, so let's make it real.
      
      This file has been hanging around on my disk uncommitted for a fair
      while, and some of the comments about review-needed are stale, but I'm
      keepin' em for historical interest.  I think I have fixes planned that
      will straight out all of them.
      1a53233c
    • Eric Myhre's avatar
      Boilerplate reduction. · d4d18944
      Eric Myhre authored
      d4d18944
    • Eric Myhre's avatar
      Merge pull request #15 from ipld/feat/mod-ci-codecov · d245623d
      Eric Myhre authored
      Add travis & codecov and go modules support
      d245623d
    • Alex's avatar
      ci: add codecov and travis · 4a737c7f
      Alex authored
      4a737c7f
    • Eric Myhre's avatar
      Confess the config file for localhost CI. · fce6682e
      Eric Myhre authored
      This works via the 'reach' tool (and more specifically,
      'reach ci' subcommand) from the Timeless Stack.
      
      (The catalog files for the compiler and base image should perhaps be
      vendored as well for maximum reliability, but it also works to create
      a '.timeless' dir somewhere either in or above this working directory,
      and clone the https://github.com/polydawn/catalog repo to the
      '.timeless/catalog' path.)
      
      Note that while this works for "localhost CI" usecases, we'll also be
      using some other tooling for getting the familiar integrations with
      Github and online dashboards, etc.  These can coexist in parallel.
      fce6682e
  2. 07 Jul, 2019 1 commit
  3. 02 Jul, 2019 1 commit
  4. 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
  5. 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
  6. 23 Jun, 2019 1 commit
  7. 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
  8. 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
  9. 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
  10. 06 Apr, 2019 1 commit
  11. 31 Mar, 2019 3 commits
    • Eric Myhre's avatar
      Track LastBlock correctly in traversal.Focus. · 717b235c
      Eric Myhre authored
      And test.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      717b235c
    • Eric Myhre's avatar
      Explicit names for several TP/TC embedded fields. · fa670628
      Eric Myhre authored
      Autocomplete on TraversalProgress was suggesting *way* too many things.
      It's now reigned in.
      
      Being able to say `tp.Ctx` is gone, but that's a small price to pay.
      (And perhaps we should actually move the Context up to TP?  Wouldn't
      seem unreasonable.  I think the main reason it's in TC right now is
      to reduce the size of memory that's shuffled when TP is passed by value
      down the stack, and it's unclear how consequential that's really
      going to be in the big picture.  We can review this later.)
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      fa670628
    • Eric Myhre's avatar
      traversal.Focus implemented and tests: links go! · d7be1f27
      Eric Myhre authored
      NodeBuilderChooser returned -- sorry.  There are some cases where it's
      unavoidable.  (If we have schemas / typed nodes, we can do feature
      detection on the node to see if it can recommend an appropriate
      NodeBuilder for the far side of its link.  If we're fine using Node
      implementations that have 'any' storage support, it's not an issue.
      If we're using *bind* implementation Nodes -- which are constrained
      by the Golang native type system, and yet not perfectly mapped onto
      our own typed.Node constraint declarations -- then we need some way
      to choose the NodeBuilder.  So.  NodeBuilderChooser.  Again: sorry.)
      
      We can probably still expect the NodeBuilderChooser to be fixed
      (probably returning one of the 'any' storage supporting Node impls)
      in practice, since these traversal systems are generally for either
      "low context" usage (e.g., dunno what the data is) or will be used
      on typed/schema nodes, in which case we're again free of these issues.
      And the default values will indeed do this, using our new helpful
      default initialization for TraversalConfig.
      
      TraversalConfig will now always be initialized to sensible default
      values when using any of the traversal methods.  That means you can
      always assume `tp.Ctx`, etc, are going to be set -- no nil checks
      necssary -- even though they're optional to the caller.
      
      Error messages from traversal.Focus are touched up a bit for both
      consistency and clearer information.  There's more work to do here:
      we want these to be full-on typed errors before we call it "done".
      This work will probably begin soon, but be spread over quite a few
      commits (we also need to go back up to the *main* ipld package and
      make types for Node-level errors, and make sure tests exist to
      standardize those errors across Node implementations as well).
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      d7be1f27
  12. 29 Mar, 2019 5 commits
    • Eric Myhre's avatar
      Merge branch 'serial-tests' · 23c6f913
      Eric Myhre authored
      23c6f913
    • Eric Myhre's avatar
      cidlink: use cids in all messages. · cd73b670
      Eric Myhre authored
      Emitting just the multihash part, though in some ways technically
      correct, is really weird looking.
      
      Let's use the CID consistently in messaging.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      cd73b670
    • Eric Myhre's avatar
      cc0c2f24
    • Eric Myhre's avatar
      Test that dagcbor and dagjson roundtrip cidlinks. · 7106176e
      Eric Myhre authored
      Including one interesting fix for dagjson.
      
      Since json can include whitespace -- and especially since our
      implementation currently uses prettyprinted json with quite a bit of
      said whitespace -- it's important to handle it consistently.
      
      We had a fun issue here: the json would be emitted with a trailing
      linebreak (as is generally what you want for printing to a terminal,
      etc!)... and thus hashed with it.  Then, when loading the object,
      our parser will load exactly every byte needed to parse the object,
      then stop.  Which... will cause it to return right before consuming
      that trailing linebreak.
      
      Which would cause that trailing linebreak to not be fed into the
      hasher, since we've carefully used a system which tees exactly the
      bytes consumed by the parser into the the hasher.
      
      So of course the link hash validation would fail.  Woowee.
      
      I documented some of these details in an issue on the specs repo:
      https://github.com/ipld/specs/issues/108
      There's not a super clear resolution over there as yet, but there seems
      to be a general agreement that whitespace should be tolerated, so...
      let's do so.
      
      As of this patch, the dagjson unmarshaller will consume all additional
      whitespace after finishing consumption of the json object iself.
      
      Dagcbor doesn't need a similar fix: there's no such thing as any
      possibility of other nonsemantic bytes, so there's nothing to absorb;
      and if we don't reach the end of the reader... we technically don't
      *care*: given the same reader over the same data being used to load
      the same link, we'll behave consistently; and therefore it follows that
      any additional bytes in the reader are unobservable to our universe.
      
      An earlier (and badly broken) draft of this attempted to put the
      read-to-end behavior in the cidlink package, but in addition to being
      unnecessary for dagcbor as described above, it also would've been
      simply *wrong*: the whitespace slurp is specific to dagjson.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      7106176e
    • Eric Myhre's avatar
      Encoding tests and fixtures and fixes. · 00a58f7a
      Eric Myhre authored
      The refmt step functions expose "done" a little more eagerly than this
      code figured on, so that's been corrected.
      Signed-off-by: default avatarEric Myhre <hash@exultant.us>
      00a58f7a
  13. 28 Mar, 2019 1 commit
  14. 24 Mar, 2019 1 commit
  15. 21 Mar, 2019 1 commit