mirror of
https://github.com/abapGit/abapGit.git
synced 2025-05-01 04:08:27 +08:00
commit
20f7c028cc
220
src/zabapgit_object_dcls.prog.abap
Normal file
220
src/zabapgit_object_dcls.prog.abap
Normal file
|
@ -0,0 +1,220 @@
|
|||
*&---------------------------------------------------------------------*
|
||||
*& Include zabapgit_object_dcls
|
||||
*&---------------------------------------------------------------------*
|
||||
|
||||
CLASS lcl_object_dcls DEFINITION INHERITING FROM lcl_objects_super FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
INTERFACES lif_object.
|
||||
ALIASES mo_files FOR lif_object~mo_files.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_object_dcls IMPLEMENTATION.
|
||||
|
||||
METHOD lif_object~has_changed_since.
|
||||
rv_changed = abap_true.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~changed_by.
|
||||
rv_user = c_user_unknown.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~get_metadata.
|
||||
rs_metadata = get_metadata( ).
|
||||
|
||||
rs_metadata-ddic = abap_true.
|
||||
rs_metadata-delete_tadir = abap_true.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~exists.
|
||||
|
||||
DATA: li_dcl TYPE REF TO object.
|
||||
|
||||
TRY.
|
||||
CALL METHOD ('CL_ACM_DCL_HANDLER_FACTORY')=>('CREATE')
|
||||
RECEIVING
|
||||
ro_handler = li_dcl.
|
||||
|
||||
CALL METHOD li_dcl->('CHECK_EXISTENCE')
|
||||
EXPORTING
|
||||
iv_objectname = ms_item-obj_name
|
||||
RECEIVING
|
||||
rv_exists = rv_bool.
|
||||
|
||||
CATCH cx_root.
|
||||
rv_bool = abap_false.
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~jump.
|
||||
|
||||
DATA: adt_link TYPE string,
|
||||
obj_name TYPE e071-obj_name,
|
||||
li_object TYPE REF TO cl_wb_object,
|
||||
li_adt TYPE REF TO object,
|
||||
li_adt_uri_mapper TYPE REF TO object,
|
||||
li_adt_objref TYPE REF TO object.
|
||||
|
||||
FIELD-SYMBOLS: <uri> TYPE string.
|
||||
|
||||
TRY.
|
||||
|
||||
obj_name = ms_item-obj_name.
|
||||
|
||||
li_object = cl_wb_object=>create_from_transport_key( p_object = ms_item-obj_type p_obj_name = obj_name ).
|
||||
|
||||
CALL METHOD ('CL_ADT_TOOLS_CORE_FACTORY')=>('GET_INSTANCE')
|
||||
RECEIVING
|
||||
result = li_adt.
|
||||
|
||||
CALL METHOD li_adt->('IF_ADT_TOOLS_CORE_FACTORY~GET_URI_MAPPER')
|
||||
RECEIVING
|
||||
result = li_adt_uri_mapper.
|
||||
|
||||
CALL METHOD li_adt_uri_mapper->('IF_ADT_URI_MAPPER~MAP_WB_OBJECT_TO_OBJREF')
|
||||
EXPORTING
|
||||
wb_object = li_object
|
||||
RECEIVING
|
||||
result = li_adt_objref.
|
||||
|
||||
ASSIGN ('li_adt_objref->ref_data-uri') TO <uri>.
|
||||
|
||||
CONCATENATE 'adt://' sy-sysid <uri> INTO adt_link.
|
||||
|
||||
cl_gui_frontend_services=>execute( EXPORTING document = adt_link
|
||||
EXCEPTIONS OTHERS = 1 ).
|
||||
|
||||
CATCH cx_root.
|
||||
lcx_exception=>raise( 'DCLS Jump Error' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~delete.
|
||||
|
||||
DATA: li_dcl TYPE REF TO object.
|
||||
|
||||
TRY.
|
||||
CALL METHOD ('CL_ACM_DCL_HANDLER_FACTORY')=>('CREATE')
|
||||
RECEIVING
|
||||
ro_handler = li_dcl.
|
||||
|
||||
CALL METHOD li_dcl->('DELETE')
|
||||
EXPORTING
|
||||
iv_dclname = ms_item-obj_name.
|
||||
|
||||
CATCH cx_root.
|
||||
lcx_exception=>raise( 'DCLS error' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~serialize.
|
||||
|
||||
DATA: lr_data TYPE REF TO data,
|
||||
li_dcl TYPE REF TO object.
|
||||
|
||||
FIELD-SYMBOLS: <ls_data> TYPE any,
|
||||
<field> TYPE any.
|
||||
|
||||
CREATE DATA lr_data TYPE ('ACM_S_DCLSRC').
|
||||
ASSIGN lr_data->* TO <ls_data>.
|
||||
|
||||
TRY.
|
||||
CALL METHOD ('CL_ACM_DCL_HANDLER_FACTORY')=>('CREATE')
|
||||
RECEIVING
|
||||
ro_handler = li_dcl.
|
||||
|
||||
CALL METHOD li_dcl->('READ')
|
||||
EXPORTING
|
||||
iv_dclname = ms_item-obj_name
|
||||
IMPORTING
|
||||
es_dclsrc = <ls_data>.
|
||||
|
||||
ASSIGN COMPONENT 'AS4USER' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
CLEAR <field>.
|
||||
|
||||
ASSIGN COMPONENT 'AS4DATE' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
CLEAR <field>.
|
||||
|
||||
ASSIGN COMPONENT 'AS4TIME' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
CLEAR <field>.
|
||||
|
||||
ASSIGN COMPONENT 'CREATED_BY' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
CLEAR <field>.
|
||||
|
||||
ASSIGN COMPONENT 'CREATED_DATE' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
CLEAR <field>.
|
||||
|
||||
ASSIGN COMPONENT 'SOURCE' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
|
||||
mo_files->add_string( iv_ext = 'asdcls' iv_string = <field> ).
|
||||
|
||||
CLEAR <field>.
|
||||
|
||||
io_xml->add( iv_name = 'DCLS'
|
||||
ig_data = <ls_data> ).
|
||||
|
||||
CATCH cx_root.
|
||||
lcx_exception=>raise( 'DCLS error' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~deserialize.
|
||||
|
||||
DATA: lr_data TYPE REF TO data,
|
||||
li_dcl TYPE REF TO object.
|
||||
|
||||
FIELD-SYMBOLS: <ls_data> TYPE any,
|
||||
<field> TYPE any.
|
||||
|
||||
CREATE DATA lr_data TYPE ('ACM_S_DCLSRC').
|
||||
ASSIGN lr_data->* TO <ls_data>.
|
||||
|
||||
io_xml->read(
|
||||
EXPORTING
|
||||
iv_name = 'DCLS'
|
||||
CHANGING
|
||||
cg_data = <ls_data> ).
|
||||
|
||||
ASSIGN COMPONENT 'SOURCE' OF STRUCTURE <ls_data> TO <field>.
|
||||
ASSERT sy-subrc = 0.
|
||||
<field> = mo_files->read_string( 'asdcls' ).
|
||||
|
||||
TRY.
|
||||
CALL METHOD ('CL_ACM_DCL_HANDLER_FACTORY')=>('CREATE')
|
||||
RECEIVING
|
||||
ro_handler = li_dcl.
|
||||
|
||||
CALL METHOD li_dcl->('SAVE')
|
||||
EXPORTING
|
||||
iv_dclname = ms_item-obj_name
|
||||
iv_put_state = 'A'
|
||||
is_dclsrc = <ls_data>
|
||||
iv_devclass = iv_package
|
||||
iv_access_mode = 'INSERT'.
|
||||
|
||||
tadir_insert( iv_package ).
|
||||
|
||||
CATCH cx_root.
|
||||
lcx_exception=>raise( 'DCLS error' ).
|
||||
ENDTRY.
|
||||
|
||||
lcl_objects_activation=>add_item( ms_item ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~compare_to_remote_version.
|
||||
CREATE OBJECT ro_comparison_result TYPE lcl_null_comparison_result.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
22
src/zabapgit_object_dcls.prog.xml
Normal file
22
src/zabapgit_object_dcls.prog.xml
Normal file
|
@ -0,0 +1,22 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<abapGit version="v1.0.0" serializer="LCL_OBJECT_PROG" serializer_version="v1.0.0">
|
||||
<asx:abap xmlns:asx="http://www.sap.com/abapxml" version="1.0">
|
||||
<asx:values>
|
||||
<PROGDIR>
|
||||
<NAME>ZABAPGIT_OBJECT_DCLS</NAME>
|
||||
<STATE>A</STATE>
|
||||
<VARCL>X</VARCL>
|
||||
<SUBC>I</SUBC>
|
||||
<RLOAD>E</RLOAD>
|
||||
<UCCHECK>X</UCCHECK>
|
||||
</PROGDIR>
|
||||
<TPOOL>
|
||||
<item>
|
||||
<ID>R</ID>
|
||||
<ENTRY>Include ZABAPGIT_OBJECT_DCLS</ENTRY>
|
||||
<LENGTH>28</LENGTH>
|
||||
</item>
|
||||
</TPOOL>
|
||||
</asx:values>
|
||||
</asx:abap>
|
||||
</abapGit>
|
|
@ -8,6 +8,7 @@ INCLUDE zabapgit_object_acid.
|
|||
INCLUDE zabapgit_object_auth.
|
||||
INCLUDE zabapgit_object_oo_functions.
|
||||
INCLUDE zabapgit_object_clas.
|
||||
INCLUDE zabapgit_object_dcls.
|
||||
INCLUDE zabapgit_object_ddls.
|
||||
INCLUDE zabapgit_object_doct.
|
||||
INCLUDE zabapgit_object_docv.
|
||||
|
|
Loading…
Reference in New Issue
Block a user