diff --git a/changelog.txt b/changelog.txt
index a8c81ec13..37baed540 100644
--- a/changelog.txt
+++ b/changelog.txt
@@ -8,6 +8,10 @@ Legend
+ : added
- : removed
+2016-11-??
+------------------
++ supported object list @debugpage
+
2016-11-12
------------------
+ brand new style for file diff display - local and remote statuses are independent and based on local/remote hash and saved state
diff --git a/src/zabapgit_objects.prog.abap b/src/zabapgit_objects.prog.abap
index 844716d85..d18b45734 100644
--- a/src/zabapgit_objects.prog.abap
+++ b/src/zabapgit_objects.prog.abap
@@ -1596,6 +1596,7 @@ CLASS lcl_objects DEFINITION FINAL.
CLASS-METHODS is_supported
IMPORTING is_item TYPE ty_item
+ iv_native_only TYPE abap_bool DEFAULT abap_false
RETURNING VALUE(rv_bool) TYPE abap_bool.
CLASS-METHODS exists
@@ -1618,10 +1619,11 @@ CLASS lcl_objects DEFINITION FINAL.
RAISING lcx_exception.
CLASS-METHODS create_object
- IMPORTING is_item TYPE ty_item
- iv_language TYPE spras
- is_metadata TYPE ty_metadata OPTIONAL
- RETURNING VALUE(ri_obj) TYPE REF TO lif_object
+ IMPORTING is_item TYPE ty_item
+ iv_language TYPE spras
+ is_metadata TYPE ty_metadata OPTIONAL
+ iv_native_only TYPE abap_bool DEFAULT abap_false
+ RETURNING VALUE(ri_obj) TYPE REF TO lif_object
RAISING lcx_exception.
CLASS-METHODS
diff --git a/src/zabapgit_objects_impl.prog.abap b/src/zabapgit_objects_impl.prog.abap
index 10031eb48..05696b421 100644
--- a/src/zabapgit_objects_impl.prog.abap
+++ b/src/zabapgit_objects_impl.prog.abap
@@ -137,17 +137,18 @@ CLASS lcl_objects IMPLEMENTATION.
is_item = is_item
iv_language = iv_language.
CATCH cx_sy_create_object_error.
- TRY.
-* 2nd step, try looking for plugins
- CREATE OBJECT ri_obj TYPE lcl_objects_bridge
- EXPORTING
- is_item = is_item.
- CATCH cx_sy_create_object_error.
- CONCATENATE 'Object type' is_item-obj_type 'not supported, serialize'
- INTO lv_message
- SEPARATED BY space. "#EC NOTEXT
- lcx_exception=>raise( lv_message ).
- ENDTRY.
+ lv_message = |Object type { is_item-obj_type } not supported, serialize|. "#EC NOTEXT
+ IF iv_native_only = abap_false.
+ TRY. " 2nd step, try looking for plugins
+ CREATE OBJECT ri_obj TYPE lcl_objects_bridge
+ EXPORTING
+ is_item = is_item.
+ CATCH cx_sy_create_object_error.
+ lcx_exception=>raise( lv_message ).
+ ENDTRY.
+ ELSE. " No native support? -> fail
+ lcx_exception=>raise( lv_message ).
+ ENDIF.
ENDTRY.
ENDMETHOD. "create_object
@@ -168,8 +169,9 @@ CLASS lcl_objects IMPLEMENTATION.
METHOD is_supported.
TRY.
- create_object( is_item = is_item
- iv_language = gc_english ).
+ create_object( is_item = is_item
+ iv_language = gc_english
+ iv_native_only = iv_native_only ).
rv_bool = abap_true.
CATCH lcx_exception.
rv_bool = abap_false.
diff --git a/src/zabapgit_page.prog.abap b/src/zabapgit_page.prog.abap
index bbdc4dd24..871464daf 100644
--- a/src/zabapgit_page.prog.abap
+++ b/src/zabapgit_page.prog.abap
@@ -277,11 +277,8 @@ CLASS lcl_gui_page_super IMPLEMENTATION.
_add 'function debugOutput(text, dstID) {'. "#EC NOTEXT
_add ' var stdout = document.getElementById(dstID || "stdout");'. "#EC NOTEXT
- _add ' if (stdout.innerHTML == "") {'. "#EC NOTEXT
- _add ' stdout.innerHTML = text;'. "#EC NOTEXT
- _add ' } else {'. "#EC NOTEXT
- _add ' stdout.innerHTML = stdout.innerHTML + "
" + text;'. "#EC NOTEXT
- _add ' }'. "#EC NOTEXT
+ _add ' var wrapped = "
" + text + "
";'. "#EC NOTEXT + _add ' stdout.innerHTML = stdout.innerHTML + wrapped;'. "#EC NOTEXT _add '}'. "#EC NOTEXT _add 'function submitForm(params, action) {'. "#EC NOTEXT diff --git a/src/zabapgit_page_debug.prog.abap b/src/zabapgit_page_debug.prog.abap index 460a89a5f..db2641f77 100644 --- a/src/zabapgit_page_debug.prog.abap +++ b/src/zabapgit_page_debug.prog.abap @@ -14,6 +14,8 @@ CLASS lcl_gui_page_debuginfo DEFINITION FINAL INHERITING FROM lcl_gui_page_super PRIVATE SECTION. METHODS render_debug_info RETURNING VALUE(ro_html) TYPE REF TO lcl_html_helper. + METHODS render_supported_object_types + RETURNING VALUE(rv_html) TYPE string. ENDCLASS. "lcl_gui_page_debuginfo @@ -25,7 +27,12 @@ CLASS lcl_gui_page_debuginfo IMPLEMENTATION. ro_html->add( header( io_include_style = styles( ) ) ). ro_html->add( title( 'DEBUG INFO' ) ). + + ro_html->add( 'abapGit version: { gc_abap_version }
| ). + ro_html->add( |XML version: { gc_xml_version }
| ). + ro_html->add( |GUI version: { lv_gui_version }
| ). ENDMETHOD. "render_debug_info + METHOD render_supported_object_types. + + DATA: lt_objects TYPE STANDARD TABLE OF ko100, + lv_list TYPE string, + ls_item TYPE ty_item. + + FIELD-SYMBOLS