summaryrefslogtreecommitdiff
path: root/gitstatus/src/git.h
blob: b85f09f7b7401742f36a30e3d6723ef818429058 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
// Copyright 2019 Roman Perepelitsa.
//
// This file is part of GitStatus.
//
// GitStatus is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// GitStatus is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with GitStatus. If not, see <https://www.gnu.org/licenses/>.

#ifndef ROMKATV_GITSTATUS_GIT_H_
#define ROMKATV_GITSTATUS_GIT_H_

#include <git2.h>

#include <cstddef>
#include <memory>
#include <string>

namespace gitstatus {

// Not null.
const char* GitError();

// Not null.
std::string RepoState(git_repository* repo);

// Returns the number of commits in the range.
size_t CountRange(git_repository* repo, const std::string& range);

// How many stashes are there?
size_t NumStashes(git_repository* repo);

// Returns the origin URL or an empty string. Not null.
std::string RemoteUrl(git_repository* repo, const git_reference* ref);

// Returns reference to HEAD or null if not found. The reference is symbolic if the repo is empty
// and direct otherwise.
git_reference* Head(git_repository* repo);

// Returns the name of the local branch, or an empty string.
const char* LocalBranchName(const git_reference* ref);

struct CommitMessage {
  // Can be empty, meaning "UTF-8".
  std::string encoding;
  // The first paragraph of the commit's message as a one-liner.
  std::string summary;
};

CommitMessage GetCommitMessage(git_repository* repo, const git_oid& id);

struct Remote {
  // Tip of the remote branch.
  git_reference* ref;

  // Name of the tracking remote. For example, "origin".
  std::string name;

  // Name of the tracking remote branch. For example, "master".
  std::string branch;

  // URL of the tracking remote. For example, "https://foo.com/repo.git".
  std::string url;

  // Note: pushurl is not exposed (but could be).

  struct Free {
    void operator()(const Remote* p) const {
      if (p) {
        if (p->ref) git_reference_free(p->ref);
        delete p;
      }
    }
  };
};

struct PushRemote {
  // Tip of the remote branch.
  git_reference* ref;

  // Name of the tracking remote. For example, "origin".
  std::string name;

  // URL of the tracking remote. For example, "https://foo.com/repo.git".
  std::string url;

  // Note: pushurl is not exposed (but could be).

  struct Free {
    void operator()(const PushRemote* p) const {
      if (p) {
        if (p->ref) git_reference_free(p->ref);
        delete p;
      }
    }
  };
};

using RemotePtr = std::unique_ptr<Remote, Remote::Free>;
using PushRemotePtr = std::unique_ptr<PushRemote, PushRemote::Free>;

RemotePtr GetRemote(git_repository* repo, const git_reference* local);
PushRemotePtr GetPushRemote(git_repository* repo, const git_reference* local);

}  // namespace gitstatus

#endif  // ROMKATV_GITSTATUS_GIT_H_