目前我的项目中有 3 个嵌入式框架:
PersistenceLayer(仅限 Swift)TransportLayer(仅限 Swift)套接字(对象)PersistenceLayer 和Socket 都没有引用它们之外的任何东西。但是 TransportLayer 导入 PersistenceLayer 和 Socket。奇怪的是,我可以在导入后使用 PersistenceLayer 对象:
import PersistenceLayer
struct User : Model {
...
}
Model 在 PersistenceLayer 中定义,Xcode 让我可以正常使用它。但是,当我尝试构建 TransportLayer 时,出现错误:No such Modul 'Persistencelayer'。所以 Xcode 识别出模块在那里,但在构建时以某种方式“松开”了它。
令人抓狂的是这曾经有效。在某些时候发生了一些变化,我无法弄清楚是什么。重要的是要注意,我与多个开发人员一起处理一个项目,并且我在更改中合并。但是,在合并之前切换到提交是行不通的。我也试过:
$(SRCROOT)(递归)添加到框架搜索路径ModuleCache 目录中的所有内容我怀疑我的项目设置发生了某些变化,但我无法弄清楚是什么,而且我检查了 git diffs 没有帮助(除了正常的文件添加之外,项目中没有任何真正改变。
此外,TransportLayer 确实成功导入并使用了 Socket。如果我删除对 PersistenceLayer 的引用但保留对 Socket 的所有引用,我可以构建 TransportLayer。
有谁知道为什么会发生这种情况或如何解决?
好的,所以我从目标中删除了“有问题的”文件以确保 Socket 正在工作(它是),然后将文件重新添加到目标(从字面上看是通过重置 git) .它现在建立......因为这是有道理的。但我尝试将 Scheme 从 iOS Device 更改为模拟器,它不再构建,但我遇到了不同的错误:
HeaderPersistenceLayer-Swift.h' not found`无法构建 Objective-C 模块“持久层”这感觉就像我在追逐随机错误......
最佳答案
我找到了答案:在 TransportLayer 目标中打开 Build Phases 并手动添加 PersistenceLayer 和 Socket 到目标依赖项。这确保了 TransportLayer 所依赖的任何东西都将在它之前被构建。
我有一种预感,iOS Device 方案起作用的最初原因是因为我删除了有问题的文件,允许所有内容正确构建,包括被缓存的 PersistenceLayer .将导入添加回项目后,它继续工作,因为不再需要构建 PersistenceLayer。其他方案不起作用,因为 PersistenceLayer 不是为这些架构构建的。我通过再次清理确认了这一点,但构建失败了。经过一番搜索后,我找到了 Target Dependencies 并在那里添加了我的两个依赖项。现在一切都可以在所有方案和所有架构中正确构建。
我的项目可能到目前为止一直运行良好,因为它正在使用在我实际使用它们之前构建的缓存框架:(我在开始处理 TransportLayer 之前构建了 )。我可能最近某个时候清理了项目,删除了缓存的框架并导致了问题。 PersistenceLayer
关于ios - Xcode: "No such module"嵌入式框架,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31435891/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
我正在尝试解析一个文本文件,该文件每行包含可变数量的单词和数字,如下所示:foo4.500bar3.001.33foobar如何读取由空格而不是换行符分隔的文件?有什么方法可以设置File("file.txt").foreach方法以使用空格而不是换行符作为分隔符? 最佳答案 接受的答案将slurp文件,这可能是大文本文件的问题。更好的解决方案是IO.foreach.它是惯用的,将按字符流式传输文件:File.foreach(filename,""){|string|putsstring}包含“thisisanexample”结果的