1 /*
2  *             Copyright Andrej Mitrovic 2013.
3  *  Distributed under the Boost Software License, Version 1.0.
4  *     (See accompanying file LICENSE_1_0.txt or copy at
5  *           http://www.boost.org/LICENSE_1_0.txt)
6  */
7 module git.types;
8 
9 import std.array;
10 import std.conv;
11 import std.exception;
12 import std..string;
13 
14 import deimos.git2.common;
15 import deimos.git2.errors;
16 import deimos.git2.types;
17 import deimos.git2.util;
18 
19 import git.exception;
20 import git.version_;
21 
22 /** Basic type (loose or packed) of any Git object. */
23 enum GitType
24 {
25     /// Object can be any of the following types.
26     any        = GIT_OBJ_ANY,
27 
28     /// Object is invalid.
29     bad        = GIT_OBJ_BAD,
30 
31     /// Reserved for future use.
32     ext1       = GIT_OBJ__EXT1,
33 
34     /// A commit object.
35     commit     = GIT_OBJ_COMMIT,
36 
37     /// A tree (directory listing) object.
38     tree       = GIT_OBJ_TREE,
39 
40     /// A file revision object.
41     blob       = GIT_OBJ_BLOB,
42 
43     /// An annotated tag object.
44     tag        = GIT_OBJ_TAG,
45 
46     /// Reserved for future use.
47     ext2       = GIT_OBJ__EXT2,
48 
49     /// A delta, base is given by an offset.
50     ofs_delta  = GIT_OBJ_OFS_DELTA,
51 
52     /// A delta, base is given by object id.
53     ref_delta  = GIT_OBJ_REF_DELTA
54 }
55 
56 /** Basic type of any Git reference. */
57 enum GitRefType
58 {
59     /** Invalid reference. */
60     invalid = GIT_REF_INVALID,
61 
62     /** A reference which points at an object id. */
63     oid = GIT_REF_OID,
64 
65     /** A reference which points at another reference. */
66     symbolic = GIT_REF_SYMBOLIC,
67 
68     list_all = GIT_REF_LISTALL,
69 }
70 
71 /** Basic type of any Git branch. */
72 enum GitBranchType
73 {
74     local = GIT_BRANCH_LOCAL,
75     remote = GIT_BRANCH_REMOTE,
76 }
77 
78 /** Valid modes for index and tree entries. */
79 enum GitFileModeType
80 {
81     new_ = GIT_FILEMODE_NEW,
82     tree = GIT_FILEMODE_TREE,
83     blob = GIT_FILEMODE_BLOB,
84     blob_exe = GIT_FILEMODE_BLOB_EXECUTABLE,
85     link = GIT_FILEMODE_LINK,
86     commit = GIT_FILEMODE_COMMIT,
87 }
88 
89 /// The return type of walker callbacks.
90 enum ContinueWalk
91 {
92     /// Stop walk
93     no,
94 
95     /// Continue walk
96     yes
97 }
98 
99 /// The return type of walker callbacks.
100 enum ContinueWalkSkip
101 {
102     /// Stop walk
103     no,
104 
105     /// Continue walk
106     yes,
107 
108     /// Skip the current sub tree
109     skip
110 }
111 
112 /**
113  * Callback for transfer progress information during remote operations (cloning,
114  * fetching).
115  *
116  * Generally called in-line with network operations, take care not to degrade
117  * performance.
118  */
119 struct GitTransferProgress
120 {
121     package this(const(git_transfer_progress)* p)
122     {
123         this.tupleof = (*p).tupleof;
124     }
125 
126     uint totalObjects;
127     uint indexedObjects;
128     uint receivedObjects;
129     static if (targetLibGitVersion == VersionInfo(0, 20, 0)) {
130         uint local_objects;
131         uint total_deltas;
132         uint indexed_deltas;
133     }
134     size_t receivedBytes;
135 }
136 
137 /// ditto
138 alias TransferCallbackDelegate = void delegate(const ref GitTransferProgress stats);