Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
G
gflags
Project
Project
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
gflags
Commits
8566bcf1
Commit
8566bcf1
authored
Mar 19, 2014
by
Andreas Schuh
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Replace GFLAGS_HAVE_* #defines by HAVE_* again.
parent
6e9f4166
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
62 additions
and
103 deletions
+62
-103
CMakeLists.txt
CMakeLists.txt
+34
-34
config.h.in
src/config.h.in
+12
-53
gflags.cc
src/gflags.cc
+4
-4
gflags_declare.h.in
src/gflags_declare.h.in
+3
-3
mutex.h
src/mutex.h
+4
-4
util.h
src/util.h
+4
-4
gflags_unittest.cc
test/gflags_unittest.cc
+1
-1
No files found.
CMakeLists.txt
View file @
8566bcf1
...
@@ -75,6 +75,28 @@ include (CheckTypeSize)
...
@@ -75,6 +75,28 @@ include (CheckTypeSize)
include
(
CheckIncludeFileCXX
)
include
(
CheckIncludeFileCXX
)
include
(
CheckCXXSymbolExists
)
include
(
CheckCXXSymbolExists
)
if
(
MSVC
)
set
(
HAVE_SYS_TYPES_H 1
)
set
(
HAVE_STDINT_H 1
)
set
(
HAVE_STDDEF_H 1
)
# used by CheckTypeSize module
set
(
HAVE_INTTYPES_H 0
)
set
(
HAVE_UNISTD_H 0
)
set
(
HAVE_SYS_STAT_H 1
)
check_include_file_cxx
(
"shlwapi.h"
HAVE_SHLWAPI_H
)
else
()
foreach
(
fname IN ITEMS unistd stdint inttypes sys/types sys/stat fnmatch
)
string
(
TOUPPER
"
${
fname
}
"
FNAME
)
string
(
REGEX REPLACE
"/"
"_"
FNAME
"
${
FNAME
}
"
)
if
(
NOT HAVE_
${
FNAME
}
_H
)
check_include_file_cxx
(
"
${
fname
}
.h"
HAVE_
${
FNAME
}
_H
)
endif
()
endforeach
()
# the following are used in #if not #ifdef
bool_to_int
(
HAVE_STDINT_H
)
bool_to_int
(
HAVE_SYS_TYPES_H
)
bool_to_int
(
HAVE_INTTYPES_H
)
endif
()
set
(
GFLAGS_INTTYPES_FORMAT
""
CACHE STRING
"Format of integer types:
\"
C99
\"
(uint32_t),
\"
BSD
\"
(u_int32_t),
\"
VC7
\"
(__int32)"
)
set
(
GFLAGS_INTTYPES_FORMAT
""
CACHE STRING
"Format of integer types:
\"
C99
\"
(uint32_t),
\"
BSD
\"
(u_int32_t),
\"
VC7
\"
(__int32)"
)
set_property
(
CACHE GFLAGS_INTTYPES_FORMAT PROPERTY STRINGS
"C99;BSD;VC7"
)
set_property
(
CACHE GFLAGS_INTTYPES_FORMAT PROPERTY STRINGS
"C99;BSD;VC7"
)
mark_as_advanced
(
GFLAGS_INTTYPES_FORMAT
)
mark_as_advanced
(
GFLAGS_INTTYPES_FORMAT
)
...
@@ -114,56 +136,34 @@ set (GFLAGS_INTTYPES_FORMAT_BSD 0)
...
@@ -114,56 +136,34 @@ set (GFLAGS_INTTYPES_FORMAT_BSD 0)
set
(
GFLAGS_INTTYPES_FORMAT_VC7 0
)
set
(
GFLAGS_INTTYPES_FORMAT_VC7 0
)
set
(
"GFLAGS_INTTYPES_FORMAT_
${
GFLAGS_INTTYPES_FORMAT
}
"
1
)
set
(
"GFLAGS_INTTYPES_FORMAT_
${
GFLAGS_INTTYPES_FORMAT
}
"
1
)
foreach
(
fname IN ITEMS stdint sys/types fnmatch inttypes unistd sys/stat
)
string
(
TOUPPER
"
${
fname
}
"
FNAME
)
string
(
REGEX REPLACE
"/"
"_"
FNAME
"
${
FNAME
}
"
)
if
(
HAVE_
${
FNAME
}
_H
)
# set by check_type_size already
set
(
GFLAGS_HAVE_
${
FNAME
}
_H
${
HAVE_
${
FNAME
}
_H
}
)
else
()
check_include_file_cxx
(
"
${
fname
}
.h"
GFLAGS_HAVE_
${
FNAME
}
_H
)
endif
()
endforeach
()
if
(
NOT GFLAGS_HAVE_FNMATCH_H AND WINDOWS
)
check_include_file_cxx
(
"shlwapi.h"
GFLAGS_HAVE_SHLWAPI_H
)
endif
()
bool_to_int
(
GFLAGS_HAVE_STDINT_H
)
bool_to_int
(
GFLAGS_HAVE_SYS_TYPES_H
)
bool_to_int
(
GFLAGS_HAVE_INTTYPES_H
)
if
(
MSVC
)
if
(
MSVC
)
set
(
GFLAGS_HAVE_strtoll FALSE
)
set
(
HAVE_strtoll 0
)
set
(
GFLAGS_HAVE_strtoq FALSE
)
set
(
HAVE_strtoq 0
)
else
()
else
()
foreach
(
fname IN ITEMS strtoll strtoq
)
foreach
(
fname IN ITEMS strtoll strtoq
)
string
(
TOUPPER
"
${
fname
}
"
FNAME
)
string
(
TOUPPER
"
${
fname
}
"
FNAME
)
check_cxx_symbol_exists
(
"
${
fname
}
"
stdlib.h
GFLAGS_
HAVE_
${
FNAME
}
)
check_cxx_symbol_exists
(
"
${
fname
}
"
stdlib.h HAVE_
${
FNAME
}
)
endforeach
()
endforeach
()
endif
()
endif
()
set
(
CMAKE_THREAD_PREFER_PTHREAD TRUE
)
set
(
CMAKE_THREAD_PREFER_PTHREAD TRUE
)
find_package
(
ThreadsCXX
)
find_package
(
ThreadsCXX
)
if
(
Threads_FOUND AND CMAKE_USE_PTHREADS_INIT
)
if
(
Threads_FOUND AND CMAKE_USE_PTHREADS_INIT
)
set
(
GFLAGS_HAVE_PTHREAD TRUE
)
set
(
HAVE_PTHREAD 1
)
check_type_size
(
pthread_rwlock_t RWLOCK LANGUAGE CXX
)
check_type_size
(
pthread_rwlock_t RWLOCK LANGUAGE CXX
)
if
(
HAVE_RWLOCK
)
set
(
GFLAGS_HAVE_RWLOCK TRUE
)
else
()
set
(
GFLAGS_HAVE_RWLOCK FALSE
)
endif
()
else
()
else
()
set
(
GFLAGS_HAVE_PTHREAD FALSE
)
set
(
HAVE_PTHREAD 0
)
endif
()
endif
()
if
(
UNIX AND NOT GFLAGS_HAVE_PTHREAD AND BUILD_gflags_LIB
)
if
(
UNIX AND NOT HAVE_PTHREAD AND BUILD_gflags_LIB
)
set_property
(
CACHE BUILD_gflags_LIB PROPERTY VALUE OFF
)
if
(
CMAKE_HAVE_PTHREAD_H
)
if
(
CMAKE_HAVE_PTHREAD_H
)
message
(
WARNING
"Could not find the pthread(s) library."
set
(
what
"library"
)
" Disabling the build of the multi-threaded gflags library."
)
else
()
else
()
message
(
WARNING
"Could not find the <pthread.h> header file."
set
(
what
".h file"
)
" Disabling the build of the multi-threaded gflags library."
)
endif
()
endif
()
message
(
FATAL_ERROR
"Could not find pthread
${
what
}
. Check the log file"
"
\n\t
${
CMAKE_BINARY_DIR
}${
CMAKE_FILES_DIRECTORY
}
/CMakeError.log"
"
\n
or disable the build of the multi-threaded gflags library (BUILD_gflags_LIB=OFF)."
)
endif
()
endif
()
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
...
@@ -226,7 +226,7 @@ endif ()
...
@@ -226,7 +226,7 @@ endif ()
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# installation
# installation
if
(
WIN
32
)
if
(
WIN
DOWS
)
set
(
RUNTIME_INSTALL_DIR Bin
)
set
(
RUNTIME_INSTALL_DIR Bin
)
set
(
LIBRARY_INSTALL_DIR Lib
)
set
(
LIBRARY_INSTALL_DIR Lib
)
set
(
INCLUDE_INSTALL_DIR Include
)
set
(
INCLUDE_INSTALL_DIR Include
)
...
...
src/config.h.in
View file @
8566bcf1
...
@@ -9,74 +9,40 @@
...
@@ -9,74 +9,40 @@
// System checks
// System checks
// Define if you have the <stdint.h> header file.
// Define if you have the <stdint.h> header file.
#cmakedefine
GFLAGS_
HAVE_STDINT_H
#cmakedefine HAVE_STDINT_H
// Define if you have the <sys/types.h> header file.
// Define if you have the <sys/types.h> header file.
#cmakedefine
GFLAGS_
HAVE_SYS_TYPES_H
#cmakedefine HAVE_SYS_TYPES_H
// Define if you have the <inttypes.h> header file.
// Define if you have the <inttypes.h> header file.
#cmakedefine
GFLAGS_
HAVE_INTTYPES_H
#cmakedefine HAVE_INTTYPES_H
// Define if you have the <sys/stat.h> header file.
// Define if you have the <sys/stat.h> header file.
#cmakedefine
GFLAGS_
HAVE_SYS_STAT_H
#cmakedefine HAVE_SYS_STAT_H
// Define if you have the <unistd.h> header file.
// Define if you have the <unistd.h> header file.
#cmakedefine
GFLAGS_
HAVE_UNISTD_H
#cmakedefine HAVE_UNISTD_H
// Define if you have the <fnmatch.h> header file.
// Define if you have the <fnmatch.h> header file.
#cmakedefine
GFLAGS_
HAVE_FNMATCH_H
#cmakedefine HAVE_FNMATCH_H
// Define if you have the <shlwapi.h> header file (Windows 2000/XP).
// Define if you have the <shlwapi.h> header file (Windows 2000/XP).
#cmakedefine
GFLAGS_
HAVE_SHLWAPI_H
#cmakedefine HAVE_SHLWAPI_H
// Define if you have the strtoll function.
// Define if you have the strtoll function.
#cmakedefine
GFLAGS_
HAVE_STRTOLL
#cmakedefine HAVE_STRTOLL
// Define if you have the strtoq function.
// Define if you have the strtoq function.
#cmakedefine
GFLAGS_
HAVE_STRTOQ
#cmakedefine HAVE_STRTOQ
// Define if you have the <pthread.h> header file.
// Define if you have the <pthread.h> header file.
#cmakedefine
GFLAGS_
HAVE_PTHREAD
#cmakedefine HAVE_PTHREAD
// Define if your pthread library defines the type pthread_rwlock_t
// Define if your pthread library defines the type pthread_rwlock_t
#cmakedefine GFLAGS_HAVE_RWLOCK
#cmakedefine HAVE_RWLOCK
// Backwards compatibility in case users defined these macros themselves
// or allow users to use these more general macros if the gflags library
// is build as part of a user project, e.g., included as Git submodule
#if defined(HAVE_STDINT_H) && !defined(GFLAGS_HAVE_STDINT_H)
# define GFLAGS_HAVE_STDINT_H
#endif
#if defined(HAVE_SYS_TYPES_H) && !defined(GFLAGS_HAVE_SYS_TYPES_H)
# define GFLAGS_HAVE_SYS_TYPES_H
#endif
#if defined(HAVE_INTTYPES_H) && !defined(GFLAGS_HAVE_INTTYPES_H)
# define GFLAGS_HAVE_INTTYPES_H
#endif
#if defined(HAVE_SYS_STAT_H) && !defined(GFLAGS_HAVE_SYS_STAT_H)
# define GFLAGS_HAVE_SYS_STAT_H
#endif
#if defined(HAVE_UNISTD_H) && !defined(GFLAGS_HAVE_UNISTD_H)
# define GFLAGS_HAVE_UNISTD_H
#endif
#if defined(HAVE_FNMATCH_H) && !defined(GFLAGS_HAVE_FNMATCH_H)
# define GFLAGS_HAVE_FNMATCH_H
#endif
#if defined(HAVE_STRTOLL) && !defined(GFLAGS_HAVE_STRTOLL)
# define GFLAGS_HAVE_STRTOLL
#endif
#if defined(HAVE_STRTOLQ) && !defined(GFLAGS_HAVE_STRTOLQ)
# define GFLAGS_HAVE_STRTOLQ
#endif
#if defined(HAVE_PTHREAD) && !defined(GFLAGS_HAVE_PTHREAD)
# define GFLAGS_HAVE_PTHREAD
#endif
#if defined(HAVE_RWLOCK) && !defined(GFLAGS_HAVE_RWLOCK)
# define GFLAGS_HAVE_RWLOCK
#endif
// gcc requires this to get PRId64, etc.
// gcc requires this to get PRId64, etc.
#if defined(
GFLAGS_
HAVE_INTTYPES_H) && !defined(__STDC_FORMAT_MACROS)
#if defined(HAVE_INTTYPES_H) && !defined(__STDC_FORMAT_MACROS)
# define __STDC_FORMAT_MACROS 1
# define __STDC_FORMAT_MACROS 1
#endif
#endif
...
@@ -139,9 +105,3 @@
...
@@ -139,9 +105,3 @@
# endif
# endif
# include "windows_port.h"
# include "windows_port.h"
#endif
#endif
// Export of STL class instantiations -- no extern keyword to not trigger a warning
// \sa http://support.microsoft.com/default.aspx?scid=KB;EN-US;168958
#if GFLAGS_IS_A_DLL && defined(_MSC_VER) && _MSC_VER >= 1100
# define GFLAGS_EXTERN_STL
#endif
\ No newline at end of file
src/gflags.cc
View file @
8566bcf1
...
@@ -93,9 +93,9 @@
...
@@ -93,9 +93,9 @@
#include <assert.h>
#include <assert.h>
#include <ctype.h>
#include <ctype.h>
#include <errno.h>
#include <errno.h>
#if defined(
GFLAGS_
HAVE_FNMATCH_H)
#if defined(HAVE_FNMATCH_H)
# include <fnmatch.h>
# include <fnmatch.h>
#elif defined(
GFLAGS_
HAVE_SHLWAPI_H)
#elif defined(
_MSC_VER) && defined(
HAVE_SHLWAPI_H)
# include <shlwapi.h>
# include <shlwapi.h>
# pragma comment(lib, "shlwapi.lib")
# pragma comment(lib, "shlwapi.lib")
#endif
#endif
...
@@ -1307,10 +1307,10 @@ string CommandLineFlagParser::ProcessOptionsFromStringLocked(
...
@@ -1307,10 +1307,10 @@ string CommandLineFlagParser::ProcessOptionsFromStringLocked(
// We try matching both against the full argv0 and basename(argv0)
// We try matching both against the full argv0 and basename(argv0)
if
(
glob
==
ProgramInvocationName
()
// small optimization
if
(
glob
==
ProgramInvocationName
()
// small optimization
||
glob
==
ProgramInvocationShortName
()
||
glob
==
ProgramInvocationShortName
()
#if defined(
GFLAGS_
HAVE_FNMATCH_H)
#if defined(HAVE_FNMATCH_H)
||
fnmatch
(
glob
.
c_str
(),
ProgramInvocationName
(),
FNM_PATHNAME
)
==
0
||
fnmatch
(
glob
.
c_str
(),
ProgramInvocationName
(),
FNM_PATHNAME
)
==
0
||
fnmatch
(
glob
.
c_str
(),
ProgramInvocationShortName
(),
FNM_PATHNAME
)
==
0
||
fnmatch
(
glob
.
c_str
(),
ProgramInvocationShortName
(),
FNM_PATHNAME
)
==
0
#elif defined(
GFLAGS_
HAVE_SHLWAPI_H)
#elif defined(
_MSC_VER) && defined(
HAVE_SHLWAPI_H)
||
PathMatchSpec
(
glob
.
c_str
(),
ProgramInvocationName
())
||
PathMatchSpec
(
glob
.
c_str
(),
ProgramInvocationName
())
||
PathMatchSpec
(
glob
.
c_str
(),
ProgramInvocationShortName
())
||
PathMatchSpec
(
glob
.
c_str
(),
ProgramInvocationShortName
())
#endif
#endif
...
...
src/gflags_declare.h.in
View file @
8566bcf1
...
@@ -79,11 +79,11 @@
...
@@ -79,11 +79,11 @@
// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------------
// Flag types
// Flag types
#include <string>
#include <string>
#if @
GFLAGS_
HAVE_STDINT_H@
#if @HAVE_STDINT_H@
# include <stdint.h> // the normal place uint32_t is defined
# include <stdint.h> // the normal place uint32_t is defined
#elif @
GFLAGS_
HAVE_SYS_TYPES_H@
#elif @HAVE_SYS_TYPES_H@
# include <sys/types.h> // the normal place u_int32_t is defined
# include <sys/types.h> // the normal place u_int32_t is defined
#elif @
GFLAGS_
HAVE_INTTYPES_H@
#elif @HAVE_INTTYPES_H@
# include <inttypes.h> // a third place for uint32_t or u_int32_t
# include <inttypes.h> // a third place for uint32_t or u_int32_t
#endif
#endif
...
...
src/mutex.h
View file @
8566bcf1
...
@@ -127,7 +127,7 @@
...
@@ -127,7 +127,7 @@
# endif
# endif
# include <windows.h>
# include <windows.h>
typedef
CRITICAL_SECTION
MutexType
;
typedef
CRITICAL_SECTION
MutexType
;
#elif defined(
GFLAGS_HAVE_PTHREAD) && defined(GFLAGS_
HAVE_RWLOCK)
#elif defined(
HAVE_PTHREAD) && defined(
HAVE_RWLOCK)
// Needed for pthread_rwlock_*. If it causes problems, you could take it
// Needed for pthread_rwlock_*. If it causes problems, you could take it
// out, but then you'd have to unset HAVE_RWLOCK (at least on linux -- it
// out, but then you'd have to unset HAVE_RWLOCK (at least on linux -- it
// *does* cause problems for FreeBSD, or MacOSX, but isn't needed
// *does* cause problems for FreeBSD, or MacOSX, but isn't needed
...
@@ -140,7 +140,7 @@
...
@@ -140,7 +140,7 @@
# endif
# endif
# include <pthread.h>
# include <pthread.h>
typedef
pthread_rwlock_t
MutexType
;
typedef
pthread_rwlock_t
MutexType
;
#elif defined(
GFLAGS_
HAVE_PTHREAD)
#elif defined(HAVE_PTHREAD)
# include <pthread.h>
# include <pthread.h>
typedef
pthread_mutex_t
MutexType
;
typedef
pthread_mutex_t
MutexType
;
#else
#else
...
@@ -247,7 +247,7 @@ bool Mutex::TryLock() { return is_safe_ ?
...
@@ -247,7 +247,7 @@ bool Mutex::TryLock() { return is_safe_ ?
void
Mutex
::
ReaderLock
()
{
Lock
();
}
// we don't have read-write locks
void
Mutex
::
ReaderLock
()
{
Lock
();
}
// we don't have read-write locks
void
Mutex
::
ReaderUnlock
()
{
Unlock
();
}
void
Mutex
::
ReaderUnlock
()
{
Unlock
();
}
#elif defined(
GFLAGS_HAVE_PTHREAD) && defined(GFLAGS_
HAVE_RWLOCK)
#elif defined(
HAVE_PTHREAD) && defined(
HAVE_RWLOCK)
#define SAFE_PTHREAD(fncall) do {
/* run fncall if is_safe_ is true */
\
#define SAFE_PTHREAD(fncall) do {
/* run fncall if is_safe_ is true */
\
if (is_safe_ && fncall(&mutex_) != 0) abort(); \
if (is_safe_ && fncall(&mutex_) != 0) abort(); \
...
@@ -272,7 +272,7 @@ void Mutex::ReaderLock() { SAFE_PTHREAD(pthread_rwlock_rdlock); }
...
@@ -272,7 +272,7 @@ void Mutex::ReaderLock() { SAFE_PTHREAD(pthread_rwlock_rdlock); }
void
Mutex
::
ReaderUnlock
()
{
SAFE_PTHREAD
(
pthread_rwlock_unlock
);
}
void
Mutex
::
ReaderUnlock
()
{
SAFE_PTHREAD
(
pthread_rwlock_unlock
);
}
#undef SAFE_PTHREAD
#undef SAFE_PTHREAD
#elif defined(
GFLAGS_
HAVE_PTHREAD)
#elif defined(HAVE_PTHREAD)
#define SAFE_PTHREAD(fncall) do {
/* run fncall if is_safe_ is true */
\
#define SAFE_PTHREAD(fncall) do {
/* run fncall if is_safe_ is true */
\
if (is_safe_ && fncall(&mutex_) != 0) abort(); \
if (is_safe_ && fncall(&mutex_) != 0) abort(); \
...
...
src/util.h
View file @
8566bcf1
...
@@ -38,7 +38,7 @@
...
@@ -38,7 +38,7 @@
#include <assert.h>
#include <assert.h>
#include <config.h>
#include <config.h>
#ifdef
GFLAGS_
HAVE_INTTYPES_H
#ifdef HAVE_INTTYPES_H
# include <inttypes.h>
# include <inttypes.h>
#endif
#endif
#include <stdarg.h> // for va_*
#include <stdarg.h> // for va_*
...
@@ -47,7 +47,7 @@
...
@@ -47,7 +47,7 @@
#include <iostream>
#include <iostream>
#include <string>
#include <string>
#include <errno.h>
#include <errno.h>
#ifdef
GFLAGS_
HAVE_SYS_STAT_H
#ifdef HAVE_SYS_STAT_H
# include <sys/stat.h> // for mkdir
# include <sys/stat.h> // for mkdir
#endif
#endif
...
@@ -59,10 +59,10 @@ namespace GFLAGS_NAMESPACE {
...
@@ -59,10 +59,10 @@ namespace GFLAGS_NAMESPACE {
extern
GFLAGS_DLL_DECL
void
(
*
gflags_exitfunc
)(
int
);
extern
GFLAGS_DLL_DECL
void
(
*
gflags_exitfunc
)(
int
);
// Work properly if either strtoll or strtoq is on this system
// Work properly if either strtoll or strtoq is on this system
#if defined(
GFLAGS_
HAVE_STRTOLL)
#if defined(HAVE_STRTOLL)
# define strto64 strtoll
# define strto64 strtoll
# define strtou64 strtoull
# define strtou64 strtoull
#elif defined(
GFLAGS_
HAVE_STRTOQ)
#elif defined(HAVE_STRTOQ)
# define strto64 strtoq
# define strto64 strtoq
# define strtou64 strtouq
# define strtou64 strtouq
#elif defined(_WIN32) && !defined(__MINGW32__) && !defined(__MINGW64__)
#elif defined(_WIN32) && !defined(__MINGW32__) && !defined(__MINGW64__)
...
...
test/gflags_unittest.cc
View file @
8566bcf1
...
@@ -39,7 +39,7 @@
...
@@ -39,7 +39,7 @@
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#ifdef
GFLAGS_
HAVE_UNISTD_H
#ifdef HAVE_UNISTD_H
# include <unistd.h> // for unlink()
# include <unistd.h> // for unlink()
#endif
#endif
#include <vector>
#include <vector>
...
...
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