mirror of
				https://git.proxmox.com/git/libgit2
				synced 2025-10-25 17:22:10 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			97 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Utilities library for libgit2 examples
 | |
|  *
 | |
|  * Written by the libgit2 contributors
 | |
|  *
 | |
|  * To the extent possible under law, the author(s) have dedicated all copyright
 | |
|  * and related and neighboring rights to this software to the public domain
 | |
|  * worldwide. This software is distributed without any warranty.
 | |
|  *
 | |
|  * You should have received a copy of the CC0 Public Domain Dedication along
 | |
|  * with this software. If not, see
 | |
|  * <http://creativecommons.org/publicdomain/zero/1.0/>.
 | |
|  */
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <string.h>
 | |
| #include <stdlib.h>
 | |
| #include <git2.h>
 | |
| 
 | |
| /**
 | |
|  * Check libgit2 error code, printing error to stderr on failure and
 | |
|  * exiting the program.
 | |
|  */
 | |
| extern void check_lg2(int error, const char *message, const char *extra);
 | |
| 
 | |
| /**
 | |
|  * Exit the program, printing error to stderr
 | |
|  */
 | |
| extern void fatal(const char *message, const char *extra);
 | |
| 
 | |
| /**
 | |
|  * Check if a string has the given prefix.  Returns 0 if not prefixed
 | |
|  * or the length of the prefix if it is.
 | |
|  */
 | |
| extern size_t is_prefixed(const char *str, const char *pfx);
 | |
| 
 | |
| /**
 | |
|  * Match an integer string, returning 1 if matched, 0 if not.
 | |
|  */
 | |
| extern int is_integer(int *out, const char *str, int allow_negative);
 | |
| 
 | |
| struct args_info {
 | |
| 	int    argc;
 | |
| 	char **argv;
 | |
| 	int    pos;
 | |
| };
 | |
| #define ARGS_INFO_INIT { argc, argv, 0 }
 | |
| 
 | |
| /**
 | |
|  * Check current `args` entry against `opt` string.  If it matches
 | |
|  * exactly, take the next arg as a string; if it matches as a prefix with
 | |
|  * an equal sign, take the remainder as a string; if value not supplied, 
 | |
|  * default value `def` will be given. otherwise return 0.
 | |
|  */
 | |
| extern int optional_str_arg(
 | |
| 	const char **out, struct args_info *args, const char *opt, const char *def);
 | |
| 
 | |
| /**
 | |
|  * Check current `args` entry against `opt` string.  If it matches
 | |
|  * exactly, take the next arg as a string; if it matches as a prefix with
 | |
|  * an equal sign, take the remainder as a string; otherwise return 0.
 | |
|  */
 | |
| extern int match_str_arg(
 | |
| 	const char **out, struct args_info *args, const char *opt);
 | |
| 
 | |
| /**
 | |
|  * Check current `args` entry against `opt` string parsing as uint16.  If
 | |
|  * `opt` matches exactly, take the next arg as a uint16_t value; if `opt`
 | |
|  * is a prefix (equal sign optional), take the remainder of the arg as a
 | |
|  * uint16_t value; otherwise return 0.
 | |
|  */
 | |
| extern int match_uint16_arg(
 | |
| 	uint16_t *out, struct args_info *args, const char *opt);
 | |
| 
 | |
| /**
 | |
|  * Check current `args` entry against `opt` string parsing as int.  If
 | |
|  * `opt` matches exactly, take the next arg as an int value; if it matches
 | |
|  * as a prefix (equal sign optional), take the remainder of the arg as a
 | |
|  * int value; otherwise return 0.
 | |
|  */
 | |
| extern int match_int_arg(
 | |
| 	int *out, struct args_info *args, const char *opt, int allow_negative);
 | |
| 
 | |
| /**
 | |
|  * Basic output function for plain text diff output
 | |
|  * Pass `FILE*` such as `stdout` or `stderr` as payload (or NULL == `stdout`)
 | |
|  */
 | |
| extern int diff_output(
 | |
| 	const git_diff_delta*, const git_diff_hunk*, const git_diff_line*, void*);
 | |
| 
 | |
| /**
 | |
|  * Convert a treeish argument to an actual tree; this will call check_lg2
 | |
|  * and exit the program if `treeish` cannot be resolved to a tree
 | |
|  */
 | |
| extern void treeish_to_tree(
 | |
| 	git_tree **out, git_repository *repo, const char *treeish);
 | 
