1 // The following ifdef block is the standard way of creating macros which make exporting
\r
2 // from a DLL simpler. All files within this DLL are compiled with the GITDLL_EXPORTS
\r
3 // symbol defined on the command line. this symbol should not be defined on any project
\r
4 // that uses this DLL. This way any other project whose source files include this file see
\r
5 // GITDLL_API functions as being imported from a DLL, whereas this DLL sees symbols
\r
6 // defined with this macro as being exported.
\r
8 #define EXTERN extern "C"
\r
13 #ifdef GITDLL_EXPORTS
\r
14 #define GITDLL_API __declspec(dllexport) EXTERN
\r
16 #define GITDLL_API __declspec(dllimport) EXTERN
\r
20 // This class is exported from the gitdll.dll
\r
21 class GITDLL_API Cgitdll {
\r
24 // TODO: add your methods here.
\r
28 #define GIT_HASH_SIZE 20
\r
30 typedef unsigned char GIT_HASH[GIT_HASH_SIZE];
\r
31 typedef unsigned int GIT_HANDLE;
\r
32 typedef unsigned int GIT_LOG;
\r
34 typedef unsigned int GIT_DIFF;
\r
35 typedef unsigned int GIT_FILE;
\r
37 struct GIT_COMMIT_AUTHOR
\r
47 typedef struct GIT_COMMIT_DATA
\r
50 struct GIT_COMMIT_AUTHOR m_Author;
\r
51 struct GIT_COMMIT_AUTHOR m_Committer;
\r
56 void * m_pGitCommit; /** internal used */
\r
61 GITDLL_API int ngitdll;
\r
63 GITDLL_API int fngitdll(void);
\r
65 * Get Git Last Error string.
\r
67 GITDLL_API char * get_git_last_error();
\r
70 * @param name [IN] Reference name, such as HEAD, master, ...
\r
71 * @param sha1 [OUT] char[20] hash value. Caller prepare char[20] buffer.
\r
72 * @return 0 success.
\r
74 GITDLL_API int git_get_sha1(const char *name, GIT_HASH sha1);
\r
77 * @remark, this function must be call before other function.
\r
80 GITDLL_API int git_init();
\r
82 GITDLL_API int git_open_log(GIT_LOG * handle, char * arg);
\r
83 GITDLL_API int git_get_log_firstcommit(GIT_LOG handle);
\r
87 * @param handle [IN]handle Get handle from git_open_log
\r
88 * @param commit [OUT]commit Caller need prepare buffer for this call
\r
90 * @remark Caller need call git_free_commit to free internal buffer after use it;
\r
92 GITDLL_API int git_get_log_nextcommit(GIT_LOG handle, GIT_COMMIT *commit);
\r
94 GITDLL_API int git_close_log(GIT_LOG handle);
\r
97 * Get Commit information from commit hash
\r
98 * @param commit [OUT] output commit information
\r
99 * @param hash [in] hash
\r
100 * @return 0 success
\r
102 GITDLL_API int git_get_commit_from_hash(GIT_COMMIT *commit, GIT_HASH hash);
\r
103 GITDLL_API int git_parse_commit(GIT_COMMIT *commit);
\r
104 GITDLL_API int git_free_commit(GIT_COMMIT *commit);
\r
106 GITDLL_API int git_open_diff(GIT_DIFF *diff, char * arg);
\r
107 GITDLL_API int git_diff(GIT_DIFF diff, GIT_HASH hash1,GIT_HASH hash2);
\r
108 GITDLL_API int git_close_diff(GIT_DIFF diff);
\r
110 GITDLL_API int git_get_diff_firstfile(GIT_DIFF diff, GIT_FILE * file);
\r
111 GITDLL_API int git_get_diff_nextfile(GIT_DIFF diff, GIT_FILE *file);
\r
112 GITDLL_API int git_get_diff_status(GIT_DIFF diff, int * status);
\r
113 GITDLL_API int git_get_diff_stat(GIT_FILE file, int *inc, int *dec, int *mode);
\r
114 GITDLL_API int git_get_diff_file(GIT_FILE file, char *newname, int newsize, char *oldname, int oldsize, int *mode);