1. 13 Dec, 2020 5 commits
  2. 04 Dec, 2020 7 commits
  3. 01 Dec, 2020 13 commits
    • Daniel Martí's avatar
      node/gendemo: use the new code generator · 9fe4b32b
      Daniel Martí authored
      The files in this codegen demo correspond to an older version of the Go
      code generator. That's not terrible in itself, but it did make repeated
      uses of 'go test' fail:
      
      	$ go test
      	testing: warning: no tests to run
      	PASS
      	ok  	github.com/ipld/go-ipld-prime/node/gendemo	0.112s
      	$ go test
      	# github.com/ipld/go-ipld-prime/node/gendemo [github.com/ipld/go-ipld-prime/node/gendemo.test]
      	./minima.go:10:2: midvalue redeclared in this block
      		previous declaration at ./ipldsch_minima.go:13:27
      	[...]
      9fe4b32b
    • Eric Myhre's avatar
      Merge-ignore pull request #89 from ipld/prettyprinter · fdb657f8
      Eric Myhre authored
      The original idea of this branch was to explore some reusable
      components for codecs; maybe to actually get a useful
      prettyprinter; and... actually turned a lot into being a bit of
      practical discovery about string encoding and escaping.
      
      Some of those goals were partially accomplished, but in general,
      this seems better to chalk up as a learning experience.
      https://github.com/ipld/go-ipld-prime/pull/89#issuecomment-703327909
      already does a good job of discussing why, and what as learned.
      
      A lot of the reusable codec components stuff has also now
      shaken out, just... in other PRs that were written after the learnings
      here.  Namely, https://github.com/ipld/go-ipld-prime/pull/101/
      was able to introduce some tree transformers; and then
      https://github.com/ipld/go-ipld-prime/pull/112 demonstrates how those
      can compose into a complete codec end to end.
      There's still work to go on these, too, but they seem to have already
      grabbed the concept of reusable parts I was hoping for here and gotten
      farther with it, so.
      
      These diffs are interesting enough I want to keep them referencable
      in history.  But I'm merging them with the "-s ours" strategy, so that
      the diffs don't actually land any impact on master.  These commits
      are for reference only.
      fdb657f8
    • Eric Myhre's avatar
      Move the pretty package out of the codec subtree. · 1d1fc495
      Eric Myhre authored
      It still uses the codec/tools package, but it's very clearly not a
      codec itself and shouldn't be grouped like one, despite the shared
      common implementation details.
      
      Renamed methods to "Stringify".
      
      Stringify no longer returns errors; those errors only arise from
      the writer erroring, and writing into an in-memory buffer can't error.
      1d1fc495
    • Eric Myhre's avatar
    • Eric Myhre's avatar
      Introduce pretty printing tool. · 32a1ed04
      Eric Myhre authored
      I think this, or a variant of it, may be reasonable to rig up as a
      Stringer on the basicnode types, and recommend for other Node
      implementations to use as their Stringer too.
      
      It's a fairly verbose output: I'm mostly aiming to use it in examples.
      
      Bytes in particular are fun: I decided to make them use the hex.Dump
      format.  (Why not?)
      
      I've put this in a codec sub-package, because in some ways it feels
      like a codec -- it's something you can apply to any node, and it
      streams data out to an io.Writer -- but it's also worth noting it's
      not meant to be a multicodec or generally written with an intention
      of use anywhere outside of debug printf sorts of uses.
      
      The codectools package, although it only has this one user, is a
      reaction to previous scenarios where I've wanted a quick debug method
      and desperately wanted something that gives me reasonable quoted
      strings... without reaching for a json package.  We'll see if it's
      worth it over time; I'm betting yes, but not with infinite confidence.
      (This particular string escaping function also has the benefit of
      encoding even non-utf-8 strings without loss of information -- which
      is noteworthy, because I've recently noticed JSON _does not_; yikes.)
      32a1ed04
    • Eric Myhre's avatar
      Merge pull request #96 , originally known as ipld/cidlink-only-usable-as-ptr · 257c260a
      Eric Myhre authored
      In fact this became a docs change; it is often desirable to *not* use the cidlink.Link type as a pointer.
      257c260a
    • Eric Myhre's avatar
      8125cacb
    • Eric Myhre's avatar
      Revert "Make the cidlink.Link type only usable as a pointer." · 96aa55ea
      Eric Myhre authored
      Trying to make CIDs only usable as a pointer would be nice from a
      consistency perspective, but has other consequences.
      
      It's easy to forget this (and I apparently just did), but...
      We often use link types as map keys.  And this is Important.
      
      That means trying to handle CIDs as pointers leads to nonsensical
      results: pointers are technically valid as a golang map key, but
      they don't "do the right thing" -- the equality check ends up operating
      on the the pointer rather than on the data.  This is well-defined,
      but generally useless for these types in context.
      96aa55ea
    • Eric Myhre's avatar
      Make the cidlink.Link type only usable as a pointer. · 55dcf0c3
      Eric Myhre authored
      As the comments in the diff say: it's a fairly sizable footgun for
      users to need to consider whether they expect the pointer form or
      the bare form when inspecting what an `ipld.Link` interface contains:
      so, let's just remove the choice.
      
      There's technically no reason for the Link.Load method to need to be
      attached to the pointer receiver other than removing this footgun.
      From the other side, though, there's no reason *not* to make it
      attached to the pointer receiver, because any time a value is assigned
      to an interface type, it necessarily heap-escapes and becomes a pointer
      anyway.  So, making it unconditional and forcing the pointer to be
      clear in the user's hands seems best.
      55dcf0c3
    • Eric Myhre's avatar
      Merge pull request #112 from ipld/codec-revamp · 2aa907a3
      Eric Myhre authored
      Codec revamp
      2aa907a3
    • Eric Myhre's avatar
      Tweak to alloc counting tests. · ca680715
      Eric Myhre authored
      I dearly wish this wasn't such a dark art.
      But I really want these tests, too.
      ca680715
    • Eric Myhre's avatar
      Revamped DAG-JSON decoder and unmarshaller. · 53fb23e4
      Eric Myhre authored
      This is added in a new "dagjson2" package for the time being,
      but aims to replace the current dagjson package entirely,
      and will take over that namespace when complete.
      
      So far only the decoder/unmarshaller is included in this first commit,
      and the encoder/marshaller is still coming up.
      
      This revamp is making several major strides:
      
      - The decoding system is cleanly separated from the tree building.
      
      - The tree building reuses the codectools token assembler systems.
        This saves a lot of code, and adds a lot of consistency.
        (By contrast, the older dagjson and dagcbor packages had similar
        outlines, but didn't actually share much code; this was annoying
        to maintain, and meant improvements to one needed to be ported
        to the other manually.  No more.)
      
      - The token type used by this codectools system is more tightly
        associated with the IPLD Data Model.  In practice, what this means
        is links are parsed at the same stage as the rest of parsing,
        rather than being added on in an awkward "parse 1.5" stage.
        This results in much less complicated code than the old token
        system from refmt which the older dagjson package leans on.
      
      - Budgets are more consistently woven through this system.
      
      - The JSON decoder components are in their own sub-package,
        and should be relatively reusable.  Some features like string parsing
        are exported in their own right, in addition to being accessable
        via the full recursive supports-everything decoders.
        (This might not often be compelling, but -- maybe.  I myself wanted
        more reusable access to fine-grained decoder and encoder components
        when I was working on the "JST" experiment, so, I'm scratching my
        own itch here if nothing else.)
        End-users should mostly not need to see this, but library
        implementors might appreciate it.
      
      - The codectools scratch.Reader type is used in all the decoder APIs.
        This results in good performance for either streaming io.Reader or
        already-in-memory bytes slices as data sources, and does it without
        doubling the number of exported functions we need (or pushing the
        need for feature detection into every single exported function).
      
      - The configuration system for the decoder is actually in this repo,
        and it's sanely and clearly settable while also being optional.
        Previously, if you wanted to configure dagjson, you'd have to reach
        into the refmt json package for *those* configuration structs,
        which was workable but just very confusing and gave the end-user a
        lot of different places to look before finding what they need.
      
      - The implementations are very mindful of memory allocation efficiency.
        Almost all of the component structures carefully utilize embedding:
        ReusableUnmarsahller embeds the Decoder; the Decoder embeds the
        scratch.Reader as well as the Token it yields; etc.
        This should result in overall being able to produce fully usable
        codecs with a minimal number of allocations -- much fewer than the
        older implementations required.
      
      Some benefits have yet to be realized, but are on the map now:
      
      - The new Token structure also includes space for position and
        progress tracking, which we want to use to produce better errors.
        (This needs more implementation work, still, though.)
      
      - There are several configuraiton options for strictness.
        These aren't all backed up by the actual implementation yet
        (I'm porting over old code fast enough to write a demo and make
        sure the whole suite of interfaces works; it'll require further
        work, especially on this strictness front, later), but
        at the very least these are now getting documented,
        and several comment blocks point to where more work is needed.
      
      - The new multicodec registry is alluded to in comments here, but
        isn't implemented yet.  This is part of the long game big goal.
        The aim is to, by the end of this revamp, be able to do something
        about https://github.com/ipld/go-ipld-prime/issues/55 , and approach
        https://gist.github.com/warpfork/c0200cc4d99ee36ba5ce5a612f1d1a22 .
      53fb23e4
    • Eric Myhre's avatar
      Add scratch.Reader tool, helpful for decoders. · 3040f082
      Eric Myhre authored
      The docs in the diff should cover it pretty well.
      It's a reader-wrapper that does a lot of extremely common
      buffering and small-read operations that parsers tend to need.
      
      This emerges from some older generation of code in refmt with similar purpose:
      https://github.com/polydawn/refmt/blob/master/shared/reader.go
      Unlike those antecedents, this one is a single concrete implementation,
      rather than using interfaces to allow switching between the two major modes of use.
      This is surely uglier code, but I think the result is more optimizable.
      
      The tests include aggressive checks that operations take exactly as
      many allocations as planned -- and mostly, that's *zero*.
      
      In the next couple of commits, I'll be adding parsers which use this.
      
      Benchmarks are still forthcoming.  My recollection from the previous
      bout of this in refmt was that microbenchmarking this type wasn't
      a great use of time, because when we start benchmarking codecs built
      *upon* it, and especially, when looking at the pprof reports from that,
      we'll see this reader showing up plain as day there, and nicely
      contextualized... so, we'll just save our efforts for that point.
      3040f082
  4. 30 Nov, 2020 1 commit
    • Will's avatar
      Allow overriden types (#116) · fe47b7f0
      Will authored
      This change will look at the destination package that codegen is being built into, and will skip generation of types that are already declared by files not prefixed with `ipldsch_`.
      
      This isn't the cleanest escape-hatch, but it's a start.
      fe47b7f0
  5. 18 Nov, 2020 1 commit
  6. 17 Nov, 2020 6 commits
  7. 14 Nov, 2020 7 commits
    • Will Scott's avatar
      Return error rather than panic · bfb8b49e
      Will Scott authored
      bfb8b49e
    • Eric Myhre's avatar
      Merge pull request #101 from ipld/codectools-tokenizers · 624fae00
      Eric Myhre authored
      Fresh take on codec APIs, and some tokenization utilities.
      624fae00
    • Eric Myhre's avatar
      Add position tracking fields to Token. · 1110155d
      Eric Myhre authored
      These aren't excersied yet -- and this is accordingly still highly
      subject to change -- but so far in developing this package, the pattern
      has been "if I say maybe this should have X", it's always turned out
      it indeed should have X.  So let's just do that and then try it out,
      and have the experimental code instead of the comments.
      1110155d
    • Eric Myhre's avatar
      Token.Normalize utility method. · a8995f6f
      Eric Myhre authored
      Useful for tests that do deep equality tests on structures.
      
      Same caveat about current placement of this method as in the previous
      commit: this might be worth detaching and shifting to a 'codectest'
      or 'tokentest' package.  But let's see how it shakes out.
      a8995f6f
    • Eric Myhre's avatar
      Extract and export StringifyTokenSequence utility. · d3511334
      Eric Myhre authored
      This is far too useful in testing to reproduce in each package that
      needs something like it.  It's already shown up as desirable again
      as soon as I start implementing even a little bit of even one codec
      tokenizer, and that's gonna keep happening.
      
      This might be worth moving to some kind of a 'tokentest' or
      'codectest' package instead of cluttering up this one, but...
      we'll see; I've got a fair amount more code to flush into commits,
      and after that we can reshake things and see if packages settle
      out differently.
      d3511334
    • Eric Myhre's avatar
      Add budget parameter to TokenReader. · 33fb7d98
      Eric Myhre authored
      There were already comments about how this would be "probably"
      necessary; I don't know why I wavered, it certainly is.
      33fb7d98
    • Eric Myhre's avatar
      Type the TokenKind consts correctly. · 72793f26
      Eric Myhre authored
      You can write a surprising amount of code where the compiler will shrug
      and silently coerce things for you.  Right up until you can't.
      (Some test cases that'll be coming down the commit queue shortly
      happened to end up checking the type of the constants, and, well.
      Suddenly this was noticable.)
      72793f26