ar on an existing .a file?

前端 未结 2 1997
醉话见心
醉话见心 2021-01-20 17:52

Essentially, what I want to do is this:

gcc foo.c -o foo.o
ar rcs foo.a foo.o
gcc bar.c -o boo.o
ar rcs bar.a bar.o foo.a

I want to archive

2条回答
  •  感情败类
    2021-01-20 18:34

    Actually, you do not want to archive one whole '.a' file inside another. You might want to archive the members of the one archive in the other - but that is a wholly different operation.

    The 'ar' program is perfectly capable of storing source files, gzipped tar files, HTML files, XML files, and pretty much any other type of file in the '.a' (and the '.a' suffix is only conventional, not mandatory) -- try it some time. However, it treats object files (and only object files) specially, and makes them available for use by the linker ('ld'), but the linker only uses such files if the extension is '.a'.

    So, you want to have two libraries:

    1. foo.a containing just foo.o
    2. bar.a containing bar.o and all the objects from foo.a

    Short of doing as you suggest and extracting the objects from foo.a and building them into bar.a, the only alternative is to list the members of foo.a as members of bar.a too:

    FOO_OBJS = foo.o
    BAR_OBJS = bar.o $(FOO_OBJS)
    
    foo.a: $(FOO_OBJS)
        $(AR) $(ARFLAGS) $@ $(FOO_OBJS)
    bar.a: $(BAR_OBJS)
        $(AR) $(ARFLAGS) $@ $(BAR_OBJS)
    

    I am assuming that your example is minimized. If it is not, then why bother with two libraries. Anything that uses just code from foo.o will only link foo.o even if given bar.a to link with. (It would be slightly different if these were shared objects, but it would probably still be better to use just one rather than two shared objects.)

自定义标题
段落格式
字体
字号
代码语言
提交回复
热议问题