Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
b9d02460
Commit
b9d02460
authored
Oct 30, 2013
by
Ben Straub
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reorganize rev-parse example
parent
784b3abb
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
56 additions
and
53 deletions
+56
-53
examples/rev-parse.c
+56
-53
No files found.
examples/rev-parse.c
View file @
b9d02460
#include <stdio.h>
/*
#include <git2.h>
* Copyright (C) the libgit2 contributors. All rights reserved.
#include <stdlib.h>
*
#include <string.h>
* This file is part of libgit2, distributed under the GNU GPL v2 with
* a Linking Exception. For full terms see the included COPYING file.
*/
static
void
check
(
int
error
,
const
char
*
message
,
const
char
*
arg
)
#include "common.h"
/* Forward declarations for helpers */
struct
parse_state
{
git_repository
*
repo
;
const
char
*
repodir
;
const
char
*
spec
;
int
not
;
};
static
void
parse_opts
(
struct
parse_state
*
ps
,
int
argc
,
char
*
argv
[]);
static
int
parse_revision
(
struct
parse_state
*
ps
);
int
main
(
int
argc
,
char
*
argv
[])
{
{
if
(
!
error
)
struct
parse_state
ps
=
{
0
};
return
;
if
(
arg
)
git_threads_init
();
fprintf
(
stderr
,
"%s %s (%d)
\n
"
,
message
,
arg
,
error
);
parse_opts
(
&
ps
,
argc
,
argv
);
else
fprintf
(
stderr
,
"%s(%d)
\n
"
,
message
,
error
);
check_lg2
(
parse_revision
(
&
ps
),
"Parsing"
,
NULL
);
exit
(
1
);
git_repository_free
(
ps
.
repo
);
git_threads_shutdown
();
return
0
;
}
}
static
void
usage
(
const
char
*
message
,
const
char
*
arg
)
static
void
usage
(
const
char
*
message
,
const
char
*
arg
)
...
@@ -24,13 +44,25 @@ static void usage(const char *message, const char *arg)
...
@@ -24,13 +44,25 @@ static void usage(const char *message, const char *arg)
exit
(
1
);
exit
(
1
);
}
}
struct
parse_state
{
static
void
parse_opts
(
struct
parse_state
*
ps
,
int
argc
,
char
*
argv
[])
git_repository
*
repo
;
{
const
char
*
repodir
;
struct
args_info
args
=
ARGS_INFO_INIT
;
int
not
;
};
static
int
parse_revision
(
struct
parse_state
*
ps
,
const
char
*
revstr
)
for
(
args
.
pos
=
1
;
args
.
pos
<
argc
;
++
args
.
pos
)
{
const
char
*
a
=
argv
[
args
.
pos
];
if
(
a
[
0
]
!=
'-'
)
{
if
(
ps
->
spec
)
usage
(
"Too many specs"
,
a
);
ps
->
spec
=
a
;
}
else
if
(
!
strcmp
(
a
,
"--not"
))
ps
->
not
=
!
ps
->
not
;
else
if
(
!
match_str_arg
(
&
ps
->
repodir
,
&
args
,
"--git-dir"
))
usage
(
"Cannot handle argument"
,
a
);
}
}
static
int
parse_revision
(
struct
parse_state
*
ps
)
{
{
git_revspec
rs
;
git_revspec
rs
;
char
str
[
GIT_OID_HEXSZ
+
1
];
char
str
[
GIT_OID_HEXSZ
+
1
];
...
@@ -38,11 +70,11 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
...
@@ -38,11 +70,11 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
if
(
!
ps
->
repo
)
{
if
(
!
ps
->
repo
)
{
if
(
!
ps
->
repodir
)
if
(
!
ps
->
repodir
)
ps
->
repodir
=
"."
;
ps
->
repodir
=
"."
;
check
(
git_repository_open_ext
(
&
ps
->
repo
,
ps
->
repodir
,
0
,
NULL
),
check
_lg2
(
git_repository_open_ext
(
&
ps
->
repo
,
ps
->
repodir
,
0
,
NULL
),
"Could not open repository from"
,
ps
->
repodir
);
"Could not open repository from"
,
ps
->
repodir
);
}
}
check
(
git_revparse
(
&
rs
,
ps
->
repo
,
revstr
),
"Could not parse"
,
revstr
);
check
_lg2
(
git_revparse
(
&
rs
,
ps
->
repo
,
ps
->
spec
),
"Could not parse"
,
ps
->
spec
);
if
((
rs
.
flags
&
GIT_REVPARSE_SINGLE
)
!=
0
)
{
if
((
rs
.
flags
&
GIT_REVPARSE_SINGLE
)
!=
0
)
{
git_oid_tostr
(
str
,
sizeof
(
str
),
git_object_id
(
rs
.
from
));
git_oid_tostr
(
str
,
sizeof
(
str
),
git_object_id
(
rs
.
from
));
...
@@ -56,9 +88,9 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
...
@@ -56,9 +88,9 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
if
((
rs
.
flags
&
GIT_REVPARSE_MERGE_BASE
)
!=
0
)
{
if
((
rs
.
flags
&
GIT_REVPARSE_MERGE_BASE
)
!=
0
)
{
git_oid
base
;
git_oid
base
;
check
(
git_merge_base
(
&
base
,
ps
->
repo
,
check
_lg2
(
git_merge_base
(
&
base
,
ps
->
repo
,
git_object_id
(
rs
.
from
),
git_object_id
(
rs
.
to
)),
git_object_id
(
rs
.
from
),
git_object_id
(
rs
.
to
)),
"Could not find merge base"
,
revstr
);
"Could not find merge base"
,
ps
->
spec
);
git_oid_tostr
(
str
,
sizeof
(
str
),
&
base
);
git_oid_tostr
(
str
,
sizeof
(
str
),
&
base
);
printf
(
"%s
\n
"
,
str
);
printf
(
"%s
\n
"
,
str
);
...
@@ -69,38 +101,9 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
...
@@ -69,38 +101,9 @@ static int parse_revision(struct parse_state *ps, const char *revstr)
git_object_free
(
rs
.
from
);
git_object_free
(
rs
.
from
);
}
}
else
{
else
{
check
(
0
,
"Invalid results from git_revparse"
,
revstr
);
fatal
(
"Invalid results from git_revparse"
,
ps
->
spec
);
}
}
return
0
;
return
0
;
}
}
int
main
(
int
argc
,
char
*
argv
[])
{
int
i
;
char
*
a
;
struct
parse_state
ps
;
git_threads_init
();
memset
(
&
ps
,
0
,
sizeof
(
ps
));
for
(
i
=
1
;
i
<
argc
;
++
i
)
{
a
=
argv
[
i
];
if
(
a
[
0
]
!=
'-'
)
{
if
(
parse_revision
(
&
ps
,
a
)
!=
0
)
break
;
}
else
if
(
!
strcmp
(
a
,
"--not"
))
ps
.
not
=
!
ps
.
not
;
else
if
(
!
strncmp
(
a
,
"--git-dir="
,
strlen
(
"--git-dir="
)))
ps
.
repodir
=
a
+
strlen
(
"--git-dir="
);
else
usage
(
"Cannot handle argument"
,
a
);
}
git_repository_free
(
ps
.
repo
);
git_threads_shutdown
();
return
0
;
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment