我正在通过带注释的 Java 代码使用 EMF,如下所示
/**
* Adds the given type to this filter. Has no effect if the given type
* already belongs to this filter.
*
* @param type
* the type to add
* @model
*/
public void addEntityType(String type);
/**
* Returns the list of types belonging to this filter. Types are identified
* by there name.
*
* @return the list of types for this entity type filter
*
* @model
*/
public List<String> getEntityTypes();
/**
* Removes the given type from this filter. Has no effect if the given type
* doesn't belong to this filter.
*
* @param type
* the type to remove
* @model
*/
public void removeEntityType(String type);
Run Code Online (Sandbox Code Playgroud)
从这个带注释的接口创建 ecore 和 genmodel 文件后,在生成代码后, getEntityTypes 方法修改如下:
public EList<String> getEntityTypes();
Run Code Online (Sandbox Code Playgroud)
出于封装的目的,我希望这个 EList 是不可修改的,因此接口客户端的代码只能通过添加和删除方法来修改列表。
有什么干净的方法可以做到这一点,即修改 Java 注释或 genmodel 文件以告诉生成器生成返回不可修改列表的代码?(谷歌搜索后我无法找到......)
你如何处理这种情况?
提前致谢
摩奴
您需要将生成的“Impl”类修改为如下所示:
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
private EList<String> getEntityTypesGen() {
if (entityTypes == null) {
entityTypes = new EDataTypeUniqueEList<String>(String.class,
this, NsPackage.THINGY__ENTITY_TYPES);
}
return entityTypes;
}
public EList<String> getEntityTypes() {
return ECollections.unmodifiableEList(getEntityTypesGen());
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void addEntityType(String type) {
getEntityTypesGen().add(type);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
public void removeEntityType(String type) {
getEntityTypesGen().remove(type);
}
Run Code Online (Sandbox Code Playgroud)
请注意,我已完成以下操作:
不过,就我个人而言,我不推荐这种方法。EMF 通常返回多值引用的可修改列表,客户端应该修改这些列表以添加或删除项目。EMF 将根据需要懒惰地创建一个空列表,因此它提供了一个更清晰的界面(不需要添加/删除方法)和一个很好的 API(用户可以在指尖获得列表 API 的全部功能,而不仅仅是添加/删除您提供的)。
归档时间: |
|
查看次数: |
1245 次 |
最近记录: |