Merge pull request #547 from larshp/issue542

ENHO: wdyconf serialization #542
This commit is contained in:
Lars Hvam 2017-01-19 11:11:32 +01:00 committed by GitHub
commit 4663ef734c
2 changed files with 124 additions and 2 deletions

View File

@ -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 }| ).

View File

@ -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.