mirror of
https://github.com/abapGit/abapGit.git
synced 2025-05-01 04:08:27 +08:00
Merge branch 'master' into ADT_Jump
This commit is contained in:
commit
93337e9db4
|
@ -21,7 +21,7 @@ TYPES: ty_file_signatures_ts TYPE SORTED TABLE OF
|
|||
ty_file_signature WITH UNIQUE KEY path filename.
|
||||
|
||||
TYPES: BEGIN OF ty_file.
|
||||
INCLUDE TYPE ty_file_signature.
|
||||
INCLUDE TYPE ty_file_signature.
|
||||
TYPES: data TYPE xstring,
|
||||
END OF ty_file.
|
||||
TYPES: ty_files_tt TYPE STANDARD TABLE OF ty_file WITH DEFAULT KEY.
|
||||
|
@ -127,7 +127,7 @@ TYPES: ty_sval_tt TYPE STANDARD TABLE OF sval WITH DEFAULT KEY.
|
|||
TYPES: ty_seocompotx_tt TYPE STANDARD TABLE OF seocompotx WITH DEFAULT KEY.
|
||||
|
||||
TYPES: BEGIN OF ty_tpool.
|
||||
INCLUDE TYPE textpool.
|
||||
INCLUDE TYPE textpool.
|
||||
TYPES: split TYPE c LENGTH 8.
|
||||
TYPES: END OF ty_tpool.
|
||||
|
||||
|
@ -185,6 +185,7 @@ CONSTANTS: BEGIN OF gc_action_type,
|
|||
dummy TYPE c VALUE '_',
|
||||
END OF gc_action_type.
|
||||
|
||||
CONSTANTS: gc_crlf TYPE abap_cr_lf VALUE cl_abap_char_utilities=>cr_lf.
|
||||
CONSTANTS: gc_newline TYPE abap_char1 VALUE cl_abap_char_utilities=>newline.
|
||||
|
||||
CONSTANTS: gc_english TYPE spras VALUE 'E'.
|
||||
|
|
|
@ -302,6 +302,7 @@ CLASS lcl_html_action_utils IMPLEMENTATION.
|
|||
CLEAR es_fields.
|
||||
|
||||
CONCATENATE LINES OF it_postdata INTO lv_string.
|
||||
REPLACE ALL OCCURRENCES OF gc_crlf IN lv_string WITH lc_replace.
|
||||
REPLACE ALL OCCURRENCES OF gc_newline IN lv_string WITH lc_replace.
|
||||
lt_fields = parse_fields( lv_string ).
|
||||
|
||||
|
|
|
@ -155,9 +155,14 @@ CLASS lcl_gui_page_commit IMPLEMENTATION.
|
|||
|
||||
METHOD render_form.
|
||||
|
||||
DATA: lo_user TYPE REF TO lcl_persistence_user,
|
||||
lv_user TYPE string,
|
||||
lv_email TYPE string.
|
||||
CONSTANTS: lc_body_col_max TYPE i VALUE 150.
|
||||
|
||||
DATA: lo_user TYPE REF TO lcl_persistence_user.
|
||||
DATA: lv_user TYPE string.
|
||||
DATA: lv_email TYPE string.
|
||||
DATA: lv_s_param TYPE string.
|
||||
DATA: lo_settings TYPE REF TO lcl_settings.
|
||||
data: lv_body_size type i.
|
||||
|
||||
* see https://git-scm.com/book/ch5-2.html
|
||||
* commit messages should be max 50 characters
|
||||
|
@ -189,13 +194,24 @@ CLASS lcl_gui_page_commit IMPLEMENTATION.
|
|||
iv_label = 'committer e-mail'
|
||||
iv_value = lv_email ) ).
|
||||
|
||||
lo_settings = lcl_app=>settings( )->read( ).
|
||||
|
||||
lv_s_param = lo_settings->get_commitmsg_comment_length( ).
|
||||
|
||||
ro_html->add( render_text_input( iv_name = 'comment'
|
||||
iv_label = 'comment'
|
||||
iv_max_length = '72' ) ).
|
||||
iv_max_length = lv_s_param ) ).
|
||||
|
||||
ro_html->add( '<div class="row">' ).
|
||||
ro_html->add( '<label for="c-body">body</label>' ).
|
||||
ro_html->add( '<textarea id="c-body" name="body" rows="10" cols="50"></textarea>' ).
|
||||
|
||||
lv_body_size = lo_settings->get_commitmsg_body_size( ).
|
||||
IF lv_body_size > lc_body_col_max.
|
||||
lv_body_size = lc_body_col_max.
|
||||
ENDIF.
|
||||
ro_html->add( |<textarea id="c-body" name="body" rows="10" cols="| &&
|
||||
|{ lv_body_size }"></textarea>| ).
|
||||
|
||||
ro_html->add( '<input type="submit" class="hidden-submit">' ).
|
||||
ro_html->add( '</div>' ).
|
||||
|
||||
|
|
|
@ -34,6 +34,8 @@ CLASS lcl_gui_page_settings DEFINITION FINAL INHERITING FROM lcl_gui_page.
|
|||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html.
|
||||
METHODS render_adt_jump_enabled
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html.
|
||||
METHODS render_commit_msg
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html.
|
||||
METHODS build_settings
|
||||
IMPORTING
|
||||
it_post_fields TYPE tihttpnvp.
|
||||
|
@ -66,11 +68,13 @@ CLASS lcl_gui_page_settings IMPLEMENTATION.
|
|||
ro_html->add( render_form_begin( ) ).
|
||||
ro_html->add( render_proxy( ) ).
|
||||
ro_html->add( |<hr>| ).
|
||||
ro_html->add( render_development_internals( ) ).
|
||||
ro_html->add( |<hr>| ).
|
||||
ro_html->add( render_max_lines( ) ).
|
||||
ro_html->add( |<hr>| ).
|
||||
ro_html->add( render_adt_jump_enabled( ) ).
|
||||
ro_html->add( |<hr>| ).
|
||||
ro_html->add( render_commit_msg( ) ).
|
||||
ro_html->add( |<hr>| ).
|
||||
ro_html->add( render_development_internals( ) ).
|
||||
ro_html->add( render_form_end( ) ).
|
||||
|
||||
ENDMETHOD. "render_content
|
||||
|
@ -103,6 +107,7 @@ CLASS lcl_gui_page_settings IMPLEMENTATION.
|
|||
ENDMETHOD.
|
||||
|
||||
METHOD lif_gui_page~on_event.
|
||||
* todo, check input values eg INT
|
||||
|
||||
DATA:
|
||||
lt_post_fields TYPE tihttpnvp.
|
||||
|
@ -128,41 +133,41 @@ CLASS lcl_gui_page_settings IMPLEMENTATION.
|
|||
|
||||
METHOD build_settings.
|
||||
|
||||
DATA: ls_post_field TYPE ihttpnvp,
|
||||
lv_max_lines_as_integer TYPE i.
|
||||
DATA: lv_i_param_value TYPE i.
|
||||
FIELD-SYMBOLS: <ls_post_field> TYPE ihttpnvp.
|
||||
|
||||
|
||||
CREATE OBJECT mo_settings.
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'proxy_url'.
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'proxy_url'.
|
||||
IF sy-subrc <> 0.
|
||||
mv_error = abap_true.
|
||||
ENDIF.
|
||||
mo_settings->set_proxy_url( ls_post_field-value ).
|
||||
mo_settings->set_proxy_url( <ls_post_field>-value ).
|
||||
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'proxy_port'.
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'proxy_port'.
|
||||
IF sy-subrc <> 0.
|
||||
mv_error = abap_true.
|
||||
ENDIF.
|
||||
mo_settings->set_proxy_port( ls_post_field-value ).
|
||||
mo_settings->set_proxy_port( <ls_post_field>-value ).
|
||||
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'proxy_auth'.
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'proxy_auth'.
|
||||
IF sy-subrc = 0.
|
||||
mo_settings->set_proxy_authentication( abap_true ).
|
||||
ELSE.
|
||||
mo_settings->set_proxy_authentication( abap_false ).
|
||||
ENDIF.
|
||||
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'critical_tests'.
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'critical_tests'.
|
||||
IF sy-subrc = 0.
|
||||
mo_settings->set_run_critical_tests( abap_true ).
|
||||
ELSE.
|
||||
mo_settings->set_run_critical_tests( abap_false ).
|
||||
ENDIF.
|
||||
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'max_lines'.
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'max_lines'.
|
||||
IF sy-subrc = 0.
|
||||
lv_max_lines_as_integer = ls_post_field-value.
|
||||
mo_settings->set_max_lines( lv_max_lines_as_integer ).
|
||||
lv_i_param_value = <ls_post_field>-value.
|
||||
mo_settings->set_max_lines( lv_i_param_value ).
|
||||
ELSE.
|
||||
mo_settings->set_max_lines( 0 ).
|
||||
ENDIF.
|
||||
|
@ -174,6 +179,28 @@ CLASS lcl_gui_page_settings IMPLEMENTATION.
|
|||
mo_settings->set_adt_jump_enanbled( abap_false ).
|
||||
ENDIF.
|
||||
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'comment_length'.
|
||||
IF sy-subrc = 0.
|
||||
lv_i_param_value = <ls_post_field>-value.
|
||||
IF lv_i_param_value < lcl_settings=>c_commitmsg_comment_length_dft.
|
||||
lv_i_param_value = lcl_settings=>c_commitmsg_comment_length_dft.
|
||||
ENDIF.
|
||||
mo_settings->set_commitmsg_comment_length( lv_i_param_value ).
|
||||
ELSE.
|
||||
mo_settings->set_commitmsg_comment_length( lcl_settings=>c_commitmsg_comment_length_dft ).
|
||||
ENDIF.
|
||||
|
||||
READ TABLE it_post_fields ASSIGNING <ls_post_field> WITH KEY name = 'body_size'.
|
||||
IF sy-subrc = 0.
|
||||
lv_i_param_value = <ls_post_field>-value.
|
||||
IF lv_i_param_value < lcl_settings=>c_commitmsg_body_size_dft.
|
||||
lv_i_param_value = lcl_settings=>c_commitmsg_body_size_dft.
|
||||
ENDIF.
|
||||
mo_settings->set_commitmsg_body_size( lv_i_param_value ).
|
||||
ELSE.
|
||||
mo_settings->set_commitmsg_body_size( lcl_settings=>c_commitmsg_body_size_dft ).
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
|
@ -276,7 +303,23 @@ CLASS lcl_gui_page_settings IMPLEMENTATION.
|
|||
&& lv_checked && ` > Enable jump to ADT first` ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD render_commit_msg.
|
||||
CREATE OBJECT ro_html.
|
||||
|
||||
ro_html->add( |<h2>Commit Message</h2>| ).
|
||||
ro_html->add( |<label for="comment_length">Max. length of comment (recommendation 50)</label>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<input name="comment_length" type="number" step="10" size="3" maxlength="3" min="50"| &&
|
||||
| value="{ mo_settings->get_commitmsg_comment_length( ) }">| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<label for="body_size">Max. line size of body (recommendation 72)</label>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<input name="body_size" type="number" step="10" size="3" maxlength="3" min="50"| &&
|
||||
| value="{ mo_settings->get_commitmsg_body_size( ) }">| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
|
|
@ -1534,6 +1534,9 @@ ENDCLASS.
|
|||
CLASS lcl_settings DEFINITION FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
CONSTANTS: c_commitmsg_comment_length_dft TYPE i VALUE 50.
|
||||
CONSTANTS: c_commitmsg_body_size_dft TYPE i VALUE 72.
|
||||
|
||||
METHODS set_proxy_url
|
||||
IMPORTING
|
||||
iv_url TYPE string.
|
||||
|
@ -1568,6 +1571,16 @@ CLASS lcl_settings DEFINITION FINAL.
|
|||
METHODS get_adt_jump_enabled
|
||||
RETURNING
|
||||
VALUE(rv_adt_jump_enabled) TYPE abap_bool.
|
||||
METHODS set_commitmsg_comment_length
|
||||
IMPORTING iv_length TYPE i.
|
||||
METHODS get_commitmsg_comment_length
|
||||
RETURNING
|
||||
VALUE(rv_length) TYPE i.
|
||||
METHODS set_commitmsg_body_size
|
||||
IMPORTING iv_length TYPE i.
|
||||
METHODS get_commitmsg_body_size
|
||||
RETURNING
|
||||
VALUE(rv_length) TYPE i.
|
||||
|
||||
PRIVATE SECTION.
|
||||
DATA: mv_proxy_url TYPE string,
|
||||
|
@ -1575,7 +1588,9 @@ CLASS lcl_settings DEFINITION FINAL.
|
|||
mv_proxy_auth TYPE string,
|
||||
mv_run_critical_tests TYPE abap_bool,
|
||||
mv_lines TYPE i,
|
||||
mv_adt_jump_enabled TYPE abap_bool.
|
||||
mv_adt_jump_enabled TYPE abap_bool,
|
||||
mv_commitmsg_comment_length TYPE i,
|
||||
mv_commitmsg_body_size TYPE i.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
|
@ -1629,6 +1644,22 @@ CLASS lcl_settings IMPLEMENTATION.
|
|||
mv_adt_jump_enabled = iv_adt_jump_enabled.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD get_commitmsg_comment_length.
|
||||
rv_length = mv_commitmsg_comment_length.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD set_commitmsg_comment_length.
|
||||
mv_commitmsg_comment_length = iv_length.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD get_commitmsg_body_size.
|
||||
rv_length = mv_commitmsg_body_size.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD set_commitmsg_body_size.
|
||||
mv_commitmsg_body_size = iv_length.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_persistence_settings DEFINITION FINAL.
|
||||
|
@ -1680,6 +1711,16 @@ CLASS lcl_persistence_settings IMPLEMENTATION.
|
|||
iv_value = 'ADT_JUMP'
|
||||
iv_data = io_settings->get_adt_jump_enabled( ) ).
|
||||
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'COMMENT_LEN'
|
||||
iv_data = |{ io_settings->get_commitmsg_comment_length( ) }| ).
|
||||
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'BODY_SIZE'
|
||||
iv_data = |{ io_settings->get_commitmsg_body_size( ) }| ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD read.
|
||||
|
@ -1689,6 +1730,8 @@ CLASS lcl_persistence_settings IMPLEMENTATION.
|
|||
lv_max_lines_as_string TYPE string,
|
||||
lv_flag TYPE abap_bool,
|
||||
lv_max_lines_as_integer TYPE i,
|
||||
lv_s_param_value TYPE string,
|
||||
lv_i_param_value TYPE i,
|
||||
lv_adt_jump_enabled_as_string TYPE string,
|
||||
lv_adt_jump_enabled_as_boolean TYPE abap_bool.
|
||||
|
||||
|
@ -1738,7 +1781,7 @@ CLASS lcl_persistence_settings IMPLEMENTATION.
|
|||
iv_value = 'MAX_LINES' ).
|
||||
lv_max_lines_as_integer = lv_max_lines_as_string.
|
||||
ro_settings->set_max_lines( lv_max_lines_as_integer ).
|
||||
CATCH lcx_not_found.
|
||||
CATCH lcx_not_found cx_sy_conversion_no_number.
|
||||
ro_settings->set_max_lines( 500 ). " default
|
||||
ENDTRY.
|
||||
|
||||
|
@ -1752,6 +1795,26 @@ CLASS lcl_persistence_settings IMPLEMENTATION.
|
|||
ro_settings->set_adt_jump_enanbled( abap_false ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
TRY.
|
||||
lv_s_param_value = lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'COMMENT_LEN' ).
|
||||
lv_i_param_value = lv_s_param_value.
|
||||
ro_settings->set_commitmsg_comment_length( lv_i_param_value ).
|
||||
CATCH lcx_not_found cx_sy_conversion_no_number.
|
||||
ro_settings->set_commitmsg_comment_length( lcl_settings=>c_commitmsg_comment_length_dft ). " default
|
||||
ENDTRY.
|
||||
|
||||
TRY.
|
||||
lv_s_param_value = lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'BODY_SIZE' ).
|
||||
lv_i_param_value = lv_s_param_value.
|
||||
ro_settings->set_commitmsg_body_size( lv_i_param_value ).
|
||||
CATCH lcx_not_found cx_sy_conversion_no_number.
|
||||
ro_settings->set_commitmsg_body_size( lcl_settings=>c_commitmsg_body_size_dft ). " default
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
|
Loading…
Reference in New Issue
Block a user