1. 20 Mar, 2017 2 commits
    • map: remove `*map_free` macros · 94af9155
      The `map_free` functions were not implemented as functions but instead
      as macros which also set the map to NULL. While this is most certainly
      sensible in most cases, we should prefer the more obvious behavior,
      namingly leaving the map pointer intact.
      
      Furthermore, this macro has been refactored incorrectly during the
      map-refactorings: the two statements are not actually grouped together
      by a `do { ... } while (0)` block, as it is required for macros to
      match the behavior of functions more closely. This has led to at least
      one subtle nesting error in `pack-objects.c`. The following code block
      
      ```
          if (pb->object_ix)
              git_oidmap_free(pb->object_ix);
      ```
      
      would be expanded to
      
      ```
          if (pb->object_ix)
              git_oidmap__free(pb->object_ix); pb->object_ix = NULL;
      ```
      
      which is not what one woudl expect. While it is not a bug here as it
      would simply become a no-op, the wrong implementation could lead to bugs
      in other occasions.
      
      Fix this by simply removing the macro altogether and replacing it with
      real function calls. This leaves the burden of setting the pointer to
      NULL afterwards to the caller, but this is actually expected and behaves
      like other `free` functions.
      Patrick Steinhardt committed
    • checkout: fix double-free of checkout_data's mkdir_map · 77c8ee74
      We currently call `git_strmap_free` on `checkout_data.mkdir_map` in the
      `checkout_data_clear` function. The only thing protecting us from a
      double-free is that the `git_strmap_free` function is in fact not a
      function, but a macro that also sets the map to NULL.
      
      Remove the second call to `git_strmap_free` and explicitly set the map
      member to NULL.
      Patrick Steinhardt committed
  2. 15 Mar, 2017 3 commits
  3. 14 Mar, 2017 2 commits
  4. 11 Mar, 2017 2 commits
  5. 09 Mar, 2017 3 commits
  6. 06 Mar, 2017 3 commits
  7. 03 Mar, 2017 8 commits
  8. 01 Mar, 2017 6 commits
  9. 28 Feb, 2017 1 commit
  10. 27 Feb, 2017 1 commit
  11. 26 Feb, 2017 4 commits
  12. 25 Feb, 2017 4 commits
  13. 24 Feb, 2017 1 commit