mirror of
https://github.com/abapGit/abapGit.git
synced 2025-04-30 20:03:20 +08:00
SFBF, SFBS, SFSW: Major bug fixes (#6020)
This commit is contained in:
parent
49c063998b
commit
71f16d08be
|
@ -3,11 +3,24 @@ CLASS zcl_abapgit_object_sfbf DEFINITION PUBLIC INHERITING FROM zcl_abapgit_obje
|
||||||
PUBLIC SECTION.
|
PUBLIC SECTION.
|
||||||
INTERFACES zif_abapgit_object.
|
INTERFACES zif_abapgit_object.
|
||||||
|
|
||||||
|
METHODS constructor
|
||||||
|
IMPORTING
|
||||||
|
!is_item TYPE zif_abapgit_definitions=>ty_item
|
||||||
|
!iv_language TYPE spras.
|
||||||
|
|
||||||
PROTECTED SECTION.
|
PROTECTED SECTION.
|
||||||
PRIVATE SECTION.
|
PRIVATE SECTION.
|
||||||
|
|
||||||
CONSTANTS c_longtext_id_sfbf TYPE dokil-id VALUE 'BF'.
|
CONSTANTS c_longtext_id_sfbf TYPE dokil-id VALUE 'BF'.
|
||||||
|
|
||||||
|
DATA mv_bf TYPE sfw_bfunction.
|
||||||
|
|
||||||
METHODS:
|
METHODS:
|
||||||
|
activate
|
||||||
|
RAISING zcx_abapgit_exception,
|
||||||
|
create
|
||||||
|
RETURNING VALUE(ro_bf) TYPE REF TO cl_sfw_bf
|
||||||
|
RAISING zcx_abapgit_exception,
|
||||||
get
|
get
|
||||||
RETURNING VALUE(ro_bf) TYPE REF TO cl_sfw_bf
|
RETURNING VALUE(ro_bf) TYPE REF TO cl_sfw_bf
|
||||||
RAISING zcx_abapgit_exception.
|
RAISING zcx_abapgit_exception.
|
||||||
|
@ -19,18 +32,64 @@ ENDCLASS.
|
||||||
CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
|
|
||||||
|
|
||||||
METHOD get.
|
METHOD activate.
|
||||||
|
|
||||||
DATA: lv_bf TYPE sfw_bfunction.
|
DATA: lt_bfuncts TYPE sfw_bftab,
|
||||||
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
|
IF zif_abapgit_object~is_active( ) = abap_true.
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
APPEND mv_bf TO lt_bfuncts.
|
||||||
|
|
||||||
|
cl_sfw_activate=>activate_sfbf(
|
||||||
|
EXPORTING
|
||||||
|
p_bfuncts = lt_bfuncts
|
||||||
|
p_version = 'I'
|
||||||
|
IMPORTING
|
||||||
|
p_msgtab = lt_msgtab ).
|
||||||
|
|
||||||
|
READ TABLE lt_msgtab WITH KEY severity = 'E' TRANSPORTING NO FIELDS.
|
||||||
|
IF sy-subrc = 0.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error activating SFBF' ).
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
lv_bf = ms_item-obj_name.
|
METHOD constructor.
|
||||||
|
|
||||||
|
super->constructor(
|
||||||
|
is_item = is_item
|
||||||
|
iv_language = iv_language ).
|
||||||
|
|
||||||
|
mv_bf = is_item-obj_name.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD create.
|
||||||
|
|
||||||
TRY.
|
TRY.
|
||||||
* make sure to clear cache, method GET_BF_FROM_DB does not exist in 702
|
" make sure to clear cache
|
||||||
ro_bf = cl_sfw_bf=>get_bf( lv_bf ).
|
ro_bf = cl_sfw_bf=>create_bf( mv_bf ).
|
||||||
ro_bf->free( ).
|
ro_bf->free( ).
|
||||||
ro_bf = cl_sfw_bf=>get_bf( lv_bf ).
|
ro_bf = cl_sfw_bf=>create_bf( mv_bf ).
|
||||||
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BF=>CREATE_BF' ).
|
||||||
|
ENDTRY.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD get.
|
||||||
|
|
||||||
|
TRY.
|
||||||
|
" make sure to clear cache, method GET_BF_FROM_DB does not exist in 702
|
||||||
|
ro_bf = cl_sfw_bf=>get_bf( mv_bf ).
|
||||||
|
ro_bf->free( ).
|
||||||
|
ro_bf = cl_sfw_bf=>get_bf( mv_bf ).
|
||||||
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BF=>GET_BF' ).
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BF=>GET_BF' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
@ -55,13 +114,10 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~delete.
|
METHOD zif_abapgit_object~delete.
|
||||||
|
|
||||||
DATA: lv_bf TYPE sfw_bfunction,
|
DATA: lt_delete TYPE sfw_bftab,
|
||||||
lt_delete TYPE sfw_bftab,
|
|
||||||
lt_msgtab TYPE sprot_u_tab.
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
|
APPEND mv_bf TO lt_delete.
|
||||||
lv_bf = ms_item-obj_name.
|
|
||||||
APPEND lv_bf TO lt_delete.
|
|
||||||
|
|
||||||
cl_sfw_activate=>delete_sfbf( EXPORTING p_bfuncts = lt_delete
|
cl_sfw_activate=>delete_sfbf( EXPORTING p_bfuncts = lt_delete
|
||||||
IMPORTING p_msgtab = lt_msgtab ).
|
IMPORTING p_msgtab = lt_msgtab ).
|
||||||
|
@ -71,15 +127,14 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
zcx_abapgit_exception=>raise( 'Error deleting SFBF' ).
|
zcx_abapgit_exception=>raise( 'Error deleting SFBF' ).
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
tadir_delete( ).
|
corr_insert( iv_package ).
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
METHOD zif_abapgit_object~deserialize.
|
METHOD zif_abapgit_object~deserialize.
|
||||||
|
|
||||||
DATA: lv_bf TYPE sfw_bfunction,
|
DATA: lo_bf TYPE REF TO cl_sfw_bf,
|
||||||
lo_bf TYPE REF TO cl_sfw_bf,
|
|
||||||
ls_header TYPE sfw_bf,
|
ls_header TYPE sfw_bf,
|
||||||
lv_name_32 TYPE sfw_name32,
|
lv_name_32 TYPE sfw_name32,
|
||||||
lv_name_80 TYPE sfw_name80,
|
lv_name_80 TYPE sfw_name80,
|
||||||
|
@ -90,6 +145,10 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
ls_sfw_bfc_rn TYPE sfw_bfc_rn,
|
ls_sfw_bfc_rn TYPE sfw_bfc_rn,
|
||||||
lt_parent_bfs TYPE sfw_bs_bf_outtab.
|
lt_parent_bfs TYPE sfw_bs_bf_outtab.
|
||||||
|
|
||||||
|
IF iv_step = zif_abapgit_object=>gc_step_id-late.
|
||||||
|
activate( ).
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
io_xml->read( EXPORTING iv_name = 'HEADER'
|
io_xml->read( EXPORTING iv_name = 'HEADER'
|
||||||
CHANGING cg_data = ls_header ).
|
CHANGING cg_data = ls_header ).
|
||||||
|
@ -111,15 +170,22 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
io_xml->read( EXPORTING iv_name = 'PARENT_BFS'
|
io_xml->read( EXPORTING iv_name = 'PARENT_BFS'
|
||||||
CHANGING cg_data = lt_parent_bfs ).
|
CHANGING cg_data = lt_parent_bfs ).
|
||||||
|
|
||||||
lv_bf = ms_item-obj_name.
|
|
||||||
TRY.
|
TRY.
|
||||||
lo_bf = cl_sfw_bf=>create_bf( lv_bf ).
|
IF zif_abapgit_object~exists( ) = abap_true.
|
||||||
|
lo_bf = get( ).
|
||||||
|
ELSE.
|
||||||
|
lo_bf = create( ).
|
||||||
|
ENDIF.
|
||||||
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
||||||
zcx_abapgit_exception=>raise( 'error in CL_SFW_BF=>CREATE_BF' ).
|
zcx_abapgit_exception=>raise( 'error in CL_SFW_BF=>CREATE_BF' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
|
||||||
ls_header-author = sy-uname.
|
ls_header-author = sy-uname.
|
||||||
ls_header-createdon = sy-datum.
|
ls_header-createdon = sy-datum.
|
||||||
|
|
||||||
|
" Get component from package
|
||||||
|
SELECT SINGLE dlvunit FROM tdevc INTO ls_header-component WHERE devclass = iv_package.
|
||||||
|
|
||||||
lo_bf->set_header_data( ls_header ).
|
lo_bf->set_header_data( ls_header ).
|
||||||
|
|
||||||
lo_bf->set_texts( p_32 = lv_name_32
|
lo_bf->set_texts( p_32 = lv_name_32
|
||||||
|
@ -175,6 +241,7 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~get_deserialize_steps.
|
METHOD zif_abapgit_object~get_deserialize_steps.
|
||||||
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
||||||
|
APPEND zif_abapgit_object=>gc_step_id-late TO rt_steps.
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
@ -222,6 +289,8 @@ CLASS zcl_abapgit_object_sfbf IMPLEMENTATION.
|
||||||
|
|
||||||
ls_header = lo_bf->get_header_data( ).
|
ls_header = lo_bf->get_header_data( ).
|
||||||
CLEAR: ls_header-author,
|
CLEAR: ls_header-author,
|
||||||
|
ls_header-version,
|
||||||
|
ls_header-component,
|
||||||
ls_header-createdon,
|
ls_header-createdon,
|
||||||
ls_header-changedby,
|
ls_header-changedby,
|
||||||
ls_header-changedon,
|
ls_header-changedon,
|
||||||
|
|
|
@ -3,11 +3,24 @@ CLASS zcl_abapgit_object_sfbs DEFINITION PUBLIC INHERITING FROM zcl_abapgit_obje
|
||||||
PUBLIC SECTION.
|
PUBLIC SECTION.
|
||||||
INTERFACES zif_abapgit_object.
|
INTERFACES zif_abapgit_object.
|
||||||
|
|
||||||
|
METHODS constructor
|
||||||
|
IMPORTING
|
||||||
|
!is_item TYPE zif_abapgit_definitions=>ty_item
|
||||||
|
!iv_language TYPE spras.
|
||||||
|
|
||||||
PROTECTED SECTION.
|
PROTECTED SECTION.
|
||||||
PRIVATE SECTION.
|
PRIVATE SECTION.
|
||||||
|
|
||||||
CONSTANTS c_longtext_id_sfbs TYPE dokil-id VALUE 'BS'.
|
CONSTANTS c_longtext_id_sfbs TYPE dokil-id VALUE 'BS'.
|
||||||
|
|
||||||
|
DATA mv_bfset TYPE sfw_bset.
|
||||||
|
|
||||||
METHODS:
|
METHODS:
|
||||||
|
activate
|
||||||
|
RAISING zcx_abapgit_exception,
|
||||||
|
create
|
||||||
|
RETURNING VALUE(ro_bfs) TYPE REF TO cl_sfw_bfs
|
||||||
|
RAISING zcx_abapgit_exception,
|
||||||
get
|
get
|
||||||
RETURNING VALUE(ro_bfs) TYPE REF TO cl_sfw_bfs
|
RETURNING VALUE(ro_bfs) TYPE REF TO cl_sfw_bfs
|
||||||
RAISING zcx_abapgit_exception.
|
RAISING zcx_abapgit_exception.
|
||||||
|
@ -19,17 +32,64 @@ ENDCLASS.
|
||||||
CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
|
|
||||||
|
|
||||||
METHOD get.
|
METHOD activate.
|
||||||
|
|
||||||
DATA: lv_bfset TYPE sfw_bset.
|
DATA: lt_bfsets TYPE sfw_bstab,
|
||||||
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
|
IF zif_abapgit_object~is_active( ) = abap_true.
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
APPEND mv_bfset TO lt_bfsets.
|
||||||
|
|
||||||
|
cl_sfw_activate=>activate_sfbs(
|
||||||
|
EXPORTING
|
||||||
|
p_bsets = lt_bfsets
|
||||||
|
p_version = 'I'
|
||||||
|
IMPORTING
|
||||||
|
p_msgtab = lt_msgtab ).
|
||||||
|
|
||||||
|
READ TABLE lt_msgtab WITH KEY severity = 'E' TRANSPORTING NO FIELDS.
|
||||||
|
IF sy-subrc = 0.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error activating SFBS' ).
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
lv_bfset = ms_item-obj_name.
|
METHOD constructor.
|
||||||
|
|
||||||
|
super->constructor(
|
||||||
|
is_item = is_item
|
||||||
|
iv_language = iv_language ).
|
||||||
|
|
||||||
|
mv_bfset = is_item-obj_name.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD create.
|
||||||
|
|
||||||
TRY.
|
TRY.
|
||||||
ro_bfs = cl_sfw_bfs=>get_bfs( lv_bfset ).
|
" make sure to clear cache
|
||||||
|
ro_bfs = cl_sfw_bfs=>create_bfs( mv_bfset ).
|
||||||
ro_bfs->free( ).
|
ro_bfs->free( ).
|
||||||
ro_bfs = cl_sfw_bfs=>get_bfs( lv_bfset ).
|
ro_bfs = cl_sfw_bfs=>create_bfs( mv_bfset ).
|
||||||
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BFS=>CREATE_BFS' ).
|
||||||
|
ENDTRY.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD get.
|
||||||
|
|
||||||
|
TRY.
|
||||||
|
" make sure to clear cache
|
||||||
|
ro_bfs = cl_sfw_bfs=>get_bfs( mv_bfset ).
|
||||||
|
ro_bfs->free( ).
|
||||||
|
ro_bfs = cl_sfw_bfs=>get_bfs( mv_bfset ).
|
||||||
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BFS=>GET_BFS' ).
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_BFS=>GET_BFS' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
@ -54,13 +114,10 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~delete.
|
METHOD zif_abapgit_object~delete.
|
||||||
|
|
||||||
DATA: lv_bfset TYPE sfw_bset,
|
DATA: lt_delete TYPE sfw_bstab,
|
||||||
lt_delete TYPE sfw_bstab,
|
|
||||||
lt_msgtab TYPE sprot_u_tab.
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
|
APPEND mv_bfset TO lt_delete.
|
||||||
lv_bfset = ms_item-obj_name.
|
|
||||||
APPEND lv_bfset TO lt_delete.
|
|
||||||
|
|
||||||
cl_sfw_activate=>delete_sfbs( EXPORTING p_bsets = lt_delete
|
cl_sfw_activate=>delete_sfbs( EXPORTING p_bsets = lt_delete
|
||||||
IMPORTING p_msgtab = lt_msgtab ).
|
IMPORTING p_msgtab = lt_msgtab ).
|
||||||
|
@ -70,15 +127,14 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
zcx_abapgit_exception=>raise( 'Error deleting SFBS' ).
|
zcx_abapgit_exception=>raise( 'Error deleting SFBS' ).
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
tadir_delete( ).
|
corr_insert( iv_package ).
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
METHOD zif_abapgit_object~deserialize.
|
METHOD zif_abapgit_object~deserialize.
|
||||||
|
|
||||||
DATA: lv_bfset TYPE sfw_bset,
|
DATA: lo_bfs TYPE REF TO cl_sfw_bfs,
|
||||||
lo_bfs TYPE REF TO cl_sfw_bfs,
|
|
||||||
ls_header TYPE sfw_bs,
|
ls_header TYPE sfw_bs,
|
||||||
lv_name_32 TYPE sfw_name32,
|
lv_name_32 TYPE sfw_name32,
|
||||||
lv_name_80 TYPE sfw_name80,
|
lv_name_80 TYPE sfw_name80,
|
||||||
|
@ -86,6 +142,10 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
lt_nested_bfs TYPE sfw_bsbs_outtab,
|
lt_nested_bfs TYPE sfw_bsbs_outtab,
|
||||||
lt_parent_bfs TYPE sfw_bs_bs_parent_outtab.
|
lt_parent_bfs TYPE sfw_bs_bs_parent_outtab.
|
||||||
|
|
||||||
|
IF iv_step = zif_abapgit_object=>gc_step_id-late.
|
||||||
|
activate( ).
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
io_xml->read( EXPORTING iv_name = 'HEADER'
|
io_xml->read( EXPORTING iv_name = 'HEADER'
|
||||||
CHANGING cg_data = ls_header ).
|
CHANGING cg_data = ls_header ).
|
||||||
|
@ -101,9 +161,12 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
io_xml->read( EXPORTING iv_name = 'PARENT_BFS'
|
io_xml->read( EXPORTING iv_name = 'PARENT_BFS'
|
||||||
CHANGING cg_data = lt_parent_bfs ).
|
CHANGING cg_data = lt_parent_bfs ).
|
||||||
|
|
||||||
lv_bfset = ms_item-obj_name.
|
|
||||||
TRY.
|
TRY.
|
||||||
lo_bfs = cl_sfw_bfs=>create_bfs( lv_bfset ).
|
IF zif_abapgit_object~exists( ) = abap_true.
|
||||||
|
lo_bfs = get( ).
|
||||||
|
ELSE.
|
||||||
|
lo_bfs = create( ).
|
||||||
|
ENDIF.
|
||||||
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
||||||
zcx_abapgit_exception=>raise( 'error in CL_SFW_BFS=>CREATE_BFS' ).
|
zcx_abapgit_exception=>raise( 'error in CL_SFW_BFS=>CREATE_BFS' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
@ -134,12 +197,9 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~exists.
|
METHOD zif_abapgit_object~exists.
|
||||||
|
|
||||||
DATA: ls_tadir TYPE tadir,
|
DATA ls_tadir TYPE tadir.
|
||||||
lv_bfset TYPE sfw_bset.
|
|
||||||
|
|
||||||
|
IF cl_sfw_bfs=>check_existence( mv_bfset ) = abap_false.
|
||||||
lv_bfset = ms_item-obj_name.
|
|
||||||
IF cl_sfw_bfs=>check_existence( lv_bfset ) = abap_false.
|
|
||||||
RETURN.
|
RETURN.
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
|
@ -163,6 +223,7 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~get_deserialize_steps.
|
METHOD zif_abapgit_object~get_deserialize_steps.
|
||||||
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
||||||
|
APPEND zif_abapgit_object=>gc_step_id-late TO rt_steps.
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
@ -205,6 +266,7 @@ CLASS zcl_abapgit_object_sfbs IMPLEMENTATION.
|
||||||
|
|
||||||
ls_header = lo_bfs->get_header_data( ).
|
ls_header = lo_bfs->get_header_data( ).
|
||||||
CLEAR: ls_header-author,
|
CLEAR: ls_header-author,
|
||||||
|
ls_header-version,
|
||||||
ls_header-createdon,
|
ls_header-createdon,
|
||||||
ls_header-changedby,
|
ls_header-changedby,
|
||||||
ls_header-changedon,
|
ls_header-changedon,
|
||||||
|
|
|
@ -3,18 +3,27 @@ CLASS zcl_abapgit_object_sfsw DEFINITION PUBLIC INHERITING FROM zcl_abapgit_obje
|
||||||
PUBLIC SECTION.
|
PUBLIC SECTION.
|
||||||
INTERFACES zif_abapgit_object.
|
INTERFACES zif_abapgit_object.
|
||||||
|
|
||||||
|
METHODS constructor
|
||||||
|
IMPORTING
|
||||||
|
!is_item TYPE zif_abapgit_definitions=>ty_item
|
||||||
|
!iv_language TYPE spras.
|
||||||
|
|
||||||
PROTECTED SECTION.
|
PROTECTED SECTION.
|
||||||
PRIVATE SECTION.
|
PRIVATE SECTION.
|
||||||
|
|
||||||
CONSTANTS c_longtext_id_sfsw TYPE dokil-id VALUE 'SW'.
|
CONSTANTS c_longtext_id_sfsw TYPE dokil-id VALUE 'SW'.
|
||||||
|
|
||||||
|
DATA mv_switch TYPE sfw_switch_id.
|
||||||
|
|
||||||
METHODS:
|
METHODS:
|
||||||
get
|
activate
|
||||||
|
RAISING zcx_abapgit_exception,
|
||||||
|
create
|
||||||
RETURNING VALUE(ro_switch) TYPE REF TO cl_sfw_sw
|
RETURNING VALUE(ro_switch) TYPE REF TO cl_sfw_sw
|
||||||
RAISING zcx_abapgit_exception,
|
RAISING zcx_abapgit_exception,
|
||||||
wait_for_background_job,
|
get
|
||||||
wait_for_deletion
|
RETURNING VALUE(ro_switch) TYPE REF TO cl_sfw_sw
|
||||||
RAISING
|
RAISING zcx_abapgit_exception.
|
||||||
zcx_abapgit_exception.
|
|
||||||
|
|
||||||
ENDCLASS.
|
ENDCLASS.
|
||||||
|
|
||||||
|
@ -23,60 +32,67 @@ ENDCLASS.
|
||||||
CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
|
|
||||||
|
|
||||||
METHOD get.
|
METHOD activate.
|
||||||
|
|
||||||
DATA: lv_switch_id TYPE sfw_switch_id.
|
DATA: lt_switches TYPE sfw_switchtab,
|
||||||
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
lv_switch_id = ms_item-obj_name.
|
IF zif_abapgit_object~is_active( ) = abap_true.
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
APPEND mv_switch TO lt_switches.
|
||||||
|
|
||||||
|
cl_sfw_activate=>activate_sfsw(
|
||||||
|
EXPORTING
|
||||||
|
p_switches = lt_switches
|
||||||
|
p_version = 'I'
|
||||||
|
IMPORTING
|
||||||
|
p_msgtab = lt_msgtab ).
|
||||||
|
|
||||||
|
READ TABLE lt_msgtab WITH KEY severity = 'E' TRANSPORTING NO FIELDS.
|
||||||
|
IF sy-subrc = 0.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error activating SFBS' ).
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD constructor.
|
||||||
|
|
||||||
|
super->constructor(
|
||||||
|
is_item = is_item
|
||||||
|
iv_language = iv_language ).
|
||||||
|
|
||||||
|
mv_switch = is_item-obj_name.
|
||||||
|
|
||||||
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
METHOD create.
|
||||||
|
|
||||||
TRY.
|
TRY.
|
||||||
ro_switch = cl_sfw_sw=>get_switch_from_db( lv_switch_id ).
|
" make sure to clear cache
|
||||||
|
ro_switch = cl_sfw_sw=>create_switch( mv_switch ).
|
||||||
|
ro_switch->free( ).
|
||||||
|
ro_switch = cl_sfw_sw=>create_switch( mv_switch ).
|
||||||
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
zcx_abapgit_exception=>raise( 'Error from CL_SFW_SW=>GET_SWITCH' ).
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_SW=>CREATE_SWITCH' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
METHOD wait_for_background_job.
|
METHOD get.
|
||||||
|
|
||||||
DATA: lv_job_count TYPE tbtco-jobcount.
|
TRY.
|
||||||
|
" make sure to clear cache
|
||||||
" We wait for at most 5 seconds. If it takes
|
ro_switch = cl_sfw_sw=>get_switch( mv_switch ).
|
||||||
" more than that it probably doesn't matter,
|
ro_switch->free( ).
|
||||||
" because we have other problems
|
ro_switch = cl_sfw_sw=>get_switch( mv_switch ).
|
||||||
|
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
||||||
DO 5 TIMES.
|
zcx_abapgit_exception=>raise( 'Error from CL_SFW_SW=>GET_SWITCH' ).
|
||||||
|
ENDTRY.
|
||||||
SELECT SINGLE jobcount
|
|
||||||
FROM tbtco
|
|
||||||
INTO lv_job_count
|
|
||||||
WHERE jobname = 'SFW_DELETE_SWITCH'
|
|
||||||
AND status = 'R'
|
|
||||||
AND sdluname = sy-uname.
|
|
||||||
|
|
||||||
IF sy-subrc = 0.
|
|
||||||
WAIT UP TO 1 SECONDS.
|
|
||||||
ELSE.
|
|
||||||
EXIT.
|
|
||||||
ENDIF.
|
|
||||||
|
|
||||||
ENDDO.
|
|
||||||
|
|
||||||
ENDMETHOD.
|
|
||||||
|
|
||||||
|
|
||||||
METHOD wait_for_deletion.
|
|
||||||
|
|
||||||
DO 5 TIMES.
|
|
||||||
|
|
||||||
IF zif_abapgit_object~exists( ) = abap_true.
|
|
||||||
WAIT UP TO 1 SECONDS.
|
|
||||||
ELSE.
|
|
||||||
EXIT.
|
|
||||||
ENDIF.
|
|
||||||
|
|
||||||
ENDDO.
|
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
@ -98,25 +114,20 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~delete.
|
METHOD zif_abapgit_object~delete.
|
||||||
|
|
||||||
DATA: lv_switch_id TYPE sfw_switch_id,
|
DATA: lt_delete TYPE sfw_switchtab,
|
||||||
lo_switch TYPE REF TO cl_sfw_sw.
|
lt_msgtab TYPE sprot_u_tab.
|
||||||
|
|
||||||
|
APPEND mv_switch TO lt_delete.
|
||||||
|
|
||||||
lv_switch_id = ms_item-obj_name.
|
cl_sfw_activate=>delete_sfsw( EXPORTING p_switches = lt_delete
|
||||||
TRY.
|
IMPORTING p_msgtab = lt_msgtab ).
|
||||||
lo_switch = cl_sfw_sw=>get_switch( lv_switch_id ).
|
|
||||||
lo_switch->set_delete_flag( lv_switch_id ).
|
|
||||||
lo_switch->save_all( ).
|
|
||||||
|
|
||||||
" deletion via background job. Wait until the job is finished...
|
READ TABLE lt_msgtab WITH KEY severity = 'E' TRANSPORTING NO FIELDS.
|
||||||
wait_for_background_job( ).
|
IF sy-subrc = 0.
|
||||||
|
zcx_abapgit_exception=>raise( 'Error deleting SFSW' ).
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
" ... the object is deleted
|
corr_insert( iv_package ).
|
||||||
wait_for_deletion( ).
|
|
||||||
|
|
||||||
CATCH cx_pak_invalid_data cx_pak_invalid_state cx_pak_not_authorized.
|
|
||||||
zcx_abapgit_exception=>raise( 'Error deleting Switch' ).
|
|
||||||
ENDTRY.
|
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
@ -124,13 +135,16 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
METHOD zif_abapgit_object~deserialize.
|
METHOD zif_abapgit_object~deserialize.
|
||||||
|
|
||||||
DATA: lo_switch TYPE REF TO cl_sfw_sw,
|
DATA: lo_switch TYPE REF TO cl_sfw_sw,
|
||||||
lv_switch_id TYPE sfw_switch_id,
|
|
||||||
ls_header TYPE sfw_switch,
|
ls_header TYPE sfw_switch,
|
||||||
lv_name_32 TYPE sfw_name32,
|
lv_name_32 TYPE sfw_name32,
|
||||||
lv_name_80 TYPE sfw_name80,
|
lv_name_80 TYPE sfw_name80,
|
||||||
lt_parent_bf TYPE sfw_bf_sw_outtab,
|
lt_parent_bf TYPE sfw_bf_sw_outtab,
|
||||||
lt_conflicts TYPE sfw_confl_outtab.
|
lt_conflicts TYPE sfw_confl_outtab.
|
||||||
|
|
||||||
|
IF iv_step = zif_abapgit_object=>gc_step_id-late.
|
||||||
|
activate( ).
|
||||||
|
RETURN.
|
||||||
|
ENDIF.
|
||||||
|
|
||||||
io_xml->read( EXPORTING iv_name = 'HEADER'
|
io_xml->read( EXPORTING iv_name = 'HEADER'
|
||||||
CHANGING cg_data = ls_header ).
|
CHANGING cg_data = ls_header ).
|
||||||
|
@ -144,9 +158,12 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
io_xml->read( EXPORTING iv_name = 'CONFLICTS'
|
io_xml->read( EXPORTING iv_name = 'CONFLICTS'
|
||||||
CHANGING cg_data = lt_conflicts ).
|
CHANGING cg_data = lt_conflicts ).
|
||||||
|
|
||||||
lv_switch_id = ms_item-obj_name.
|
|
||||||
TRY.
|
TRY.
|
||||||
lo_switch = cl_sfw_sw=>create_switch( lv_switch_id ).
|
IF zif_abapgit_object~exists( ) = abap_true.
|
||||||
|
lo_switch = get( ).
|
||||||
|
ELSE.
|
||||||
|
lo_switch = create( ).
|
||||||
|
ENDIF.
|
||||||
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
CATCH cx_pak_not_authorized cx_pak_invalid_state cx_pak_invalid_data.
|
||||||
zcx_abapgit_exception=>raise( 'error in CL_SFW_SW=>CREATE_SWITCH' ).
|
zcx_abapgit_exception=>raise( 'error in CL_SFW_SW=>CREATE_SWITCH' ).
|
||||||
ENDTRY.
|
ENDTRY.
|
||||||
|
@ -183,12 +200,9 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~exists.
|
METHOD zif_abapgit_object~exists.
|
||||||
|
|
||||||
DATA: ls_tadir TYPE tadir,
|
DATA ls_tadir TYPE tadir.
|
||||||
lv_switch_id TYPE sfw_switch_id.
|
|
||||||
|
|
||||||
|
IF cl_sfw_sw=>check_existence( mv_switch ) = abap_false.
|
||||||
lv_switch_id = ms_item-obj_name.
|
|
||||||
IF cl_sfw_sw=>check_existence( lv_switch_id ) = abap_false.
|
|
||||||
RETURN.
|
RETURN.
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
|
@ -201,6 +215,7 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
ENDIF.
|
ENDIF.
|
||||||
|
|
||||||
rv_bool = abap_true.
|
rv_bool = abap_true.
|
||||||
|
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
@ -211,6 +226,7 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
|
|
||||||
METHOD zif_abapgit_object~get_deserialize_steps.
|
METHOD zif_abapgit_object~get_deserialize_steps.
|
||||||
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
APPEND zif_abapgit_object=>gc_step_id-ddic TO rt_steps.
|
||||||
|
APPEND zif_abapgit_object=>gc_step_id-late TO rt_steps.
|
||||||
ENDMETHOD.
|
ENDMETHOD.
|
||||||
|
|
||||||
|
|
||||||
|
@ -252,6 +268,7 @@ CLASS zcl_abapgit_object_sfsw IMPLEMENTATION.
|
||||||
|
|
||||||
ls_header = lo_switch->get_header_data( ).
|
ls_header = lo_switch->get_header_data( ).
|
||||||
CLEAR: ls_header-author,
|
CLEAR: ls_header-author,
|
||||||
|
ls_header-version,
|
||||||
ls_header-createdon,
|
ls_header-createdon,
|
||||||
ls_header-changedby,
|
ls_header-changedby,
|
||||||
ls_header-changedon,
|
ls_header-changedon,
|
||||||
|
|
Loading…
Reference in New Issue
Block a user