• Show log

    Commit

  • Hash : c6184f0c
    Author : Patrick Steinhardt
    Date : 2020-06-08T21:07:36

    tree-wide: do not compile deprecated functions with hard deprecation
    
    When compiling libgit2 with -DDEPRECATE_HARD, we add a preprocessor
    definition `GIT_DEPRECATE_HARD` which causes the "git2/deprecated.h"
    header to be empty. As a result, no function declarations are made
    available to callers, but the implementations are still available to
    link against. This has the problem that function declarations also
    aren't visible to the implementations, meaning that the symbol's
    visibility will not be set up correctly. As a result, the resulting
    library may not expose those deprecated symbols at all on some platforms
    and thus cause linking errors.
    
    Fix the issue by conditionally compiling deprecated functions, only.
    While it becomes impossible to link against such a library in case one
    uses deprecated functions, distributors of libgit2 aren't expected to
    pass -DDEPRECATE_HARD anyway. Instead, users of libgit2 should manually
    define GIT_DEPRECATE_HARD to hide deprecated functions. Using "real"
    hard deprecation still makes sense in the context of CI to test we don't
    use deprecated symbols ourselves and in case a dependant uses libgit2 in
    a vendored way and knows it won't ever use any of the deprecated symbols
    anyway.