在使用cocoapods进行组件管理,编译xcode工程时,可能会遇到以下错误:python
Argument list too long: recursive header expansion failed at /Users/liusilan/Documents/workspace/douyu/project/PlayerRoom/Demo/xx/xx.
复制代码
这个问题从字面上看起来的缘由是参数列表太长,在递归展开的时候失败
。经过排查,发现咱们工程出现的缘由是由于搜索路径范围太大($(PODS_ROOT)/**
),编译时会遍历搜索范围内的全部目录。这时候当工程根目录的层级比较深时,Pods里面的层级也比较多时,致使路径太长,超出范围。xcode
好比个人工程目录是/Users/liusilan/Documents/workspace/douyu/project/PlayerRoom/Demo
,pods的层级Pods/VideoComponent/VideoComponent/Classes/Business/Video
,而Video
下面还有几级子目录,这样链接起来就会致使路径很是的长。bash
Pods-xx.debug.xcconfig
文件,搜索LIBRARY_SEARCH_PATHS
或者FRAMEWORK_SEARCH_PATHS
是否包含"$(PODS_ROOT)/**"
。正是由于**
,致使搜索范围过大。通常出现这种搜索路径,是因为在podspec
里面指定search_path
时图方便,写的不规范。好比:ide
s.xcconfig = {
"LIBRARY_SEARCH_PATHS" => "\"$(PODS_ROOT)/**\""
}
复制代码
比较好的作法是指定具体的路径,如sdk/libs/*.a
,这样会极大的减小搜索范围。ui
那么,如何查找哪些podspec有问题呢?对于大型项目,组件上百个,手动去查找显得费时费力。spa
可经过脚本,扫描~/.cocoapods/repos/xx
,xx表明要扫描的spec仓库,而后逐个读取podspec文件,搜索"$(PODS_ROOT)/**
,若是搜索到了,则记录下来。最后将结果打印,能够看到哪些podspec有问题,而后再逐个修改。debug
简单列一下python
代码:code
PODS_ROOT_result = set('')
def list(rootDir):
for lists in os.listdir(rootDir):
path = os.path.join(rootDir, lists)
if os.path.isdir(path):
list(path)
else:
file_extension = os.path.splitext(path)[1]
if file_extension == '.podspec':
file_object = open(path, 'r')
try:
all_the_text = file_object.read()
basename=os.path.basename(path)
(filename,extension) = os.path.splitext(basename)
if all_the_text.find("$(PODS_ROOT)/**") != -1:
print "PODS_ROOT:"+filename
PODS_ROOT_result.add(filename)
result.add(filename)
finally:
file_object.close()
复制代码
不过,可能其余同窗的podspec里不是这样写的"$(PODS_ROOT)/**"
,那么能够改为搜索**
之类的,主要核心思想就是排查搜索路径是否过大。递归