複数のファイルを含むプロジェクトに取り組んでおり、それぞれにログインする必要があります。
ファイルをコンパイルするには、次のものが必要です。
/* Define the stock front-end process identity, so that it links when using
* fe.N, fe.simple, etc. */
PANTHEIOS_EXTERN_C const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("fileX.cpp");
たとえば、両方のファイルに共通の log1.cpp と log2.cpp と log.h があるとします。これらのファイルは、log1.o および log2.o にコンパイルされます。それはうまくいきます。
ここで、これら 2 つのファイルを 1 つの実行可能ファイルにリンクすると、次のエラーが発生します。
log2.o:(.rodata+0x11): multiple definition of `PANTHEIOS_FE_PROCESS_IDENTITY'
log1.o:(.rodata+0x45): first defined here
問題は、コンパイルするために PANTHEIOS_FE_PROCESS_IDENTITY を file1.cpp と file2.cpp の両方で定義する必要があることです。
コードを実行可能ファイルにリンクできるようにするには、コードをどのように変更する必要がありますか?
使用されるファイルは次のとおりです: log1.cpp:
#include "log.h"
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("log1.cpp");
int main()
{
PANTHEIOS_TRACE_NOTICE(PSTR("a string at NOTICE level"));
return 0;
}
log2.cpp:
#include "log.h"
const PAN_CHAR_T PANTHEIOS_FE_PROCESS_IDENTITY[] = PSTR("log1.cpp");
log.h:
#ifndef LOG_H
#define LOG_H
/* Pantheios Header Files */
#include <pantheios/pantheios.h> // Pantheios C main header
#ifndef STLSOFT_CF_SUPPORTS_VARIADIC_MACROS
# error This example uses the Tracing API, which requires that the compiler support variadic macros
#endif /* !STLSOFT_CF_SUPPORTS_VARIADIC_MACROS */
#ifdef STLSOFT_CF_FUNCTION_SYMBOL_SUPPORT
# include <string>
# define PANTHEIOS_TRACE_PREFIX \
( std::basic_string< PANTHEIOS_NS_QUAL(pan_char_t)>(__FILE__ " " PANTHEIOS_STRINGIZE(__LINE__) ": ") + \
__FUNCTION__ + \
"(): " \
).c_str()
#endif /* STLSOFT_CF_FUNCTION_SYMBOL_SUPPORT */
#include <pantheios/trace.h> // Pantheios Trace API
#include <pantheios/pantheios.hpp> // Pantheios C++ main header
/* Standard C/C++ Header Files */
#include <exception> // for std::exception
#include <new> // for std::bad_alloc
#include <string> // for std::string
#include <stdlib.h> // for exit codes
#ifndef PANTHEIOS_DOCUMENTATION_SKIP_SECTION
# if defined(STLSOFT_COMPILER_IS_MSVC)
# pragma warning(disable : 4702)
# endif /* compiler */
#endif /* !PANTHEIOS_DOCUMENTATION_SKIP_SECTION */
#define PSTR(x) PANTHEIOS_LITERAL_STRING(x)
#include "pantheios/frontends/fe.simple.h" //for pantheios_fe_simple_setSeverityCeiling(level);
#endif //LOG_H
そしてmakeの出力:
g++ log1.cpp -c -I../pantheios-1.0.1-beta213/include -I../stlsoft-1.9.112/include
g++ log2.cpp -c -I../pantheios-1.0.1-beta213/include -I../stlsoft-1.9.112/include
g++ -o log log1.o log2.o -L../pantheios-1.0.1-beta213/lib \
-lpantheios.1.core.gcc44\
-lpantheios.1.be.fprintf.gcc44 -lpantheios.1.bec.fprintf.gcc44\
-lpantheios.1.fe.simple.gcc44 -lpantheios.1.util.gcc44
log2.o:(.rodata+0x0): multiple definition of `PANTHEIOS_FE_PROCESS_IDENTITY'
log1.o:(.rodata+0x1): first defined here
/usr/bin/ld: Warning: size of symbol `PANTHEIOS_FE_PROCESS_IDENTITY' changed from 14 in log1.o to 9 in log2.o
collect2: ld returned 1 exit status
編集: pantheios-1.0.1-beta213/include/pantheios/frontends/stock.h:120 で 'PANTHEIOS_FE_PROCESS_IDENTITY' が extern として宣言されているため、静的として再定義できません。