内容简介:在使用cocoapods进行组件管理,编译xcode工程时,可能会遇到如下错误:这个问题从字面上看起来的原因是比如我的工程目录是
在使用cocoapods进行组件管理,编译xcode工程时,可能会遇到如下错误:
Argument list too long: recursive header expansion failed at /Users/liusilan/Documents/workspace/douyu/project/PlayerRoom/Demo/xx/xx. 复制代码
这个问题从字面上看起来的原因是 参数列表太长,在递归展开的时候失败
。通过排查,发现我们工程出现的原因是因为搜索路径范围太大( $(PODS_ROOT)/**
),编译时会遍历搜索范围内的所有目录。这时候当工程根目录的层级比较深时,Pods里面的层级也比较多时,导致路径太长,超出范围。
比如我的工程目录是 /Users/liusilan/Documents/workspace/douyu/project/PlayerRoom/Demo
,pods的层级 Pods/VideoComponent/VideoComponent/Classes/Business/Video
,而 Video
下面还有几级子目录,这样连接起来就会导致路径非常的长。
解决方案
- 将工程移到目录结构比较浅的地方,比如移到上上级文件夹,减少层级。(临时方案,不能解决根本问题,不建议)
-
如果是debug,则查看
Pods-xx.debug.xcconfig
文件,搜索LIBRARY_SEARCH_PATHS
或者FRAMEWORK_SEARCH_PATHS
是否包含"$(PODS_ROOT)/**"
。正是因为**
,导致搜索范围过大。
一般出现这种搜索路径,是由于在 podspec
里面指定 search_path
时图方便,写的不规范。比如:
s.xcconfig = { "LIBRARY_SEARCH_PATHS" => "\"$(PODS_ROOT)/**\"" } 复制代码
比较好的做法是指定具体的路径,如 sdk/libs/*.a
,这样会极大的减少搜索范围。
如何排查
那么,如何查找哪些podspec有问题呢?对于大型项目,组件上百个,手动去查找显得费时费力。
可通过脚本,扫描 ~/.cocoapods/repos/xx
,xx代表要扫描的spec仓库,然后逐个读取podspec文件,搜索 "$(PODS_ROOT)/**
,如果搜索到了,则记录下来。最后将结果打印,可以看到哪些podspec有问题,然后再逐个修改。
简单列一下 python
代码:
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)/**"
,那么可以改成搜索 **
之类的,主要核心思想就是排查搜索路径是否过大。
以上所述就是小编给大家介绍的《关于Argument list too long的问题》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- acme.sh 续期问题(路径问题)
- 缓存的一些问题和一些加密算法【缓存问题】
- 如何把设计问题转化为数学问题(方法论)
- 推荐系统中的冷启动问题和探索利用问题
- GraphQL 教程(六)—— N+1问题和缓存等问题
- Golang 并发问题(四)之单核上的并发问题
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C语言算法速查手册
程晓旭、耿鲁静、张海、王勇 / 2009-10 / 49.00元
《C语言算法速查手册》用C语言编写了科研和工程中最常用的166个算法,这些算法包括复数运算、多项式的计算、矩阵运算、线性代数方程组的求解、非线性方程与方程组的求解、代数插值法、数值积分法、常微分方程(组)初值问题的求解、拟合与逼近、特殊函数、极值问题、随机数产生与统计描述、查找、排序、数学变换与滤波等。同时结合这些算法列举了将近100个应用实例,对其进行验证和分析。 《C语言算法速查手册》适......一起来看看 《C语言算法速查手册》 这本书的介绍吧!