我正在尝试从源文件中创建一个静态库。为了说明我面临的问题,请考虑以下代码段:
foo.h
:
void public_fn_exposed_to_client();
foo.cpp
:
#include "foo.h"
#include <iostream>
#define EXPORT __attribute__ ((visibility ("default")))
static void private_fn() {
std::cout << "Hello private world" << std::endl;
}
// Can't declare static as this can be used elsewhere in my lib.
// I tried to make this symbol hidden.
void internal_fn_used_inside_lib(){
std::cout << "Hello Internal Wolrd" << std::endl;
}
EXPORT
void public_fn_exposed_to_client()
{
std::cout << "Hello Outside World" << std::endl;
internal_fn_used_inside_lib();
}
main.cpp
(通常由客户编写):
#include "foo.h"
int main(int argc, char** argv)
{
// This is all good.
public_fn_exposed_to_client();
}
main2.cpp
(通常由客户编写):
#include "foo.h"
extern void internal_fn_used_inside_lib();
int main(int argc, char** argv)
{
// Ideally, This should not be allowed
internal_fn_used_inside_lib();
}
汇编:
g++ -o foo.o foo.c -fvisibility=hidden
ar rcs libfoo.a foo.o
ranlib libfoo.a
g++ -o main1 main.cpp -L. -lfoo
g++ -o main2 main2.cpp -L. -lfoo
我想实现main2没有编译/链接的情况。这是为了阻止我的库的客户端使用未作为API公开的低级函数。
特别是,如何处理无法声明为静态的函数?
我尝试过的事情:
如this中所述,我尝试将objcopy与localize隐藏标志一起使用,但没有什么能阻止客户端再次全局化它吗?
导出地图 - 我不知道如何使用静态存档。相反,我根本不知道它们是否适用。
答案 0 :(得分:1)
不可能。可以将静态库视为所有未链接对象文件的单个文件存档。因此,可见的是链接目标文件的内容从整个静态库中可见。
“隐藏”事物的唯一方法是不提供头文件,但没有什么能阻止用户自己重新创建这些头文件。