-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
first release libsophon.
- Loading branch information
0 parents
commit 76b3614
Showing
4,465 changed files
with
2,645,060 additions
and
0 deletions.
The diff you're trying to view is too large. We only load the first 3000 changed files.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
/* Generated from defines.h.in during build configuration using CMake. */ | ||
|
||
// Note: This header file is only used internally. It is not part of public interface! | ||
// Any cmakedefine is defined using the -D flag instead when Bazel is used. | ||
// For Bazel, this file is thus not used to avoid a private file in $(GENDIR). | ||
|
||
#ifndef GFLAGS_DEFINES_H_ | ||
#define GFLAGS_DEFINES_H_ | ||
|
||
|
||
// Define if you build this library for a MS Windows OS. | ||
/* #undef OS_WINDOWS */ | ||
|
||
// Define if you have the <stdint.h> header file. | ||
#define HAVE_STDINT_H | ||
|
||
// Define if you have the <sys/types.h> header file. | ||
#define HAVE_SYS_TYPES_H | ||
|
||
// Define if you have the <inttypes.h> header file. | ||
#define HAVE_INTTYPES_H | ||
|
||
// Define if you have the <sys/stat.h> header file. | ||
#define HAVE_SYS_STAT_H | ||
|
||
// Define if you have the <unistd.h> header file. | ||
#define HAVE_UNISTD_H | ||
|
||
// Define if you have the <fnmatch.h> header file. | ||
#define HAVE_FNMATCH_H | ||
|
||
// Define if you have the <shlwapi.h> header file (Windows 2000/XP). | ||
/* #undef HAVE_SHLWAPI_H */ | ||
|
||
// Define if you have the strtoll function. | ||
#define HAVE_STRTOLL | ||
|
||
// Define if you have the strtoq function. | ||
/* #undef HAVE_STRTOQ */ | ||
|
||
// Define if you have the <pthread.h> header file. | ||
#define HAVE_PTHREAD | ||
|
||
// Define if your pthread library defines the type pthread_rwlock_t | ||
#define HAVE_RWLOCK | ||
|
||
|
||
#endif // GFLAGS_DEFINES_H_ |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
// Copyright (c) 2008, Google Inc. | ||
// All rights reserved. | ||
// | ||
// Redistribution and use in source and binary forms, with or without | ||
// modification, are permitted provided that the following conditions are | ||
// met: | ||
// | ||
// * Redistributions of source code must retain the above copyright | ||
// notice, this list of conditions and the following disclaimer. | ||
// * Redistributions in binary form must reproduce the above | ||
// copyright notice, this list of conditions and the following disclaimer | ||
// in the documentation and/or other materials provided with the | ||
// distribution. | ||
// * Neither the name of Google Inc. nor the names of its | ||
// contributors may be used to endorse or promote products derived from | ||
// this software without specific prior written permission. | ||
// | ||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
// | ||
// --- | ||
|
||
// | ||
// Implement helpful bash-style command line flag completions | ||
// | ||
// ** Functional API: | ||
// HandleCommandLineCompletions() should be called early during | ||
// program startup, but after command line flag code has been | ||
// initialized, such as the beginning of HandleCommandLineHelpFlags(). | ||
// It checks the value of the flag --tab_completion_word. If this | ||
// flag is empty, nothing happens here. If it contains a string, | ||
// however, then HandleCommandLineCompletions() will hijack the | ||
// process, attempting to identify the intention behind this | ||
// completion. Regardless of the outcome of this deduction, the | ||
// process will be terminated, similar to --helpshort flag | ||
// handling. | ||
// | ||
// ** Overview of Bash completions: | ||
// Bash can be told to programatically determine completions for the | ||
// current 'cursor word'. It does this by (in this case) invoking a | ||
// command with some additional arguments identifying the command | ||
// being executed, the word being completed, and the previous word | ||
// (if any). Bash then expects a sequence of output lines to be | ||
// printed to stdout. If these lines all contain a common prefix | ||
// longer than the cursor word, bash will replace the cursor word | ||
// with that common prefix, and display nothing. If there isn't such | ||
// a common prefix, bash will display the lines in pages using 'more'. | ||
// | ||
// ** Strategy taken for command line completions: | ||
// If we can deduce either the exact flag intended, or a common flag | ||
// prefix, we'll output exactly that. Otherwise, if information | ||
// must be displayed to the user, we'll take the opportunity to add | ||
// some helpful information beyond just the flag name (specifically, | ||
// we'll include the default flag value and as much of the flag's | ||
// description as can fit on a single terminal line width, as specified | ||
// by the flag --tab_completion_columns). Furthermore, we'll try to | ||
// make bash order the output such that the most useful or relevent | ||
// flags are the most likely to be shown at the top. | ||
// | ||
// ** Additional features: | ||
// To assist in finding that one really useful flag, substring matching | ||
// was implemented. Before pressing a <TAB> to get completion for the | ||
// current word, you can append one or more '?' to the flag to do | ||
// substring matching. Here's the semantics: | ||
// --foo<TAB> Show me all flags with names prefixed by 'foo' | ||
// --foo?<TAB> Show me all flags with 'foo' somewhere in the name | ||
// --foo??<TAB> Same as prior case, but also search in module | ||
// definition path for 'foo' | ||
// --foo???<TAB> Same as prior case, but also search in flag | ||
// descriptions for 'foo' | ||
// Finally, we'll trim the output to a relatively small number of | ||
// flags to keep bash quiet about the verbosity of output. If one | ||
// really wanted to see all possible matches, appending a '+' to the | ||
// search word will force the exhaustive list of matches to be printed. | ||
// | ||
// ** How to have bash accept completions from a binary: | ||
// Bash requires that it be informed about each command that programmatic | ||
// completion should be enabled for. Example addition to a .bashrc | ||
// file would be (your path to gflags_completions.sh file may differ): | ||
|
||
/* | ||
$ complete -o bashdefault -o default -o nospace -C \ | ||
'/home/build/eng/bash/bash_completions.sh --tab_completion_columns $COLUMNS' \ | ||
time env binary_name another_binary [...] | ||
*/ | ||
|
||
// This would allow the following to work: | ||
// $ /path/to/binary_name --vmodule<TAB> | ||
// Or: | ||
// $ ./bin/path/another_binary --gfs_u<TAB> | ||
// (etc) | ||
// | ||
// Sadly, it appears that bash gives no easy way to force this behavior for | ||
// all commands. That's where the "time" in the above example comes in. | ||
// If you haven't specifically added a command to the list of completion | ||
// supported commands, you can still get completions by prefixing the | ||
// entire command with "env". | ||
// $ env /some/brand/new/binary --vmod<TAB> | ||
// Assuming that "binary" is a newly compiled binary, this should still | ||
// produce the expected completion output. | ||
|
||
|
||
#ifndef GFLAGS_COMPLETIONS_H_ | ||
#define GFLAGS_COMPLETIONS_H_ | ||
|
||
namespace google { | ||
|
||
extern void HandleCommandLineCompletions(void); | ||
|
||
} | ||
|
||
#endif // GFLAGS_COMPLETIONS_H_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,156 @@ | ||
// Copyright (c) 1999, Google Inc. | ||
// All rights reserved. | ||
// | ||
// Redistribution and use in source and binary forms, with or without | ||
// modification, are permitted provided that the following conditions are | ||
// met: | ||
// | ||
// * Redistributions of source code must retain the above copyright | ||
// notice, this list of conditions and the following disclaimer. | ||
// * Redistributions in binary form must reproduce the above | ||
// copyright notice, this list of conditions and the following disclaimer | ||
// in the documentation and/or other materials provided with the | ||
// distribution. | ||
// * Neither the name of Google Inc. nor the names of its | ||
// contributors may be used to endorse or promote products derived from | ||
// this software without specific prior written permission. | ||
// | ||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
|
||
// --- | ||
// | ||
// Revamped and reorganized by Craig Silverstein | ||
// | ||
// This is the file that should be included by any file which declares | ||
// command line flag. | ||
|
||
#ifndef GFLAGS_DECLARE_H_ | ||
#define GFLAGS_DECLARE_H_ | ||
|
||
|
||
// --------------------------------------------------------------------------- | ||
// Namespace of gflags library symbols. | ||
#define GFLAGS_NAMESPACE google | ||
|
||
// --------------------------------------------------------------------------- | ||
// Windows DLL import/export. | ||
|
||
// Whether gflags library is a DLL. | ||
// | ||
// Set to 1 by default when the shared gflags library was built on Windows. | ||
// Must be overwritten when this header file is used with the optionally also | ||
// built static library instead; set by CMake's INTERFACE_COMPILE_DEFINITIONS. | ||
#ifndef GFLAGS_IS_A_DLL | ||
# define GFLAGS_IS_A_DLL 0 | ||
#endif | ||
|
||
// We always want to import the symbols of the gflags library. | ||
#ifndef GFLAGS_DLL_DECL | ||
# if GFLAGS_IS_A_DLL && defined(_MSC_VER) | ||
# define GFLAGS_DLL_DECL __declspec(dllimport) | ||
# elif defined(__GNUC__) && __GNUC__ >= 4 | ||
# define GFLAGS_DLL_DECL __attribute__((visibility("default"))) | ||
# else | ||
# define GFLAGS_DLL_DECL | ||
# endif | ||
#endif | ||
|
||
// We always want to import variables declared in user code. | ||
#ifndef GFLAGS_DLL_DECLARE_FLAG | ||
# if GFLAGS_IS_A_DLL && defined(_MSC_VER) | ||
# define GFLAGS_DLL_DECLARE_FLAG __declspec(dllimport) | ||
# elif defined(__GNUC__) && __GNUC__ >= 4 | ||
# define GFLAGS_DLL_DECLARE_FLAG __attribute__((visibility("default"))) | ||
# else | ||
# define GFLAGS_DLL_DECLARE_FLAG | ||
# endif | ||
#endif | ||
|
||
// --------------------------------------------------------------------------- | ||
// Flag types | ||
#include <string> | ||
#if 1 | ||
# include <stdint.h> // the normal place uint32_t is defined | ||
#elif 1 | ||
# include <sys/types.h> // the normal place u_int32_t is defined | ||
#elif 1 | ||
# include <inttypes.h> // a third place for uint32_t or u_int32_t | ||
#endif | ||
|
||
namespace GFLAGS_NAMESPACE { | ||
|
||
#if 1 // C99 | ||
typedef int32_t int32; | ||
typedef uint32_t uint32; | ||
typedef int64_t int64; | ||
typedef uint64_t uint64; | ||
#elif 0 // BSD | ||
typedef int32_t int32; | ||
typedef u_int32_t uint32; | ||
typedef int64_t int64; | ||
typedef u_int64_t uint64; | ||
#elif 0 // Windows | ||
typedef __int32 int32; | ||
typedef unsigned __int32 uint32; | ||
typedef __int64 int64; | ||
typedef unsigned __int64 uint64; | ||
#else | ||
# error Do not know how to define a 32-bit integer quantity on your system | ||
#endif | ||
|
||
} // namespace GFLAGS_NAMESPACE | ||
|
||
|
||
namespace fLS { | ||
|
||
// The meaning of "string" might be different between now and when the | ||
// macros below get invoked (e.g., if someone is experimenting with | ||
// other string implementations that get defined after this file is | ||
// included). Save the current meaning now and use it in the macros. | ||
typedef std::string clstring; | ||
|
||
} // namespace fLS | ||
|
||
|
||
#define DECLARE_VARIABLE(type, shorttype, name) \ | ||
/* We always want to import declared variables, dll or no */ \ | ||
namespace fL##shorttype { extern GFLAGS_DLL_DECLARE_FLAG type FLAGS_##name; } \ | ||
using fL##shorttype::FLAGS_##name | ||
|
||
#define DECLARE_bool(name) \ | ||
DECLARE_VARIABLE(bool, B, name) | ||
|
||
#define DECLARE_int32(name) \ | ||
DECLARE_VARIABLE(::GFLAGS_NAMESPACE::int32, I, name) | ||
|
||
#define DECLARE_uint32(name) \ | ||
DECLARE_VARIABLE(::GFLAGS_NAMESPACE::uint32, U, name) | ||
|
||
#define DECLARE_int64(name) \ | ||
DECLARE_VARIABLE(::GFLAGS_NAMESPACE::int64, I64, name) | ||
|
||
#define DECLARE_uint64(name) \ | ||
DECLARE_VARIABLE(::GFLAGS_NAMESPACE::uint64, U64, name) | ||
|
||
#define DECLARE_double(name) \ | ||
DECLARE_VARIABLE(double, D, name) | ||
|
||
#define DECLARE_string(name) \ | ||
/* We always want to import declared variables, dll or no */ \ | ||
namespace fLS { \ | ||
extern GFLAGS_DLL_DECLARE_FLAG ::fLS::clstring& FLAGS_##name; \ | ||
} \ | ||
using fLS::FLAGS_##name | ||
|
||
|
||
#endif // GFLAGS_DECLARE_H_ |
Oops, something went wrong.