Create an extras directory with files that are not related to the build but that I need to keep around for reference.
This commit is contained in:
		
							parent
							
								
									ccf37e758c
								
							
						
					
					
						commit
						8b61f7b86b
					
				
					 5 changed files with 297 additions and 11 deletions
				
			
		|  | @ -53,16 +53,29 @@ thing that failed on the build was `libgit2/src/utils/process.h` had several err | ||||||
| missing types.  To keep this description short here's the patch I crafted that solved the problem: | missing types.  To keep this description short here's the patch I crafted that solved the problem: | ||||||
| 
 | 
 | ||||||
| ```diff | ```diff | ||||||
| 10a11,12 | --- subprojects/libgit2-1.8.0/src/util/process.h	2024-03-20 16:19:37.000000000 -0400 | ||||||
| > typedef struct git_str git_str; | +++ process.h	2024-05-09 08:05:48.279986200 -0400 | ||||||
| > | @@ -8,6 +8,8 @@ | ||||||
| 115,118c117 |  #ifndef INCLUDE_process_h__ | ||||||
| < GIT_INLINE(bool) git_process__is_cmdline_option(const char *str) |  #define INCLUDE_process_h__ | ||||||
| < { |   | ||||||
| < 	return (str && str[0] == '-'); | +typedef struct git_str git_str; | ||||||
| < } | + | ||||||
| --- |  typedef struct git_process git_process; | ||||||
| > #define git_process__is_cmdline_option(str) ((str) && (str[0]) == '-') |   | ||||||
|  |  typedef struct { | ||||||
|  | @@ -112,10 +114,7 @@ | ||||||
|  |   * cmdline arguments to ensure that they are not erroneously treated | ||||||
|  |   * as an option. For example, arguments to `ssh`. | ||||||
|  |   */ | ||||||
|  | -GIT_INLINE(bool) git_process__is_cmdline_option(const char *str) | ||||||
|  | -{ | ||||||
|  | -	return (str && str[0] == '-'); | ||||||
|  | -} | ||||||
|  | +#define git_process__is_cmdline_option(str) ((str) && (str[0]) == '-') | ||||||
|  |   | ||||||
|  |  /** | ||||||
|  |   * Start the process. | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| What's even stranger is that the compilation errors _only_ showed up when I included any C++ | What's even stranger is that the compilation errors _only_ showed up when I included any C++ | ||||||
|  | @ -83,7 +96,7 @@ int main(int argc, char *argv[]) | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| What's wile is do you see how I have a `test_libgit2` function and I'm including a `libgit2-test.h` | What's wild is do you see how I have a `test_libgit2` function and I'm including a `libgit2-test.h` | ||||||
| file?  I even went so far as to place all of the `libgit2` code into a separate compilation unit to | file?  I even went so far as to place all of the `libgit2` code into a separate compilation unit to | ||||||
| firewall it off and the bug _STILL_ showed up.  That `libgit2-test.h` header had absolutely zero | firewall it off and the bug _STILL_ showed up.  That `libgit2-test.h` header had absolutely zero | ||||||
| `libgit2` headers or definitions. It only had the one `test_libgit2` function in it. | `libgit2` headers or definitions. It only had the one `test_libgit2` function in it. | ||||||
|  |  | ||||||
							
								
								
									
										3
									
								
								PPP3/extras/README.md
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								PPP3/extras/README.md
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | ||||||
|  | This directory contains additional files that I need to keep around but are not directly related to | ||||||
|  | the build. For example, the `process.h` and `process.diff` are patches to libgit2's | ||||||
|  | `src/util/process.h` file that has a strange bug randomly. | ||||||
							
								
								
									
										26
									
								
								PPP3/extras/git_minimal.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								PPP3/extras/git_minimal.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | ||||||
|  | #include <git2.h> | ||||||
|  | #include <iostream> | ||||||
|  | #include <iomanip> | ||||||
|  | #include <fstream> | ||||||
|  | #include <fmt/core.h> | ||||||
|  | #include <regex> | ||||||
|  | #include <string> | ||||||
|  | #include <iterator> | ||||||
|  | #include <ctime> | ||||||
|  | #include "dbc.h" | ||||||
|  | #include <unistd.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <regex> | ||||||
|  | 
 | ||||||
|  | int main(int argc, char *argv[]) | ||||||
|  | { | ||||||
|  |   git_repository* repo = nullptr; | ||||||
|  | 
 | ||||||
|  |   git_libgit2_init(); | ||||||
|  | 
 | ||||||
|  |   int err = git_repository_open(&repo, argv[1]); | ||||||
|  | 
 | ||||||
|  |   git_libgit2_shutdown(); | ||||||
|  | 
 | ||||||
|  |   git_libgit2_shutdown(); | ||||||
|  | } | ||||||
							
								
								
									
										23
									
								
								PPP3/extras/process.diff
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								PPP3/extras/process.diff
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | ||||||
|  | --- subprojects/libgit2-1.8.0/src/util/process.h	2024-03-20 16:19:37.000000000 -0400
 | ||||||
|  | +++ process.h	2024-05-09 08:05:48.279986200 -0400
 | ||||||
|  | @@ -8,6 +8,8 @@
 | ||||||
|  |  #ifndef INCLUDE_process_h__ | ||||||
|  |  #define INCLUDE_process_h__ | ||||||
|  |   | ||||||
|  | +typedef struct git_str git_str;
 | ||||||
|  | +
 | ||||||
|  |  typedef struct git_process git_process; | ||||||
|  |   | ||||||
|  |  typedef struct { | ||||||
|  | @@ -112,10 +114,7 @@
 | ||||||
|  |   * cmdline arguments to ensure that they are not erroneously treated | ||||||
|  |   * as an option. For example, arguments to `ssh`. | ||||||
|  |   */ | ||||||
|  | -GIT_INLINE(bool) git_process__is_cmdline_option(const char *str)
 | ||||||
|  | -{
 | ||||||
|  | -	return (str && str[0] == '-');
 | ||||||
|  | -}
 | ||||||
|  | +#define git_process__is_cmdline_option(str) ((str) && (str[0]) == '-')
 | ||||||
|  |   | ||||||
|  |  /** | ||||||
|  |   * Start the process. | ||||||
							
								
								
									
										221
									
								
								PPP3/extras/process.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										221
									
								
								PPP3/extras/process.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,221 @@ | ||||||
|  | /*
 | ||||||
|  |  * Copyright (C) the libgit2 contributors. All rights reserved. | ||||||
|  |  * | ||||||
|  |  * This file is part of libgit2, distributed under the GNU GPL v2 with | ||||||
|  |  * a Linking Exception. For full terms see the included COPYING file. | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | #ifndef INCLUDE_process_h__ | ||||||
|  | #define INCLUDE_process_h__ | ||||||
|  | 
 | ||||||
|  | typedef struct git_str git_str; | ||||||
|  | 
 | ||||||
|  | typedef struct git_process git_process; | ||||||
|  | 
 | ||||||
|  | typedef struct { | ||||||
|  | 	unsigned int capture_in  : 1, | ||||||
|  | 	             capture_out : 1, | ||||||
|  | 	             capture_err : 1, | ||||||
|  | 	             exclude_env : 1; | ||||||
|  | 
 | ||||||
|  | 	char *cwd; | ||||||
|  | } git_process_options; | ||||||
|  | 
 | ||||||
|  | typedef enum { | ||||||
|  | 	GIT_PROCESS_STATUS_NONE, | ||||||
|  | 	GIT_PROCESS_STATUS_NORMAL, | ||||||
|  | 	GIT_PROCESS_STATUS_ERROR | ||||||
|  | } git_process_result_status; | ||||||
|  | 
 | ||||||
|  | #define GIT_PROCESS_RESULT_INIT { GIT_PROCESS_STATUS_NONE } | ||||||
|  | 
 | ||||||
|  | typedef struct { | ||||||
|  | 	git_process_result_status status; | ||||||
|  | 	int exitcode; | ||||||
|  | 	int signal; | ||||||
|  | } git_process_result; | ||||||
|  | 
 | ||||||
|  | #define GIT_PROCESS_OPTIONS_INIT { 0 } | ||||||
|  | 
 | ||||||
|  | #ifdef GIT_WIN32 | ||||||
|  | # define p_pid_t DWORD | ||||||
|  | #else | ||||||
|  | # define p_pid_t pid_t | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Create a new process.  The command to run should be specified as the | ||||||
|  |  * element of the `arg` array, execv-style. This should be the full path | ||||||
|  |  * to the command to run, the PATH is not obeyed. | ||||||
|  |  * | ||||||
|  |  * This function will add the given environment variables (in `env`) | ||||||
|  |  * to the current environment.  Operations on environment variables | ||||||
|  |  * are not thread safe, so you may not modify the environment during | ||||||
|  |  * this call.  You can avoid this by setting `exclude_env` in the | ||||||
|  |  * options and providing the entire environment yourself. | ||||||
|  |  * | ||||||
|  |  * @param out location to store the process | ||||||
|  |  * @param args the command (with arguments) to run | ||||||
|  |  * @param args_len the length of the args array | ||||||
|  |  * @param env environment variables to add (or NULL) | ||||||
|  |  * @param env_len the length of the env len | ||||||
|  |  * @param opts the options for creating the process | ||||||
|  |  * @return 0 or an error code | ||||||
|  |  */ | ||||||
|  | extern int git_process_new( | ||||||
|  | 	git_process **out, | ||||||
|  | 	const char **args, | ||||||
|  | 	size_t args_len, | ||||||
|  | 	const char **env, | ||||||
|  | 	size_t env_len, | ||||||
|  | 	git_process_options *opts); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Create a new process. The command to run should be specified as the | ||||||
|  |  * `cmdline` option - which is the full text of the command line as it | ||||||
|  |  * would be specified or run by a user. The command to run will be | ||||||
|  |  * looked up in the PATH. | ||||||
|  |  * | ||||||
|  |  * On Unix, this will be executed by the system's shell (`/bin/sh`) | ||||||
|  |  * and may contain _Bourne-style_ shell quoting rules. On Windows, | ||||||
|  |  * this will be passed to `CreateProcess`, and similarly, may | ||||||
|  |  * contain _Windows-style_ shell quoting rules. | ||||||
|  |  * | ||||||
|  |  * This function will add the given environment variables (in `env`) | ||||||
|  |  * to the current environment.  Operations on environment variables | ||||||
|  |  * are not thread safe, so you may not modify the environment during | ||||||
|  |  * this call.  You can avoid this by setting `exclude_env` in the | ||||||
|  |  * options and providing the entire environment yourself. | ||||||
|  |  */ | ||||||
|  | extern int git_process_new_from_cmdline( | ||||||
|  | 	git_process **out, | ||||||
|  | 	const char *cmdline, | ||||||
|  | 	const char **env, | ||||||
|  | 	size_t env_len, | ||||||
|  | 	git_process_options *opts); | ||||||
|  | 
 | ||||||
|  | #ifdef GIT_WIN32 | ||||||
|  | 
 | ||||||
|  | extern int git_process__appname( | ||||||
|  | 	git_str *out, | ||||||
|  | 	const char *cmdline); | ||||||
|  | 
 | ||||||
|  | /* Windows path parsing is tricky; this helper function is for testing. */ | ||||||
|  | extern int git_process__cmdline( | ||||||
|  | 	git_str *out, | ||||||
|  | 	const char **in, | ||||||
|  | 	size_t in_len); | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | /*
 | ||||||
|  |  * Whether the given string looks like a command line option (starts | ||||||
|  |  * with a dash). This is useful for examining strings that will become | ||||||
|  |  * cmdline arguments to ensure that they are not erroneously treated | ||||||
|  |  * as an option. For example, arguments to `ssh`. | ||||||
|  |  */ | ||||||
|  | #define git_process__is_cmdline_option(str) ((str) && (str[0]) == '-') | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Start the process. | ||||||
|  |  * | ||||||
|  |  * @param process the process to start | ||||||
|  |  * @return 0 or an error code | ||||||
|  |  */ | ||||||
|  | extern int git_process_start(git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Returns the process id of the process. | ||||||
|  |  * | ||||||
|  |  * @param out pointer to a pid_t to store the process id | ||||||
|  |  * @param process the process to query | ||||||
|  |  * @return 0 or an error code | ||||||
|  |  */ | ||||||
|  | extern int git_process_id(p_pid_t *out, git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Read from the process's stdout.  The process must have been created with | ||||||
|  |  * `capture_out` set to true. | ||||||
|  |  * | ||||||
|  |  * @param process the process to read from | ||||||
|  |  * @param buf the buf to read into | ||||||
|  |  * @param count maximum number of bytes to read | ||||||
|  |  * @return number of bytes read or an error code | ||||||
|  |  */ | ||||||
|  | extern ssize_t git_process_read(git_process *process, void *buf, size_t count); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Read from the process's stderr.  The process must have been created with | ||||||
|  |  * `capture_err` set to true. | ||||||
|  |  * | ||||||
|  |  * @param process the process to read from | ||||||
|  |  * @param buf the buf to read into | ||||||
|  |  * @param count maximum number of bytes to read | ||||||
|  |  * @return number of bytes read or an error code | ||||||
|  |  */ | ||||||
|  | extern ssize_t git_process_read_err(git_process *process, void *buf, size_t count); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Write to the process's stdin.  The process must have been created with | ||||||
|  |  * `capture_in` set to true. | ||||||
|  |  * | ||||||
|  |  * @param process the process to write to | ||||||
|  |  * @param buf the buf to write | ||||||
|  |  * @param count maximum number of bytes to write | ||||||
|  |  * @return number of bytes written or an error code | ||||||
|  |  */ | ||||||
|  | extern ssize_t git_process_write(git_process *process, const void *buf, size_t count); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Wait for the process to finish. | ||||||
|  |  * | ||||||
|  |  * @param result the result of the process or NULL | ||||||
|  |  * @param process the process to wait on | ||||||
|  |  */ | ||||||
|  | extern int git_process_wait(git_process_result *result, git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Close the input pipe from the child. | ||||||
|  |  * | ||||||
|  |  * @param process the process to close the pipe on | ||||||
|  |  */ | ||||||
|  | extern int git_process_close_in(git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Close the output pipe from the child. | ||||||
|  |  * | ||||||
|  |  * @param process the process to close the pipe on | ||||||
|  |  */ | ||||||
|  | extern int git_process_close_out(git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Close the error pipe from the child. | ||||||
|  |  * | ||||||
|  |  * @param process the process to close the pipe on | ||||||
|  |  */ | ||||||
|  | extern int git_process_close_err(git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Close all resources that are used by the process.  This does not | ||||||
|  |  * wait for the process to complete. | ||||||
|  |  * | ||||||
|  |  * @parma process the process to close | ||||||
|  |  */ | ||||||
|  | extern int git_process_close(git_process *process); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Place a human-readable error message in the given git buffer. | ||||||
|  |  * | ||||||
|  |  * @param msg the buffer to store the message | ||||||
|  |  * @param result the process result that produced an error | ||||||
|  |  */ | ||||||
|  | extern int git_process_result_msg(git_str *msg, git_process_result *result); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Free a process structure | ||||||
|  |  * | ||||||
|  |  * @param process the process to free | ||||||
|  |  */ | ||||||
|  | extern void git_process_free(git_process *process); | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw