mirror of
https://github.com/abapGit/abapGit.git
synced 2025-05-02 04:36:49 +08:00
Merge pull request #547 from larshp/issue542
ENHO: wdyconf serialization #542
This commit is contained in:
commit
4663ef734c
|
@ -18,6 +18,109 @@ INTERFACE lif_object_enho.
|
||||||
|
|
||||||
ENDINTERFACE.
|
ENDINTERFACE.
|
||||||
|
|
||||||
|
CLASS lcl_object_enho_wdyconf DEFINITION.
|
||||||
|
|
||||||
|
PUBLIC SECTION.
|
||||||
|
METHODS: constructor
|
||||||
|
IMPORTING
|
||||||
|
is_item TYPE ty_item
|
||||||
|
io_files TYPE REF TO lcl_objects_files.
|
||||||
|
INTERFACES: lif_object_enho.
|
||||||
|
|
||||||
|
PRIVATE SECTION.
|
||||||
|
DATA: ms_item TYPE ty_item,
|
||||||
|
mo_files TYPE REF TO lcl_objects_files.
|
||||||
|
|
||||||
|
ENDCLASS.
|
||||||
|
|
||||||
|
CLASS lcl_object_enho_wdyconf IMPLEMENTATION.
|
||||||
|
|
||||||
|
METHOD constructor.
|
||||||
|
ms_item = is_item.
|
||||||
|
mo_files = io_files.
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
METHOD lif_object_enho~deserialize.
|
||||||
|
|
||||||
|
DATA: lv_enhname TYPE enhname,
|
||||||
|
lo_wdyconf TYPE REF TO cl_wdr_cfg_enhancement,
|
||||||
|
li_tool TYPE REF TO if_enh_tool,
|
||||||
|
ls_obj TYPE wdy_config_key,
|
||||||
|
lv_package TYPE devclass.
|
||||||
|
|
||||||
|
|
||||||
|
io_xml->read( EXPORTING iv_name = 'ORIGINAL_OBJECT'
|
||||||
|
CHANGING cg_data = ls_obj ).
|
||||||
|
|
||||||
|
lv_enhname = ms_item-obj_name.
|
||||||
|
lv_package = iv_package.
|
||||||
|
TRY.
|
||||||
|
cl_enh_factory=>create_enhancement(
|
||||||
|
EXPORTING
|
||||||
|
enhname = lv_enhname
|
||||||
|
enhtype = ''
|
||||||
|
enhtooltype = cl_wdr_cfg_enhancement=>tooltype
|
||||||
|
IMPORTING
|
||||||
|
enhancement = li_tool
|
||||||
|
CHANGING
|
||||||
|
devclass = lv_package ).
|
||||||
|
lo_wdyconf ?= li_tool.
|
||||||
|
|
||||||
|
* todo
|
||||||
|
* io_xml->read_xml()
|
||||||
|
* CL_WDR_CFG_PERSISTENCE_UTILS=>COMP_XML_TO_TABLES( )
|
||||||
|
* lo_wdyconf->set_enhancement_data( )
|
||||||
|
ASSERT 0 = 1.
|
||||||
|
|
||||||
|
lo_wdyconf->if_enh_object~save( ).
|
||||||
|
lo_wdyconf->if_enh_object~unlock( ).
|
||||||
|
CATCH cx_enh_root.
|
||||||
|
lcx_exception=>raise( 'error deserializing ENHO wdyconf' ).
|
||||||
|
ENDTRY.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
METHOD lif_object_enho~serialize.
|
||||||
|
|
||||||
|
DATA: lo_wdyconf TYPE REF TO cl_wdr_cfg_enhancement,
|
||||||
|
lt_data TYPE wdy_cfg_expl_data_tab,
|
||||||
|
ls_outline TYPE wdy_cfg_outline_data,
|
||||||
|
ls_obj TYPE wdy_config_key,
|
||||||
|
li_document TYPE REF TO if_ixml_document,
|
||||||
|
li_element TYPE REF TO if_ixml_element.
|
||||||
|
|
||||||
|
|
||||||
|
lo_wdyconf ?= ii_enh_tool.
|
||||||
|
|
||||||
|
ls_obj = lo_wdyconf->get_original_object( ).
|
||||||
|
io_xml->add( iv_name = 'TOOL'
|
||||||
|
ig_data = ii_enh_tool->get_tool( ) ).
|
||||||
|
io_xml->add( iv_name = 'ORIGINAL_OBJECT'
|
||||||
|
ig_data = ls_obj ).
|
||||||
|
|
||||||
|
lo_wdyconf->get_enhancement_data(
|
||||||
|
EXPORTING
|
||||||
|
p_scope = 1
|
||||||
|
IMPORTING
|
||||||
|
p_enh_data = lt_data ).
|
||||||
|
|
||||||
|
cl_wdr_cfg_persistence_utils=>comp_tables_to_xml(
|
||||||
|
EXPORTING
|
||||||
|
outline_data = ls_outline
|
||||||
|
expl_data_tab = lt_data
|
||||||
|
IMPORTING
|
||||||
|
element = li_element
|
||||||
|
CHANGING
|
||||||
|
document = li_document ).
|
||||||
|
|
||||||
|
io_xml->add_xml( iv_name = 'ENHANCEMENT_DATA'
|
||||||
|
ii_xml = li_element ).
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
ENDCLASS.
|
||||||
|
|
||||||
|
|
||||||
CLASS lcl_object_enho_clif DEFINITION.
|
CLASS lcl_object_enho_clif DEFINITION.
|
||||||
|
|
||||||
PUBLIC SECTION.
|
PUBLIC SECTION.
|
||||||
|
@ -820,9 +923,13 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
||||||
EXPORTING
|
EXPORTING
|
||||||
is_item = ms_item
|
is_item = ms_item
|
||||||
io_files = mo_files.
|
io_files = mo_files.
|
||||||
|
WHEN cl_wdr_cfg_enhancement=>tooltype.
|
||||||
|
CREATE OBJECT ri_enho TYPE lcl_object_enho_wdyconf
|
||||||
|
EXPORTING
|
||||||
|
is_item = ms_item
|
||||||
|
io_files = mo_files.
|
||||||
* ToDo:
|
* ToDo:
|
||||||
* WHEN 'ENHFUGRDATA'. "cl_enh_tool_fugr
|
* WHEN 'ENHFUGRDATA'. "cl_enh_tool_fugr
|
||||||
* WHEN cl_wdr_cfg_enhancement=>tooltype.
|
|
||||||
* WHEN 'ENHWDYN'. "cl_enh_tool_wdy
|
* WHEN 'ENHWDYN'. "cl_enh_tool_wdy
|
||||||
WHEN OTHERS.
|
WHEN OTHERS.
|
||||||
lcx_exception=>raise( |Unsupported ENHO type { iv_tool }| ).
|
lcx_exception=>raise( |Unsupported ENHO type { iv_tool }| ).
|
||||||
|
|
|
@ -180,6 +180,9 @@ CLASS lcl_xml_output DEFINITION FINAL INHERITING FROM lcl_xml CREATE PUBLIC.
|
||||||
RAISING lcx_exception,
|
RAISING lcx_exception,
|
||||||
set_raw
|
set_raw
|
||||||
IMPORTING ii_raw TYPE REF TO if_ixml_element,
|
IMPORTING ii_raw TYPE REF TO if_ixml_element,
|
||||||
|
add_xml
|
||||||
|
IMPORTING iv_name TYPE clike
|
||||||
|
ii_xml TYPE REF TO if_ixml_element,
|
||||||
render
|
render
|
||||||
IMPORTING iv_normalize TYPE sap_bool DEFAULT abap_true
|
IMPORTING iv_normalize TYPE sap_bool DEFAULT abap_true
|
||||||
is_metadata TYPE ty_metadata OPTIONAL
|
is_metadata TYPE ty_metadata OPTIONAL
|
||||||
|
@ -230,7 +233,18 @@ CLASS lcl_xml_output IMPLEMENTATION.
|
||||||
mi_xml_doc->get_root( )->append_child( li_doc->get_root( )->get_first_child( ) ).
|
mi_xml_doc->get_root( )->append_child( li_doc->get_root( )->get_first_child( ) ).
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
ENDMETHOD. "add
|
ENDMETHOD.
|
||||||
|
|
||||||
|
METHOD add_xml.
|
||||||
|
|
||||||
|
DATA: li_element TYPE REF TO if_ixml_element.
|
||||||
|
|
||||||
|
li_element = mi_xml_doc->create_element( iv_name ).
|
||||||
|
li_element->append_child( ii_xml ).
|
||||||
|
|
||||||
|
mi_xml_doc->get_root( )->get_first_child( )->get_first_child( )->append_child( li_element ).
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
METHOD render.
|
METHOD render.
|
||||||
|
|
||||||
|
@ -280,6 +294,7 @@ CLASS lcl_xml_input DEFINITION FINAL INHERITING FROM lcl_xml CREATE PUBLIC.
|
||||||
RAISING lcx_exception,
|
RAISING lcx_exception,
|
||||||
get_raw
|
get_raw
|
||||||
RETURNING VALUE(ri_raw) TYPE REF TO if_ixml_node,
|
RETURNING VALUE(ri_raw) TYPE REF TO if_ixml_node,
|
||||||
|
* todo, add read_xml to match add_xml in lcl_xml_output
|
||||||
get_metadata
|
get_metadata
|
||||||
RETURNING VALUE(rs_metadata) TYPE ty_metadata.
|
RETURNING VALUE(rs_metadata) TYPE ty_metadata.
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user