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.
|
||||
|
||||
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.
|
||||
|
||||
PUBLIC SECTION.
|
||||
|
@ -820,9 +923,13 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
EXPORTING
|
||||
is_item = ms_item
|
||||
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:
|
||||
* WHEN 'ENHFUGRDATA'. "cl_enh_tool_fugr
|
||||
* WHEN cl_wdr_cfg_enhancement=>tooltype.
|
||||
* WHEN 'ENHWDYN'. "cl_enh_tool_wdy
|
||||
WHEN OTHERS.
|
||||
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,
|
||||
set_raw
|
||||
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
|
||||
IMPORTING iv_normalize TYPE sap_bool DEFAULT abap_true
|
||||
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( ) ).
|
||||
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.
|
||||
|
||||
|
@ -280,6 +294,7 @@ CLASS lcl_xml_input DEFINITION FINAL INHERITING FROM lcl_xml CREATE PUBLIC.
|
|||
RAISING lcx_exception,
|
||||
get_raw
|
||||
RETURNING VALUE(ri_raw) TYPE REF TO if_ixml_node,
|
||||
* todo, add read_xml to match add_xml in lcl_xml_output
|
||||
get_metadata
|
||||
RETURNING VALUE(rs_metadata) TYPE ty_metadata.
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user