在Enterprise Architect

时间:2015-06-09 07:24:03

标签: c# enterprise-architect

我正在尝试使用C#脚本来重新创建Enterprise Architects功能。我成功扫描了每个包,并查看其版本是否使用以下代码进行控制:

Collection models = eaRepository.Models;

foreach (Package package in models) {
    resolveRecursivelyGetLatestOnPackage(package);
}

eaRepository.ScanXMIAndReconcile();

Console.WriteLine("GetLatestFinished.");

private void resolveRecursivelyGetLatestOnPackage(Package package)
{
    if (package.IsVersionControlled) {
        package.VersionControlGetLatest(false);
    }

    foreach (Package childPackage in package.Packages) {
            resolveRecursivelyGetLatestOnPackage(childPackage);
    }
}

然而,我使用它的EAP模型非常大,并且上层代码需要花费大量时间,因为它扫描所有包。因此,我试图通过使用Select语句获取所有版本的受控软件包。

SELECT * 
FROM t_package 
WHERE IsControlled = True 

可悲的是,我发现无法在EA的自动化界面中收到包的集合。

到目前为止我尝试过:

eArepository.GetElementSet ("SELECT * FROM t_package WHERE IsControlled = True", false);

eArepository.SQLQuery ("SELECT * FROM t_package WHERE IsControlled = True");

getElementSet会返回一个空集合,因为它不是我要搜索的元素。

SQL查询似乎返回了我想要的内容,但格式错误。我不知道如何从它返回的XML中获取包。有没有办法做到这一点?

如何快速获得所有版本控制的软件包的集合?

1 个答案:

答案 0 :(得分:0)

您应该只使用查询查询包ID,然后使用Repository.GetPackageByID()获取EA.Package对象。

然后查询变为

"SELECT Package_ID FROM t_package WHERE IsControlled = True"

您可以使用Enterprise Architect Addin Framework

中与此操作类似的操作
/// <summary>
/// returns the elementwrappers that are identified by the Object_ID's returned by the given query
/// </summary>
/// <param name="sqlQuery">query returning the Object_ID's</param>
/// <returns>elementwrappers returned by the query</returns>
public List<ElementWrapper> getElementWrappersByQuery(string sqlQuery)
{
  // get the nodes with the name "ObjectID"
  XmlDocument xmlObjectIDs = this.SQLQuery(sqlQuery);
  XmlNodeList objectIDNodes = xmlObjectIDs.SelectNodes(formatXPath("//Object_ID"));
  List<ElementWrapper> elements = new List<ElementWrapper>();

  foreach( XmlNode objectIDNode in objectIDNodes ) 
  {
    ElementWrapper element = this.getElementWrapperByID(int.Parse(objectIDNode.InnerText));
    if (element != null)
    {
        elements.Add(element);
    }
  }
  return elements;
}