I use the issue in this blog to demonstrate the usage of this small repository parse tool: We need to know under which enhancement set the component usage “ZCUSTOM” is added to UI component BT116H_SRVO.
This customizing activity could allow us to compare the runtime repository between the original UI component and the enhanced one:
However, if there are too many enhancement sets in the system, it could be very inefficient for manual comparison.
Fortunately the comparison could be done by code below.
The report is quite simple: (1) in line 9, get all enhancement sets list under which the UI component is enhanced. (2) get the enhanced BSP application name and page name in line 11 and 12, then get the component usage information for each enhanced BSP application via repository tool, then filter it by usage name “ZCUSTOM”.
REPORT zbsp.
CONSTANTS: cv_host TYPE o2applname VALUE 'BT116H_SRVO'.
DATA: lt_enh_sets TYPE bsp_dlct_ehset,
ls_enh_set LIKE LINE OF lt_enh_sets,
lt_extension TYPE STANDARD TABLE OF bspwd_comp_ext,
ls_extension LIKE LINE OF lt_extension,
lt_usages TYPE bsp_wd_cmp_usage_descr_tab,
ls_usage LIKE LINE OF lt_usages.
lt_enh_sets = cl_bsp_dlc_config_util=>get_eh_sets_of_comp( iv_comp_name = cv_host ).
CHECK lt_enh_sets IS NOT INITIAL.
SELECT * INTO TABLE lt_extension FROM bspwd_comp_ext FOR ALL ENTRIES IN lt_enh_sets WHERE
enhancement_set = lt_enh_sets-enhancement_set AND comp_name = cv_host.
LOOP AT lt_enh_sets INTO ls_enh_set.
READ TABLE lt_extension INTO ls_extension WITH KEY enhancement_set = ls_enh_set-enhancement_set comp_name = cv_host.
IF sy-subrc = 0.
CLEAR: lt_usages.
CALL METHOD zcl_view_repo_tool=>get_repo_metadata(
EXPORTING
iv_comp_name = ls_extension-bsp_appl
iv_page_name = ls_extension-rt_rep_page
IMPORTING
et_usages = lt_usages ).
READ TABLE lt_usages WITH KEY usage_name = 'ZCUSTOM' INTO ls_usage.
IF sy-subrc = 0.
WRITE: / 'EnhancementSet: ', ls_enh_set-enhancement_set,
' defines component usage to component: ', ls_usage-child_cmp_type.
ENDIF.
ENDIF.
ENDLOOP.
The small parse tool zcl_view_repo_tool just parse the repository xml from database table and convert it to two internal tables which contains the view information and component usage information. Its source code could be found in attachment.
We can compare the report execution result and the manual check via customizing activity: they are exactly the same.
Update on 2017-06-02 14:45PM
It seems the source code in attachment is lost after SCN is migrated to SAP community. Please use the following report instead:
REPORT tool_bsp_metadata.
PARAMETERS: name TYPE o2applname DEFAULT 'SMCHS'.
TYPES ltype_viewline TYPE cl_bsp_wd_rep_view=>gtype_viewline .
TYPES:
BEGIN OF gtype_op_mapping,
name TYPE string,
op_plug TYPE string,
switch_id TYPE sfw_switch_id,
reaction TYPE sfw_showhide,
END OF gtype_op_mapping .
TYPES:
BEGIN OF gtype_ip_follow_up,
name TYPE string,
navlink TYPE string,
switch_id TYPE sfw_switch_id,
reaction TYPE sfw_showhide,
END OF gtype_ip_follow_up .
TYPES:
BEGIN OF gtype_navlink,
name TYPE string,
targets_done TYPE flag,
targets TYPE tbsp_wd_rep_navigation_targets,
sfw_data TYPE bsp_wd_sfw_data BOXED,
END OF gtype_navlink .
TYPES:
BEGIN OF gtype_viewline,
view TYPE string,
active TYPE abap_bool,
view_id TYPE n LENGTH 4,
parent_viewset TYPE string,
parent_viewarea TYPE string,
parent TYPE REF TO cl_bsp_wd_rep_view,
initials TYPE tbsp_wd_rep_viewarea_assigns,
initials_done TYPE abap_bool,
navlinks TYPE SORTED TABLE OF gtype_navlink
WITH NON-UNIQUE KEY name
INITIAL SIZE 0,
rep_view TYPE REF TO cl_bsp_wd_rep_view,
is_window TYPE abap_bool,
is_intf_view TYPE abap_bool,
is_default_window TYPE abap_bool,
ip_follow_ups TYPE HASHED TABLE OF gtype_ip_follow_up
WITH UNIQUE KEY name
INITIAL SIZE 0,
op_mappings TYPE HASHED TABLE OF gtype_op_mapping
WITH UNIQUE KEY name
INITIAL SIZE 0,
sfw_data TYPE bsp_wd_sfw_data BOXED,
END OF gtype_viewline .
TYPES:
ltype_view_tab TYPE HASHED TABLE OF ltype_viewline
WITH UNIQUE KEY view active
INITIAL SIZE 0 .
DATA: lv_loader TYPE REF TO cl_bsp_wd_stream_loader,
lv_xml TYPE string,
lv_root TYPE string.
CREATE OBJECT lv_loader.
lv_xml = lv_loader->load_from_bsp_page( iv_bsp_appl = name
iv_bsp_page = 'Repository.xml' ). "#EC NOTEXT
DATA: lt_views TYPE ltype_view_tab,
lt_usages TYPE bsp_wd_cmp_usage_descr_tab,
result TYPE REF TO cl_bsp_wd_repository.
* "parse" repository xml data directly into memory
CALL TRANSFORMATION bsp_wd_rt_rep_runtime
SOURCE XML lv_xml
RESULT views = lt_views
rootview = lv_root
usages = lt_usages.
BREAK-POINT.
要获取更多Jerry的原创文章,请关注公众号"汪子熙":
相关推荐
CRM7.0 WebClient UI config
这是cross component navigation在起作用。 Result list是model在ICQR里面,如果点service,会navigate到service detail page,这个service detail page是做在PRD02OV上,所以这个navigation是cross component ...
Sent: Thursday, May 9, 2013 6:30 PM Subject: ON_NEW_FOCUS的用途 ROOT ———————————— Product ID PRODshortText ———————————— Product Description Genil Model hierarchy
UI Guidelines for CRM WebClient User Interface
C# WebClient 上传文件 WebClient上传文件至服务器
WebClient方式上传数据到服务器下
WebClient jar包
C# WebClient实现文件下载 示例源码
webui学习者
SilverLight 学习笔记 使用WebClient实现通讯 二 上传和下载流数据
WebClient上传下载源码 我们先在IIS网站中建立一个文件夹,此处为"Mp3",并设置此文件夹相关读写权限。 例1:使用WebClient中的UploadFile方法上传文件。代码如下。使用此方法需要将上传的文件夹权限设置为 IIS来宾...
主要介绍了C#中在WebClient中使用post发送数据实现方法,需要的朋友可以参考下
本篇文章主要介绍了C#中WebClient实现文件下载,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
c#中的WebClient的用法,模拟请求
使用WebClient的UploadFileAsync、UploadFile、DownloadFile、DownloadFileAsync方法,异步调用服务器上传下载数据。
支持 Session 和 Cookie 的 WebClient
WebClient下载文件展示进度条
基于webClient 的ftp操作,该案例是基于http模式,如果是ftp,直接将http改成ftp即可
webClient 服务器端与客户端配置