1. 08 Aug, 2018 2 commits
  2. 07 Aug, 2018 2 commits
  3. 05 Aug, 2018 1 commit
  4. 31 Jul, 2018 1 commit
  5. 30 Jul, 2018 4 commits
  6. 28 Jul, 2018 2 commits
  7. 23 Jul, 2018 1 commit
  8. 18 Jul, 2018 4 commits
  9. 17 Jul, 2018 1 commit
  10. 16 Jul, 2018 6 commits
  11. 09 Jul, 2018 2 commits
    • Lucas Molas's avatar
      unixfs: remove unused `ShardSplitThreshold` variable · ba02f3fa
      Lucas Molas authored
      License: MIT
      Signed-off-by: default avatarLucas Molas <schomatis@gmail.com>
      ba02f3fa
    • Lucas Molas's avatar
      unixfs: add a directory interface · 842c17b9
      Lucas Molas authored
      Add a UnixFS `Directory` that hides implementation details and helps to
      distinguish *what* is a UnixFS directory.
      
      Replace the `unixfs.io.Directory` structure that contained the HAMT and basic
      directory implementations (through inner pointers) with an interface containing
      the same methods. Implement those methods in two clearly distinct structures for
      each implementation (`BasicDirectory` and `HAMTDirectory`) avoiding pointer
      logic and clearly differentiating which implementation does what.
      
      The potential basic to HAMT transition was being hidden behind the `AddChild`
      call at the UnixFS layer (changing one implementation pointer  with the other
      one), it is now being explicitly done at the MFS layer.
      
      Rename the `dirbuilder.go` file to `directory.go` and change the `Directory` MFS
      attribute `dirbuilder` to `unixfsDir` to be consistent.
      
      License: MIT
      Signed-off-by: default avatarLucas Molas <schomatis@gmail.com>
      842c17b9
  12. 06 Jul, 2018 3 commits
  13. 05 Jul, 2018 1 commit
  14. 28 Jun, 2018 3 commits
  15. 27 Jun, 2018 2 commits
    • Steven Allen's avatar
      use `copy` instead of looping · b5263d6a
      Steven Allen authored
      License: MIT
      Signed-off-by: default avatarSteven Allen <steven@stebalien.com>
      b5263d6a
    • Steven Allen's avatar
      gx update · afe71e4b
      Steven Allen authored
      Updates:
      
      * go-kad-dht: Query performance improvements, DHT client fixes, validates
        records on *local* put.
      * go-libp2p-swarm/go-libp2p-transport: Timeout improvements.
      * go-multiaddr-net: Exposes useful Conn methods (CloseWrite, CloseRead, etc.)
      * go-log: fixes possible panic when enabling/disabling events.
      * go-multiaddr: fixes possible panic when stringifying malformed multiaddrs,
        adds support for consuming /p2p/ multiaddrs.
      
      fixes #5113
      unblocks #4895
      
      License: MIT
      Signed-off-by: default avatarSteven Allen <steven@stebalien.com>
      afe71e4b
  16. 13 Jun, 2018 1 commit
  17. 11 Jun, 2018 1 commit
    • Lucas Molas's avatar
      unixfs: integrate `pb.Data` into `FSNode` · 3c982f0b
      Lucas Molas authored
      To avoid duplicating fields and making the code easier to follow.
      
      Remove all of `FSNode` previous fields in favor on a single `pb.Data` structure
      that is not exported. Accessor methods are added only for the necessary internal
      fields. This takes up more memory, `pb.Data` is always created inside `FSNode`
      and it stays there instead of just being created and destroyed during the
      (un)marshal operations.
      
      The removed fields `Data`, `blocksizes` and `Type` had a direct counterpart in
      the embedded `pb.Data` structure, in contrast (only) the `subtotal` field
      doesn't have one, it was used as a temporary accumulator to track the
      `Filesize`, which is now being kept updated on every modification (to ensure the
      entire `FSNode` is always at a valid state), so `subtotal` could just be removed
      without the addition of any other field (this temporary accumulator  was
      obscuring how `Filesize` was computed).
      
      To keep `Filesize` up to date a method was added (`UpdateFilesize()`) to adjust
      its value in the two places where the file size could be modified, when changing
      its data (in `SetData()`, accessor method added) and when adding or removing
      child nodes (in `AddBlockSize()` and `RemoveBlockSize()`).
      
      A constructor method was added (`NewFSNode()`) to initialize the required
      fields, like `Type` which is explicitly set, this deprecates the previous
      methodology of just calling `new(FSNode)` and relying in the default value of
      `pb.Data_DataType` (`Data_Raw`) to avoid an explicit assignment. Also,
      `Filesize` is initialized to avoid being left with a `nil` value before
      marshaling empty nodes, which would result in a different hash from previous
      versions, to be backwards compatible. Previous versions of `GetBytes()` always
      set the `Filesize` value, even though it is reflected as an `optional` field in
      the `.proto` file (this may be an inaccurate field rule).
      
      Without the duplicated fields the functions `GetBytes()` and `FSNodeFromBytes()`
      are now reduced to simple `Marshal()` and `Unmarshal()` operations respectively.
      
      License: MIT
      Signed-off-by: default avatarLucas Molas <schomatis@gmail.com>
      3c982f0b
  18. 09 Jun, 2018 1 commit
  19. 01 Jun, 2018 1 commit
  20. 20 Apr, 2018 1 commit