我正在尝试使用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中获取包。有没有办法做到这一点?
如何快速获得所有版本控制的软件包的集合?
答案 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;
}