我在 Delphi XE2 版本 16.0.4429.46931 中有一个组件包,同时是运行时和设计时包。这个包已经存在一年多了,文件/文件夹结构一直都是一样的。我将所有单元保存在根目录的专用Source
文件夹中,并将实际包保存在Packages
同一根目录的文件夹中。因此,可以在 中找到包,在 中找到\Root\Packages\
单元\Root\Source\
。
今天,在构建运行时包之后,我正在查看提示和警告。其中一个警告是:
[DCC Warning] Inno.TimeChart.pas(1): W1025 Unsupported language feature: 'class constructor'
警告本身并不是我担心的。问题是当我双击此警告时,我从 IDE 收到一条错误消息:
我立即注意到的一件事是它不是在Source
文件夹中查找,而是直接在文件夹中查找Packages
。不知何故,IDE 期望该单元与包位于同一位置。自从我一年多前创建包以来,我从未更改过任何库路径、文件位置或包的结构。
该文件确实存在,但位于与看起来不同的位置。该文件从未与项目一起保存在文件夹中,事实上,除了包项目本身之外,没有其他任何东西保存在该Packages
文件夹中。这一切都驻留在Source
文件夹中,但 IDE 似乎不这么认为。
为什么 IDE 会认为该文件位于不同的文件夹中?当我双击它们时,与同一单元相关的所有其他提示和警告都可以正常工作,但不是这个。
编辑
我创建了一个新的测试包来解决这个问题。
Root\TestPackage.dpr
Root\Source\TestPackageUnit.pas
导致此编译器警告的特定代码在此类中:
type
TMyComponent = class(TComponent)
strict private
class constructor Create;
end;
当我使用 Process Monitor 进行编译时,我看到 IDE 正在 30 多个不同的地方搜索这个文件(当然失败了),它看起来像是在每个库路径中搜索,而不是在包所说的那个地方。
我尝试过的事情
DPR
已验证和DPROJ
文件之间的这些路径之间没有区别- 安装了所有最新的更新和 IDE FixPack(实际上给了我新的问题)
- 使用 Process Monitor 监控文件的访问
- 过滤器:进程名称等于
BDS.exe
;路径以TestPackageUnit.pas
- 结果:“未找到名称”-> 所需访问:通用读取处置:打开选项:同步 IO 非警报、非目录文件属性:N 共享模式:读取、写入分配大小:n/a
- 过滤器:进程名称等于
- 尝试使用仅设计时、仅运行时和设计时/运行时组合
- 尝试使用已注册和未注册的组件
- 尝试使用库路径中的目录而不是库路径中的目录
- 从库路径中删除了大约 20 个不必要的条目以使其更短
- 将目录移动到库路径的顶部
- 已验证没有
DOF
与项目关联的文件(我认为来自旧版本) - 重启IDE和电脑的次数
- 从项目中清理已编译和临时文件,包括 BPL 和 DCU 文件
- 改为
strict private
公正private
和均匀public