4.1.3.6 版本控制(Revision Control)
虽然对象可能反映最终状态,但它们也可能在项目生命周期中不断被修改并反映瞬态状态。针对多用户更新同一信息的场景,存在基于支持多用户的共享存储库的本地信息副本概念。这种共享存储库通常被称为 模型服务器。模型服务器在概念上类似于文档版本控制服务器,但能够按对象识别声明的变更,而不是从文本差异中推断变更。模型服务器具有按项目进行版本控制的概念,其中每个版本由特定用户在特定时间对包含对象进行的一组变更组成。
为了支持模型服务器场景,每个对象都可以标记一个 change action(变更动作),指示自项目从服务器的特定版本序列检索以来,该对象是新增、修改、删除还是未变更。给定对象的标识符 (IFC-GUID) 和变更动作,在提交到模型服务器时可以合并对象的状态。当对象的任何直接特性发生变更、引用的资源定义(任何不继承自 IfcRoot 的实体)上的特性发生变更、集合中添加或移除项,或列表中的项被添加、移除或重新排序时,该对象即被视为已修改。
当多个用户对同一对象进行冲突性修改时,用户在提交到服务器时可以选择保留自己的变更、接受他人的变更、合并两者的变更,或采用某种组合方式。或者,为了避免此类合并场景并协调工作,可以锁定对象,使特定用户在当前时间对特定对象拥有独占的读和/或写访问权限。
项目库也可以从具有特定版本且可能与引用项目具有不同服务器 URI 的模型服务器中检索。由于项目可能包含同一项目库的多个版本(当多个用户使用他人修改的库时,这是常见场景),IfcRoot.ObjectIdentifier IFC-GUID 仅在引用项目的范围内有效,而单独的 library reference(库引用)用于标识其原始模型服务器内的基于项目库的对象。
最后,对象还可以携带信息特性,指示对象的创建时间、创建者、最后修改对象的时间和应用程序,以及当前所有者(可能根据其锁定状态拥有独占使用权)。
下图展示了应用此概念时使用的通用类和关系。
此外,概念可能对常见或标准化的行业实践和场景具有特殊意义。对于这些特定的使用场景,下表展示了用户可采用的推荐通用使用模式列表。
Figure 4.1.3.6.A
General Usage
表 4.1.3.6.B