Bsp download

hi experts,
i have a download button on clciking on that button the user gets 4 files in the application server.But now the requirement is on cliking on excel the user should be able to download it on local ,my question is shall i get 4 diffrent popus wheni download it on excel ,below is the code :
esixting scenario
CASE event_id.
  WHEN 'excel'.
Language  ****************
    IF application->tlang IS NOT INITIAL.
      WRITE sy-datum TO date1  YYMMDD.
      table = 'lang'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      len = STRLEN( title1 ).
      WRITE '.csv' TO title1+len(4).
      CALL FUNCTION 'FILE_GET_NAME'
        EXPORTING
          logical_filename = 'SAP_INTERFACE_NFSPC'
          parameter_1      = '0273/out/act'
          parameter_2      = title1
        IMPORTING
          file_name        = full_filename.
Open the file for editing
      OPEN DATASET full_filename FOR OUTPUT IN TEXT MODE
                             ENCODING DEFAULT.
      IF sy-subrc = 0.
        CLEAR wreturn.
        wreturn-type = 'S'.
        wreturn-message = 'Successfully created Language File'.
        APPEND wreturn TO return.
      ELSE.
        CLEAR wreturn.
        wreturn-type = 'E'.
        wreturn-message = 'Failed to create Language File'.
        APPEND wreturn TO return.
      ENDIF.
      LOOP AT application->tlang INTO wlang.
        g10c-prod = config.
        g10c-lang = wlang-mvgr1.
        TRANSFER g10c TO full_filename.
      ENDLOOP.
      CLOSE DATASET full_filename .
      CLEAR g10c.
    ENDIF.
Metric ******************
    IF tmp_metric IS NOT INITIAL.
      table = 'metric'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      len = STRLEN( title1 ).
      WRITE '.csv' TO title1+len(4).
      CALL FUNCTION 'FILE_GET_NAME'
        EXPORTING
          logical_filename = 'SAP_INTERFACE_NFSPC'
          parameter_1      = '0273/out/act'
          parameter_2      = title1
        IMPORTING
          file_name        = full_filename.
open the file for editing
      OPEN DATASET full_filename FOR OUTPUT IN TEXT MODE
                             ENCODING DEFAULT.
      IF sy-subrc = 0.
        CLEAR wreturn.
        wreturn-type = 'S'.
        wreturn-message = 'Successfully created Metric File'.
        APPEND wreturn TO return.
      ELSE.
        CLEAR wreturn.
        wreturn-type = 'E'.
        wreturn-message = 'Failed to create Metric File'.
        APPEND wreturn TO return.
      ENDIF.
      CLEAR wmetric.
      LOOP AT tmp_metric INTO wmetric.
        g10c-prod = config.
        g10c-lang = wmetric-description.
        TRANSFER g10c TO full_filename.
      ENDLOOP.
      CLOSE DATASET full_filename .
      CLEAR g10c.
    ENDIF.
Server Class ******************
    IF tmp_tsclass IS NOT INITIAL.
      table = 'SrvrCls'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      len = STRLEN( title1 ).
      WRITE '.csv' TO title1+len(4).
      CALL FUNCTION 'FILE_GET_NAME'
        EXPORTING
          logical_filename = 'SAP_INTERFACE_NFSPC'
          parameter_1      = '0273/out/act'
          parameter_2      = title1
        IMPORTING
          file_name        = full_filename.
open the file for editing
      OPEN DATASET full_filename FOR OUTPUT IN TEXT MODE
                             ENCODING DEFAULT.
      IF sy-subrc = 0.
        CLEAR wreturn.
        wreturn-type = 'S'.
        wreturn-message = 'Successfully created Server Class File'.
        APPEND wreturn TO return.
      ELSE.
        CLEAR wreturn.
        wreturn-type = 'E'.
        wreturn-message = 'Failed to create Server Class File'.
        APPEND wreturn TO return.
      ENDIF.
      CLEAR wsclass.
      LOOP AT tmp_tsclass INTO wsclass.
        g10c-prod = config.
        g10c-lang = wsclass-description.
        TRANSFER g10c TO full_filename.
      ENDLOOP.
      CLOSE DATASET full_filename .
      CLEAR g10c.
    ENDIF.
Type ******************
    IF tmp_type IS NOT INITIAL.
      table = 'Type'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      len = STRLEN( title1 ).
      WRITE '.csv' TO title1+len(4).
      CALL FUNCTION 'FILE_GET_NAME'
        EXPORTING
          logical_filename = 'SAP_INTERFACE_NFSPC'
          parameter_1      = '0273/out/act'
          parameter_2      = title1
        IMPORTING
          file_name        = full_filename.
open the file for editing
      OPEN DATASET full_filename FOR OUTPUT IN TEXT MODE
                             ENCODING DEFAULT.
      IF sy-subrc = 0.
        CLEAR wreturn.
        wreturn-type = 'S'.
        wreturn-message = 'Successfully created Type File'.
        APPEND wreturn TO return.
      ELSE.
        CLEAR wreturn.
        wreturn-type = 'E'.
        wreturn-message = 'Failed to create Type File'.
        APPEND wreturn TO return.
      ENDIF.
      CLEAR wtype.
      LOOP AT tmp_type INTO wtype.
        g10c-prod = config.
        g10c-lang = wtype-description.
        TRANSFER g10c TO full_filename.
      ENDLOOP.
      CLOSE DATASET full_filename .
      CLEAR g10c.
    ENDIF.
Term ******************
    IF application->tterm IS NOT INITIAL.
      table = 'Term'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      len = STRLEN( title1 ).
      WRITE '.csv' TO title1+len(4).
      CALL FUNCTION 'FILE_GET_NAME'
        EXPORTING
          logical_filename = 'SAP_INTERFACE_NFSPC'
          parameter_1      = '0273/out/act'
          parameter_2      = title1
        IMPORTING
          file_name        = full_filename.
open the file for editing
      OPEN DATASET full_filename FOR OUTPUT IN TEXT MODE
                             ENCODING DEFAULT.
      IF sy-subrc = 0.
        CLEAR wreturn.
        wreturn-type = 'S'.
        wreturn-message = 'Successfully created Term File'.
        APPEND wreturn TO return.
      ELSE.
        CLEAR wreturn.
        wreturn-type = 'E'.
        wreturn-message = 'Failed to create Term File'.
        APPEND wreturn TO return.
      ENDIF.
      CLEAR wterm.
      LOOP AT application->tterm INTO wterm.
        g10c-prod = config.
        g10c-lang = wterm-description.
        TRANSFER g10c TO full_filename.
      ENDLOOP.
      CLOSE DATASET full_filename .
      CLEAR g10c.
cretes 4 diffrent files in the application server , i have implemented this :
IF application->tlang IS NOT INITIAL.
     WRITE sy-datum TO date1  YYMMDD.
      table = 'lang'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
LOOP AT application->tlang INTO wlang.
        g10c-prod = config.
        g10c-lang = wlang-mvgr1.
         concatenate
         output
         g10c-prod tab
         g10c-lang
       CL_ABAP_CHAR_UTILITIES=>CR_LF
        INTO output SEPARATED BY space.
clear  g10c.
endloop.
app_type = 'APPLICATION/MSEXCEL;charset=utf-16le'.
CALL FUNCTION 'SCMS_STRING_TO_XSTRING'
EXPORTING
text = output
mimetype = 'APPLICATION/MSEXCEL;charset=utf-16le'
IMPORTING
buffer = l_xstring.
CONCATENATE cl_abap_char_utilities=>byte_order_mark_little
l_xstring
INTO l_xstring IN BYTE MODE.
CALL METHOD cl_bsp_utility=>download
EXPORTING
object_s = l_xstring
content_type = app_type
content_disposition = 'attachment;filename=title1.xls'
response = mresponse
navigation = navigation.
endif.
Metric ******************
    IF tmp_metric IS NOT INITIAL.
      table = 'metric'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      CLEAR wmetric.
      LOOP AT tmp_metric INTO wmetric.
        g10c-prod = config.
        g10c-lang = wmetric-description.
       concatenate
         output
         g10c-prod tab
         g10c-lang
       CL_ABAP_CHAR_UTILITIES=>CR_LF
        INTO output SEPARATED BY space.
clear  g10c.
endloop.
app_type = 'APPLICATION/MSEXCEL;charset=utf-16le'.
CALL FUNCTION 'SCMS_STRING_TO_XSTRING'
EXPORTING
text = output
mimetype = 'APPLICATION/MSEXCEL;charset=utf-16le'
IMPORTING
buffer = l_xstring.
CONCATENATE cl_abap_char_utilities=>byte_order_mark_little
l_xstring
INTO l_xstring IN BYTE MODE.
CALL METHOD cl_bsp_utility=>download
EXPORTING
object_s = l_xstring
content_type = app_type
content_disposition = 'attachment;filename=title1.xls'
response = mresponse
navigation = navigation.
endif.
Server Class ******************
    IF tmp_tsclass IS NOT INITIAL.
      table = 'SrvrCls'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      CLEAR wsclass.
      LOOP AT tmp_tsclass INTO wsclass.
        g10c-prod = config.
        g10c-lang = wsclass-description.
      concatenate
         output
         g10c-prod tab
         g10c-lang
       CL_ABAP_CHAR_UTILITIES=>CR_LF
        INTO output SEPARATED BY space.
clear  g10c.
      ENDLOOP.
  app_type = 'APPLICATION/MSEXCEL;charset=utf-16le'.
CALL FUNCTION 'SCMS_STRING_TO_XSTRING'
EXPORTING
text = output
mimetype = 'APPLICATION/MSEXCEL;charset=utf-16le'
IMPORTING
buffer = l_xstring.
CONCATENATE cl_abap_char_utilities=>byte_order_mark_little
l_xstring
INTO l_xstring IN BYTE MODE.
CALL METHOD cl_bsp_utility=>download
EXPORTING
object_s = l_xstring
content_type = app_type
content_disposition = 'attachment;filename=title1.xls'
response = mresponse
navigation = navigation.
endif.
Type ******************
    IF tmp_type IS NOT INITIAL.
      table = 'Type'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      LOOP AT tmp_type INTO wtype.
        g10c-prod = config.
        g10c-lang = wtype-description.
      concatenate
         output
         g10c-prod tab
         g10c-lang
       CL_ABAP_CHAR_UTILITIES=>CR_LF
        INTO output SEPARATED BY space.
clear  g10c.
      ENDLOOP.
  app_type = 'APPLICATION/MSEXCEL;charset=utf-16le'.
CALL FUNCTION 'SCMS_STRING_TO_XSTRING'
EXPORTING
text = output
mimetype = 'APPLICATION/MSEXCEL;charset=utf-16le'
IMPORTING
buffer = l_xstring.
CONCATENATE cl_abap_char_utilities=>byte_order_mark_little
l_xstring
INTO l_xstring IN BYTE MODE.
CALL METHOD cl_bsp_utility=>download
EXPORTING
object_s = l_xstring
content_type = app_type
content_disposition = 'attachment;filename=title1.xls'
response = mresponse
navigation = navigation.
ENDIF.
Term ******************
    IF application->tterm IS NOT INITIAL.
      table = 'Term'.
      CONCATENATE   table
                    sy-uname+0(4)
                    date1+2(4)
                    sy-uzeit+0(4)
             INTO   title1.
      CLEAR wterm.
      LOOP AT application->tterm INTO wterm.
        g10c-prod = config.
        g10c-lang = wterm-description.
   concatenate
         output
         g10c-prod tab
         g10c-lang
       CL_ABAP_CHAR_UTILITIES=>CR_LF
        INTO output SEPARATED BY space.
clear  g10c.
      ENDLOOP.
  app_type = 'APPLICATION/MSEXCEL;charset=utf-16le'.
CALL FUNCTION 'SCMS_STRING_TO_XSTRING'
EXPORTING
text = output
mimetype = 'APPLICATION/MSEXCEL;charset=utf-16le'
IMPORTING
buffer = l_xstring.
CONCATENATE cl_abap_char_utilities=>byte_order_mark_little
l_xstring
INTO l_xstring IN BYTE MODE.
CALL METHOD cl_bsp_utility=>download
EXPORTING
object_s = l_xstring
content_type = app_type
content_disposition = 'attachment;filename=title1.xls'
response = mresponse
navigation = navigation.
ENDIF.
but i am getting only 1 pop ups.am not getting four pops i want 2 get 4 pop ups

modifying the subject line

Similar Messages

  • BSP - download xlsx(excel 2007) document - error

    Hi all,
    i have a requirement to download different types of documents saved in server. All MS office documents are downloading correctly. it is supporting .xls files but .xlsx files are beiong saved and opened but with empty data, when opened in text document, it shows unrecognized characters(corrupted data)
    i am using the  below code.
    1. FM to get the data in bianry format, file name and mome type.
    2. then....
        concatenate 'attachment;filename=' <filename> into lv_content_disposition_value .
        loop at <binary data> into LT_CONTENT_BIN.   " LT_CONTENT_BIN is of RAW(1022) type
          CONCATENATE xstr LT_CONTENT_BIN-line INTO xstr IN BYTE MODE.
        endloop.
        me->response->set_data( data = xstr ).
        me->response->set_header_field( name = 'Content-Type' value = lv_mimetype ).
        me->response->set_header_field(
           NAME  = 'content-disposition'
           VALUE = lv_content_disposition_value ).
        navigation->response_complete( ).
    the above code is written in Controller - do_request. no view is being called at the end. only the controller is available.
    this is of high priority.. so please respond quickly.
    thanks in advance.
    Ajay.

    Hi Guys,
    How did you solve the problem, as I am facing
    the same issue with 'SCMS_STRING_TO_XSTRING'
    in an existing custom BSP application while converting the string to a XLSX file.
    FM 'SCMS_STRING_TO_XSTRING'
    was working fine with XLS format but for XLSX format(Microsoft excel 2007) I am
    not able to open the file.
    I have tried with the MIMETYPE “application/vnd.openxmlformats-officedocument.spreadsheetml.sheet”
    but was not successful.
    Can you guys
    toss some light on this please!!!

  • Formating an excel file by BSP Download

    I have made a BSP application which can dowload file into an excel file.But now i have a requirement in which i have to format the excel file with colour and cell width.I have to colour the column  header of the excel file with some colours like blue,red etc.
    Please suggest me how we can achieve this?
    Thanks and regards,
    Manish Kumar

    Hi Manish,
    This can be achieved using javascirpts and active x objects. Check this wiki,
    http://wiki.sdn.sap.com/wiki/display/CRM/DownloaddatafromwebuitoExcelandPPT
    Regards,
    Arun

  • Re: Downloading BSP Code to PC for backup

    Hi,
    Is there any method or code to download BSP code to local PC? I found a link named SAPLINK but not sure how to use this.
    Please help me.
    Regards,
    Anshuman

    Hi,
    ABAP prog for downloading BSP application to PC:
    Selection Text:
    CHK_ATTR Attributes
    CHK_BSP DownLoad BSP
    CHK_CLS DownLoad Class
    CHK_CONT Controllers
    CHK_EVTS Events
    CHK_FRAG Page Fragments
    CHK_METH Methods
    CHK_PGFL Page with Flow Logic
    CHK_TYPE Types
    CHK_VIEW Views
    P_DIRCLS Folder Name
    P_DIRNAM Folder Name
    R_ALL All Components
    R_BSPALL All Components
    R_BSPPAR Partial Components
    R_PAR Partial Components
    S_BSPAPP BSP Application/s
    S_CLSNAM Class Name/s
    *& Report Z_UMA_BSP_DOWNLOAD
    report z_uma_bsp_download message-id zmsgcls line-size 180.
    * TABLES
    tables: seoclass,
    o2appl,
    o2pagcon.
    * TYPE-POOLS
    type-pools: seoo,seos,seor,seof,seot,seok,seop.
    * TYPE DEFINITIONS
    types: begin of t_class,
    clsname type seoclass-clsname, "Class Name
    descrip type seoclasstx-descript, "Class Description
    end of t_class.
    types: begin of t_component,
    clsname type seoclsname,
    cmpname type seocmpname,
    cmptype type seocmptype,
    mtdtype type seomtdtype,
    descrip type seodescr,
    end of t_component.
    types: begin of t_format,
    cmpname(30),
    decltyp(20),
    exposur(15),
    typtype(15),
    type(110),
    attval(110),
    desc(100),
    end of t_format.
    types: begin of t_format1,
    pad(4),
    sconame(30),
    decl(10),
    pass(20),
    optn(10),
    typtype(15),
    type(100),
    valu(100),
    desc(100),
    end of t_format1.
    types: begin of t_format2,
    pad(4),
    sconame(30),
    desc(100),
    end of t_format2.
    types: begin of t_mtd_compo,
    clsname type seoclsname,
    cmpname type seocmpname,
    sconame type seosconame,
    scotype type seoscotype,
    descrip type seodescr,
    end of t_mtd_compo.
    types: begin of t_bspappl,
    applname type o2applname,
    applclas type o2applclas,
    startpage type o2pageext,
    stateful type o2stateful,
    descrip type o2descr,
    end of t_bspappl.
    types: begin of t_pagdetl,
    applname type o2applname,
    pagekey type o2page,
    pagename type o2pageext,
    implclass type o2ctrcls,
    pagetype type o2pagtyp,
    controllerurl type o2pageext,
    lifetime type o2lifetime,
    state type o2pagstate,
    is_error_page type o2errpag,
    error_page type o2pageext,
    browser_cache type o2bcache,
    server_cache type o2scache,
    author type cnam,
    createdon type rdir_cdate,
    changedby type unam,
    changedon type rdir_udate,
    end of t_pagdetl.
    types: begin of t_pagcon,
    applname type o2applname,
    pagekey type o2page,
    objtype type o2objtype,
    version type r3state,
    end of t_pagcon.
    types: begin of t_pagedata,
    content type o2pageline_table,
    ev_handler type o2pagevh_tabletype,
    parameters type o2pagpar_tabletype,
    typesource type rswsourcet,
    xml_source type xstring,
    otr_guids type bsp_guids,
    html_pool type string,
    end of t_pagedata.
    types : begin of t_scr_out,
    appname type string,
    component type string,
    path type string,
    status type string ,
    etype type c,
    end of t_scr_out.
    * DATA DECLARATIONS
    data: v_langu type sy-langu,
    v_filename type string,
    x_format type t_format,
    x_format1 type t_format1,
    x_format2 type t_format2,
    v_lines type i,
    x_mtdkey type seocpdkey,
    x_transport type trkey,
    v_sourcename type programm,
    v_repid type sy-repid,
    v_dynnr type sy-dynnr,
    v_uzeit type sy-uzeit,
    v_filestr type string,
    v_datum type sy-datum,
    r_temp_all type c,
    v_cnt_cls type string.
    INTERNAL TABLE DECLARTIONS
    data: it_class type standard table of t_class with header line,
    it_compo type standard table of t_component with header line,
    it_mtd_compo type standard table of t_mtd_compo with header line,
    it_attributes type seoo_attributes_r,
    it_methods type seoo_methods_r,
    it_events type seoo_events_r,
    it_types type seoo_types_r,
    it_parameters type seos_parameters_r,
    it_exceps type seos_exceptions_r,
    it_implementings type seor_implementings_r,
    it_redefinitions type seor_redefinitions_r,
    it_friendships type seof_friendships_r,
    it_typepusages type seot_typepusages_r,
    it_clsdeferrds type seot_clsdeferrds_r,
    it_intdeferrds type seot_intdeferrds_r,
    it_explore_inheritance type seok_cls_typeinfos,
    it_explore_implementings type seok_int_typeinfos,
    it_aliases type seoo_aliases_r,
    it_bspappl type standard table of t_bspappl with header line,
    it_pagdetl type standard table of t_pagdetl with header line,
    it_pagcon type standard table of t_pagcon with header line,
    it_source type t_pagedata,
    it_scr_out type standard table of t_scr_out with header line,
    it_data(400) occurs 0 with header line,
    wa_source type line of o2pageline_table,
    wa_pagecon_key type o2pconkey.
    * CONSTANTS DECLARATIONS
    constants: gc_cmp_attr type n value 0, "COMPONENT ATTRIBUTE
    gc_cmp_meth type n value 1, "COMPONENT METHOD
    gc_cmp_evnt type n value 2, "COMPONENT EVENT
    gc_cmp_type type n value 3, "COMPONENT TYPE
    gc_mtd_meth type n value 0, "METHOD METHOD
    gc_mtd_evnt type n value 1, "METHOD EVENT
    gc_mtd_cons type n value 2, "METHOD CONSTRUCTOR
    gc_mtd_dest type n value 3, "METHOD DESTRUCTOR
    gc_mtd_getm type n value 4, "METHOD GET
    gc_mtd_setm type n value 5, "METHOD SET
    gc_sco_para type n value 0, "SCOPE PARAMETER
    gc_sco_excp type n value 1, "SCOPE EXCEPTION
    gc_exp_priv type n value 0, "EXPOSURE PRIVATE
    gc_exp_prot type n value 1, "EXPOSURE PROTECTED
    gc_exp_publ type n value 2, "EXPOSURE PUBLIC
    gc_typ_like type n value 0, "TYPE LIKE
    gc_typ_type type n value 1, "TYPE TYPE
    gc_typ_otyp type n value 2, "TYPE OBJECT TYPE
    gc_typ_tref type n value 3, "TYPE TYPE REF TO
    gc_atr_inst type n value 0, "ATTRIBUTE INSTANCE
    gc_atr_stat type n value 1, "ATTRIBUTE STATIC
    gc_atr_cnst type n value 2, "ATTRIBUTE CONSTANT
    gc_par_impo type n value 0, "PARAMETER IMPORTING
    gc_par_expo type n value 1, "PARAMETER EXPORTING
    gc_par_chng type n value 2, "PARAMETER CHANGING
    gc_par_retn type n value 3, "PARAMETER RETURNING
    gc_pas_valu type n value 0, "PARAMETER PASS BY VALUE
    gc_pas_refr type n value 1, "PARAMETER CALL BY REFERENCE
    gc_yes type c value 'X',
    gc_no type c value space,
    gc_tab(8) type c value ' ',
    gc_bsp_ctrl type o2pagtyp value 'C',
    gc_bsp_pgfr type o2pagtyp value 'X',
    gc_bsp_pgfl type o2pagtyp value space,
    gc_bsp_view type o2pagtyp value 'V',
    gc_lft_upgc type c value space,
    gc_lft_requ type c value '1',
    gc_lft_sess type c value '2'.
    * SELECTION SCREENS
    *Selection Screen for the Options
    selection-screen : begin of block b_main with frame title text-009.
    parameters : chk_bsp as checkbox user-command ucom,
    chk_cls as checkbox user-command ucom1.
    selection-screen : end of block b_main.
    *Selection Screen for the BSP Application
    selection-screen : begin of block b_bsp1 with frame title text-005.
    selection-screen : begin of block b_bsp2 with frame title text-006.
    select-options : s_bspapp for o2appl-applname no intervals modif id bsp.
    parameters : p_dirnam type rlgrap-filename default 'C:\' modif id bsp.
    selection-screen : end of block b_bsp2.
    selection-screen : begin of block b_bsp3 with frame title text-007.
    parameters : r_bspall radiobutton group rad1 user-command u1 modif id bsp default 'X',
    r_bsppar radiobutton group rad1 modif id bsp.
    selection-screen : begin of block b_bsp4 with frame title text-008.
    parameters : chk_cont as checkbox modif id bs1,
    chk_view as checkbox modif id bs1,
    chk_pgfl as checkbox modif id bs1,
    chk_frag as checkbox modif id bs1.
    selection-screen : end of block b_bsp4.
    selection-screen : end of block b_bsp3.
    selection-screen : end of block b_bsp1.
    *Selection Screen for Class Download
    selection-screen : begin of block b1 with frame title text-001.
    selection-screen : begin of block b2 with frame title text-002.
    select-options : s_clsnam for seoclass-clsname no intervals modif id cls.
    parameters : p_dircls like rlgrap-filename default 'C:\' modif id cls.
    selection-screen : end of block b2.
    selection-screen : begin of block b3 with frame title text-003.
    parameters : r_all radiobutton group rbsp user-command u2 modif id cls default 'X',
    r_par radiobutton group rbsp modif id cls.
    selection-screen : begin of block b4 with frame title text-004.
    parameters : chk_attr as checkbox modif id cl1,
    chk_meth as checkbox modif id cl1,
    chk_evts as checkbox modif id cl1,
    chk_type as checkbox modif id cl1.
    selection-screen : end of block b4.
    selection-screen : end of block b3.
    selection-screen : end of block b1.
    * INTIALIZATION
    initialization.
    v_repid = sy-repid.
    v_dynnr = sy-dynnr.
    v_langu = sy-langu.
    * AT SELECTION-SCREEN OUTPUT
    at selection-screen output.
    loop at screen.
    if chk_bsp = 'X'.
    if screen-group1 = 'BSP' or screen-group1 = 'BS1'.
    screen-active = 1.
    endif.
    else.
    if screen-group1 = 'BSP' or screen-group1 = 'BS1' .
    screen-active = 0.
    endif.
    endif.
    if r_bspall = 'X'.
    if screen-group1 = 'BS1'.
    screen-active = 0.
    endif.
    else.
    if screen-group1 = 'BS1'.
    screen-active = 1.
    endif.
    endif.
    modify screen.
    endloop.
    loop at screen.
    if chk_cls = 'X'.
    if screen-group1 = 'CLS' or screen-group1 = 'cl1'.
    screen-active = 1.
    endif.
    else.
    if screen-group1 = 'CLS' or screen-group1 = 'cl1'.
    screen-active = 0.
    endif.
    endif.
    if r_all = 'X'.
    if screen-group1 = 'CL1'.
    screen-active = 0.
    endif.
    else.
    if screen-group1 = 'CL1'.
    screen-active = 1.
    endif.
    endif.
    modify screen.
    endloop.
    * AT SELECTION-SCREEN
    at selection-screen.
    * START OF SELECTION
    start-of-selection.
    * If the user selected BSP check box then we need to do down load the BSP application
    if chk_cls is initial and
    chk_bsp is initial.
    message i001 with 'Select any download option'(007).
    exit.
    endif.
    if chk_bsp = 'X'.
    refresh it_bspappl.
    clear it_bspappl.
    if s_bspapp is initial.
    set pf-status'AA'.
    message i002 with 'Enter BSP Application Names'(010).
    exit.
    endif.
    * Check the directory name is entered or not
    if p_dirnam is initial.
    message i004 with 'Enter Directory name for BSP Download'(012).
    exit.
    else.
    if r_bspall = 'X'.
    clear : chk_cont,chk_view,chk_pgfl,chk_frag.
    endif.
    select a~applname
    a~applclas
    a~startpage
    a~stateful
    b~text into table it_bspappl
    from o2appl as a inner join o2applt as b
    on a~applname = b~applname
    where a~applname in s_bspapp and
    a~version = 'A' and
    b~langu = v_langu.
    * Check we got any entries in the class internal table
    clear v_lines.
    describe table it_bspappl lines v_lines.
    if v_lines > 0.
    loop at it_bspappl.
    perform save_bspappl_details using it_bspappl.
    perform get_bspappl_compo using it_bspappl.
    endloop.
    else.
    write:/ 'Enter Valid BSP Application Names'.
    endif.
    endif.
    endif.
    * If the user selected class check box then we need to do down load the class
    if chk_cls = 'X'.
    refresh it_class.
    clear it_class.
    clear r_temp_all.
    * Check Class name is empty or not
    if s_clsnam is initial.
    message i003 with 'Enter Class Names'(011).
    exit.
    endif.
    * Check the directory name is entered or not
    if p_dircls is initial.
    message i000 with 'Enter Directory name for Class Download'(008).
    exit.
    else.
    * if user selected All Components in Class Down Load
    * then clear all the check box variables
    move r_all to r_temp_all.
    if r_temp_all = 'X'.
    clear: chk_attr,chk_meth,chk_evts,chk_type.
    endif.
    * get the class name and Class Description from the table SEOCLASS
    * for all the classes which user entered in selection screen based on
    * the system language
    select a~clsname b~descript into table it_class
    from seoclass as a left outer join seoclasstx as b
    on a~clsname = b~clsname and
    b~langu = v_langu
    where a~clsname in s_clsnam.
    * Check we got any entries in the class internal table
    clear v_lines.
    describe table it_class lines v_lines.
    * if you got any enties in class interbnal table then we need to
    * get the other details about that class
    if v_lines > 0.
    perform add_slash_4dir changing p_dircls.
    perform check_dir_exists using p_dircls.
    loop at it_class.
    perform get_class_details using it_class-clsname 'X' ' '.
    endloop.
    else.
    write:/ 'PLEASE ENTER VALID CLASS NAMES'.
    endif.
    endif.
    endif.
    * END OF SELECTION
    end-of-selection.
    write: /1(25) 'Application Name',
    26(25) 'Component Name',
    52(50) 'Download Path',
    102(50) 'ErrorSuccess Message'.
    write:/ sy-uline.
    loop at it_scr_out.
    write:/1(25) it_scr_out-appname,
    26(25) it_scr_out-component,
    52(50) it_scr_out-path,
    102(50) it_scr_out-status.
    endloop.
    *& Form GET_CLASS_DETAILS
    * used to get the other details of the class
    form get_class_details using p_clsname p_check p_filename.
    * Data Declarations
    data: x_class type vseoclass,
    x_inheritance type vseoextend,
    x_seoclskey type seoclskey,
    x_attributes type line of seoo_attributes_r,
    x_methods type line of seoo_methods_r,
    x_events type line of seoo_events_r,
    x_types type line of seoo_types_r,
    x_parameters type line of seos_parameters_r,
    x_exceps type line of seos_exceptions_r,
    x_implementings type line of seor_implementings_r,
    x_redefinitions type line of seor_redefinitions_r,
    x_friendships type line of seof_friendships_r,
    x_typepusages type line of seot_typepusages_r,
    x_clsdeferrds type line of seot_clsdeferrds_r,
    x_intdeferrds type line of seot_intdeferrds_r,
    x_explore_inheritance type line of seok_cls_typeinfos,
    x_explore_implementings type line of seok_int_typeinfos,
    x_aliases type line of seoo_aliases_r.
    * REFRESH & CLEAR ALL THE VARIABLES.
    refresh: it_attributes,it_methods,it_events,it_types,it_parameters,
    it_exceps,it_implementings,it_redefinitions,it_friendships,
    it_typepusages,it_clsdeferrds,it_intdeferrds,it_data,
    it_explore_inheritance,it_explore_implementings,it_aliases.
    clear : it_attributes,it_methods,it_events,it_types,it_parameters,
    it_exceps,it_implementings,it_redefinitions,it_friendships,
    it_typepusages,it_clsdeferrds,it_intdeferrds,it_data,
    it_explore_inheritance,it_explore_implementings,it_aliases.
    clear : x_attributes,x_methods,x_events,x_types,x_parameters,
    x_exceps,x_implementings,x_redefinitions,x_friendships,
    x_typepusages,x_clsdeferrds,x_intdeferrds,
    x_explore_inheritance,x_explore_implementings,x_aliases,
    x_class,x_inheritance,x_seoclskey.
    * SET THE CLASS NAME TO THE STRUCTURE
    x_seoclskey-clsname = p_clsname.
    call function 'SEO_CLASS_TYPEINFO_GET'
    exporting
    clskey = x_seoclskey
    importing
    class = x_class
    attributes = it_attributes
    methods = it_methods
    events = it_events
    types = it_types
    parameters = it_parameters
    exceps = it_exceps
    implementings = it_implementings
    inheritance = x_inheritance
    redefinitions = it_redefinitions
    friendships = it_friendships
    typepusages = it_typepusages
    clsdeferrds = it_clsdeferrds
    intdeferrds = it_intdeferrds
    explore_inheritance = it_explore_inheritance
    explore_implementings = it_explore_implementings
    aliases = it_aliases
    exceptions
    not_existing = 1
    is_interface = 2
    model_only = 3
    others = 4.
    if sy-subrc <> 0.
    it_scr_out-component = p_clsname.
    it_scr_out-status = 'ERROR'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    * DOWNLOAD CLASS INFORMATION
    perform download_class_info using x_class.
    * DOWNLOAD INHERITANCE INFORMATION
    perform download_class_inht using x_inheritance.
    * DOWNLOAD CLASS IMPLEMENTATION
    perform download_class_otherdetails using p_clsname seop_ext_class_locals_imp.
    * DOWNLOAD CLASS TYPES
    perform download_class_otherdetails using p_clsname seop_ext_class_locals_def.
    DOWNLOAD CLASS MACROS
    perform download_class_otherdetails using p_clsname seop_ext_class_macros.
    DOWNLOAD CLASS ATTRIBUTES
    if r_temp_all = 'X' or chk_attr = 'X'.
    perform download_class_attr tables it_attributes.
    endif.
    DOWNLOAD CLASS METHODS
    if r_temp_all = 'X' or chk_meth = 'X'.
    perform download_class_meth tables it_methods
    it_parameters
    it_exceps.
    endif.
    Interface Implementations.
    perform download_class_implementation tables it_explore_implementings.
    DOWNLOAD CLASS EVENTS.
    if r_temp_all = 'X' or chk_evts = 'X'.
    perform download_class_evts.
    endif.
    * DOWNLOAD CLASS TYPE GROUPS.
    perform download_class_type_groups.
    * DOWNLOAD INTERNAL TYPES
    if r_temp_all = 'X' or chk_type = 'X'.
    perform download_class_internal_types.
    endif.
    if p_check = 'X'.
    * DOWNLOAD CLASS DEFINITION
    perform download_classdef using p_filename.
    else.
    * while downloading the bsp we need to pass the directory and
    * class name to the function module so the file will create
    perform download_class using p_check.
    endif.
    endif.
    endform. " GET_CLASS_DETAILS
    *& Form DOWNLOAD_CLASS_INFO
    * used to download the class information
    form download_class_info using p_x_class structure vseoclass.
    it_data = p_x_class-clsname.
    append it_data.
    clear it_data.
    it_data = p_x_class-descript.
    append it_data.
    clear it_data.
    endform. " DOWNLOAD_CLASS_INFO
    *& Form DOWNLOAD_CLASS_INHT
    * used to download the inheritance
    form download_class_inht using p_x_inheritance structure vseoextend.
    if not p_x_inheritance-refclsname is initial.
    concatenate 'INHERITED FROM: ' p_x_inheritance-refclsname into it_data.
    append it_data.
    clear it_data.
    endif.
    endform. " DOWNLOAD_CLASS_INHT
    *& Form DOWNLOAD_CLASS_ATTR
    * text
    form download_class_attr tables p_it_attr type seoo_attributes_r.
    data: x_attributes type line of seoo_attributes_r.
    it_data = '*********************************************************'.
    append it_data.
    clear it_data.
    it_data = 'ATTRIBUTES'.
    append it_data.
    clear it_data.
    it_data = '-----------'.
    append it_data.
    clear it_data.
    loop at p_it_attr into x_attributes.
    clear x_format.
    * ATTRIBUTE NAME
    x_format-cmpname = x_attributes-cmpname.
    * ATTRIBUTE DECLARATION LEVEL
    case x_attributes-attdecltyp.
    when gc_atr_inst.
    x_format-decltyp = 'INSTANCE ATTRIBUTE'.
    when gc_atr_stat.
    x_format-decltyp = 'STATIC ATTRIBUTE'.
    when gc_atr_cnst.
    x_format-decltyp = 'CONSTANT ATTRIBUTE'.
    endcase.
    * ATTRIBUTE EXPOSURE
    case x_attributes-exposure.
    when gc_exp_priv.
    x_format-exposur = 'PRIVATE'.
    when gc_exp_publ.
    x_format-exposur = 'PUBLIC'.
    when gc_exp_prot.
    x_format-exposur = 'PROTECTED'.
    endcase.
    * ATTRIBUTE TYPTYPE
    case x_attributes-typtype.
    when gc_typ_like.
    x_format-typtype = 'LIKE'.
    when gc_typ_type.
    x_format-typtype = 'TYPE'.
    when gc_typ_otyp.
    x_format-typtype = 'OBJECT TYPE'.
    when gc_typ_tref.
    x_format-typtype = 'TYPE REF TO'.
    endcase.
    * ATTRIBUTE REFERNCE TYPE
    x_format-type = x_attributes-type.
    * ATTRIBUTE INITIAL VALUE
    x_format-attval = x_attributes-attvalue.
    * ATTRIBUTE DESCRIPTION
    x_format-desc = x_attributes-descript.
    move x_format to it_data.
    append it_data.
    clear it_data.
    endloop.
    it_data = '*********************************************************'.
    append it_data.
    clear it_data.
    endform. " DOWNLOAD_CLASS_ATTR
    *& Form DOWNLOAD_CLASS_METH
    * used to download the methods of the class
    form download_class_meth tables p_it_meth type seoo_methods_r
    p_it_parm type seos_parameters_r
    p_it_excp type seos_exceptions_r.
    data: x_methods type line of seoo_methods_r,
    x_params type line of seos_parameters_r,
    x_exceps type line of seos_exceptions_r.
    clear: x_methods,x_params,x_exceps.
    it_data = 'METHODS'.
    append it_data.
    clear it_data.
    it_data = '-------'.
    append it_data.
    clear it_data.
    loop at p_it_meth into x_methods.
    clear: x_format.
    * METHOD NAME
    x_format-cmpname = x_methods-cmpname.
    * METHOD DECLARATION TYPE
    case x_methods-mtddecltyp.
    when gc_atr_inst.
    x_format-decltyp = 'INSTANCE METHOD'.
    when gc_atr_stat.
    x_format-decltyp = 'STATIC METHOD'.
    endcase.
    * METHOD EXPOSURE
    case x_methods-exposure.
    when gc_exp_priv.
    x_format-exposur = 'PRIVATE'.
    when gc_exp_publ.
    x_format-exposur = 'PUBLIC'.
    when gc_exp_prot.
    x_format-exposur = 'PROTECTED'.
    endcase.
    * METHOD DESCRIPTION.
    x_format-desc = x_methods-descript.
    move x_format to it_data.
    append it_data.
    clear it_data.
    * DOWNLOAD METHOD PARAMETERS
    perform download_method_params tables it_parameters
    using x_methods-cmpname.
    * DOWNLOAD METHOD EXCEPTIONS
    perform download_method_exceps tables it_exceps
    using x_methods-cmpname.
    * DOWNLOAD METHOD SOURCE
    perform download_method_source using it_class-clsname
    x_methods-cmpname.
    endloop.
    * DOWNLOAD RE-DEFINED METHODS IF ANY
    perform download_redef_methods.
    endform. " DOWNLOAD_CLASS_METH
    *& Form DOWNLOAD_METHOD_PARAMS
    * used to download the method parameters
    form download_method_params tables p_it_params type seos_parameters_r
    using p_cmpname.
    data: x_parameters type line of seos_parameters_r.
    clear: x_parameters.
    it_data = '^^^^PARAMETERS'.
    append it_data.
    clear it_data.
    loop at p_it_params into x_parameters where cmpname = p_cmpname.
    clear: x_format1.
    * METHOD PARAMETER NAME
    x_format1-sconame = x_parameters-sconame.
    * METHOD PARAMETER DECLARATION TYPE
    case x_parameters-pardecltyp.
    when gc_par_impo.
    x_format1-decl = 'IMPORTING'.
    when gc_par_expo.
    x_format1-decl = 'EXPORTING'.
    when gc_par_chng.
    x_format1-decl = 'CHANGING'.
    when gc_par_retn.
    x_format1-decl = 'RETURNING'.
    endcase.
    * METHOD PARAMETERS PASSING TYOE
    case x_parameters-parpasstyp.
    when gc_pas_valu.
    x_format1-pass = 'PASS BY VALUE'.
    when gc_pas_refr.
    x_format1-pass = 'PASS BY REFERENCE'.
    endcase.
    * METHOD PARAMETER TYPTYPE
    case x_parameters-typtype.
    when gc_typ_like.
    x_format1-typtype = 'LIKE'.
    when gc_typ_type.
    x_format1-typtype = 'TYPE'.
    when gc_typ_otyp.
    x_format1-typtype = 'OBJECT TYPE'.
    when gc_typ_tref.
    x_format1-typtype = 'TYPE REF TO'.
    endcase.
    * METHOD PARAMETER OPTIONAL/MANDATORY
    case x_parameters-paroptionl.
    when gc_yes.
    x_format1-optn = 'OPTIONAL'.
    when gc_no.
    x_format1-optn = 'MANDATORY'.
    endcase.
    * METHOD PARAMETER TYPE
    x_format1-type = x_parameters-type.
    * METHOD PARAMETER INITIAL VALUE
    x_format1-valu = x_parameters-parvalue.
    * METHOD PARAMETER DESCRIPTION
    x_format1-desc = x_parameters-descript.
    move x_format1 to it_data.
    append it_data.
    clear it_data.
    endloop.
    endform. " DOWNLOAD_METHOD_PARAMS
    *& Form DOWNLOAD_METHOD_EXCEPS
    * used to download the Exceptions of methods
    form download_method_exceps tables p_it_exceps type seos_exceptions_r
    using p_cmpname.
    data: x_exceps type line of seos_exceptions_r.
    clear: x_exceps.
    it_data = '^^^^EXCEPTION'.
    append it_data.
    loop at p_it_exceps into x_exceps where cmpname = p_cmpname.
    clear x_format2.
    * METHOD EXCEPTION NAME
    x_format2-sconame = x_exceps-sconame.
    * METHOD EXCEPTION DESCRIPTION
    x_format2-desc = x_exceps-descript.
    move x_format2 to it_data.
    append it_data.
    clear it_data.
    endloop.
    endform. " DOWNLOAD_METHOD_EXCEPS
    *& Form DOWNLOAD_METHOD_SOURCE
    * text
    form download_method_source using p_clsname
    p_cmpname.
    data : x_mtdkey type seocpdkey,
    x_source type line of seop_source,
    it_source type seop_source.
    refresh: it_source.
    clear : it_source,x_source,x_mtdkey.
    x_mtdkey-clsname = p_clsname.
    x_mtdkey-cpdname = p_cmpname.
    call function 'SEO_METHOD_GET_SOURCE'
    exporting
    mtdkey = x_mtdkey
    importing
    source = it_source
    exceptions
    _internal_method_not_existing = 1
    _internal_class_not_existing = 2
    others = 3.
    if sy-subrc <> 0.
    it_scr_out-component = p_cmpname.
    it_scr_out-status = ' FAILED '.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    loop at it_source into x_source.
    move x_source to it_data.
    append it_data.
    clear it_data.
    endloop.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    endif.
    endform. " DOWNLOAD_METHOD_SOURCE
    *& Form DOWNLOAD_REDEF_METHODS
    * used to download any redefined methods if any
    form download_redef_methods .
    data: x_redef type line of seor_redefinitions_r.
    loop at it_redefinitions into x_redef.
    * DOWNLOAD METHOD SOURCE
    perform download_method_source using it_class-clsname
    x_redef-mtdname.
    endloop.
    endform. " DOWNLOAD_REDEF_METHODS
    *& Form DOWNLOAD_CLASS_EVTS
    * used to download the class events types
    form download_class_evts .
    data: x_events type line of seoo_events_r.
    it_data = 'EVENTS'.
    append it_data.
    clear it_data.
    it_data = '-------'.
    append it_data.
    clear it_data.
    loop at it_events into x_events.
    clear: x_format.
    * EVENT NAME
    x_format-cmpname = x_events-cmpname.
    * METHOD DECLARATION TYPE
    case x_events-evtdecltyp.
    when gc_atr_inst.
    x_format-decltyp = 'INSTANCE EVENT'.
    when gc_atr_stat.
    x_format-decltyp = 'STATIC EVENT'.
    endcase.
    * EVENT EXPSOURE.
    case x_events-exposure.
    when gc_exp_priv.
    x_format-exposur = 'PRIVATE'.
    when gc_exp_publ.
    x_format-exposur = 'PUBLIC'.
    when gc_exp_prot.
    x_format-exposur = 'PROTECTED'.
    endcase.
    * EVENT DESCRIPTION
    x_format-desc = x_events-descript.
    append x_format to it_data.
    clear it_data.
    endloop.
    endform. " DOWNLOAD_CLASS_EVTS
    *& Form DOWNLOAD_CLASS_TYPE_GROUPS
    * used to download the type groups
    form download_class_type_groups .
    data: x_typep type line of seot_typepusages_r.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    it_data = 'TYPE-GROUPS'.
    append it_data.
    clear it_data.
    it_data = '------------'.
    append it_data.
    clear it_data.
    loop at it_typepusages into x_typep.
    it_data = x_typep-typegroup.
    append it_data.
    clear it_data.
    endloop.
    endform. " DOWNLOAD_CLASS_TYPE_GROUPS
    *& Form DOWNLOAD_CLASS_INTERNAL_TYPES
    * used to download the class type internal type definitions
    form download_class_internal_types .
    data: x_types type line of seoo_types_r.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    it_data = 'INTERNAL TYPES'.
    append it_data.
    clear it_data.
    it_data = '------------'.
    append it_data.
    clear it_data.
    loop at it_types into x_types.
    clear: x_format.
    * TYPE NAME
    x_format-cmpname = x_types-cmpname.
    * TYPE EXPSOURE.
    case x_types-exposure.
    when gc_exp_priv.
    x_format-exposur = 'PRIVATE'.
    when gc_exp_publ.
    x_format-exposur = 'PUBLIC'.
    when gc_exp_prot.
    x_format-exposur = 'PROTECTED'.
    endcase.
    * TYPTYPE
    case x_types-typtype.
    when gc_typ_like.
    x_format-typtype = 'LIKE'.
    when gc_typ_type.
    x_format-typtype = 'TYPE'.
    when gc_typ_otyp.
    x_format-typtype = 'OBJECT TYPE'.
    when gc_typ_tref.
    x_format-typtype = 'TYPE REF TO'.
    endcase.
    * TYPE
    x_format-type = x_types-type.
    * DESCRIPTION
    x_format-desc = x_types-descript.
    append x_format to it_data.
    clear it_data.
    endloop.
    endform. " DOWNLOAD_CLASS_INTERNAL_TYPES
    *& Form DOWNLOAD_CLASSDEF
    * used to download total class to the text file
    form download_classdef using p_p_filename.
    data: lv_filename type string.
    if p_p_filename = ' '.
    v_filename = it_class-clsname.
    concatenate p_dircls v_filename '.txt' into lv_filename.
    else.
    move p_p_filename to lv_filename.
    concatenate lv_filename '.txt' into lv_filename.
    endif.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_filename
    tables
    data_tab = it_data
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    it_scr_out-component = it_class-clsname.
    it_scr_out-path = lv_filename.
    it_scr_out-status = 'FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_scr_out-component = it_class-clsname.
    it_scr_out-path = lv_filename.
    it_scr_out-status = 'SUCCESSFULL'.
    it_scr_out-etype = 'S'.
    append it_scr_out.
    clear it_scr_out.
    endif.
    endform. " DOWNLOAD_CLASSDEF
    *& Form SAVE_BSPAPPL_DETAILS
    * Used to Save the Bsp Application Details
    form save_bspappl_details using p_it_bspappl type t_bspappl.
    data: lv_filestr type string,
    lv_filenam type rlgrap-filename.
    refresh it_data.
    clear: it_data,lv_filestr.
    concatenate 'APPLICATION NAME: ' p_it_bspappl-applname into it_data.
    append it_data.
    concatenate 'DESCRIPTION: ' p_it_bspappl-descrip into it_data.
    append it_data.
    concatenate 'APPLICATION CLASS: ' p_it_bspappl-applclas into it_data.
    append it_data.
    concatenate 'START PAGE: ' p_it_bspappl-startpage into it_data.
    append it_data.
    if p_it_bspappl-stateful is initial.
    it_data = 'STATELESS APPLICATION'.
    else.
    it_data = 'STATEFUL APPLICATION'.
    endif.
    append it_data.
    perform add_slash_4dir changing p_dirnam.
    concatenate p_dirnam it_bspappl-applname '\' into lv_filenam.
    move lv_filenam to lv_filestr.
    call function 'GUI_CREATE_DIRECTORY'
    exporting
    dirname = lv_filenam
    exceptions
    failed = 1
    others = 2.
    move lv_filestr to v_filestr.
    concatenate lv_filestr it_bspappl-applname '.TXT' into lv_filestr.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_filestr
    tables
    data_tab = it_data
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    it_scr_out-appname = p_it_bspappl-applname.
    it_scr_out-component = 'Application Details'.
    it_scr_out-path = lv_filestr.
    it_scr_out-status = 'FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_scr_out-appname = p_it_bspappl-applname.
    it_scr_out-component = 'Application Details'.
    it_scr_out-path = lv_filestr.
    it_scr_out-status = 'SUCCESSFULL'.
    it_scr_out-etype = 'S'.
    append it_scr_out.
    clear it_scr_out.
    endif.
    endform. " SAVE_BSPAPPL_DETAILS
    *& Form ADD_SLASH_4DIR
    * used to add '/' after the direcory if necessary
    form add_slash_4dir changing p_dirnamcls.
    data: lv_tempvar(1),
    lv_length type i.
    lv_length = strlen( p_dirnamcls ).
    lv_length = lv_length - 1.
    lv_tempvar = p_dirnam+lv_length(1).
    if lv_tempvar <> '\'.
    concatenate p_dirnamcls '\' into p_dirnamcls.
    endif.
    endform. " ADD_SLASH_4DIR
    *& Form CHECK_DIR_EXISTS
    * Check the Directory Exists or Not
    form check_dir_exists using p_dirnamcls.
    data: lv_filename type rlgrap-filename,
    lv_filestr type string,
    it_data(10) occurs 0 with header line.
    clear: lv_filename.
    v_datum = sy-datum.
    v_uzeit = sy-uzeit.
    concatenate p_dirnamcls 'TESTFIL_09087' '.TXT' into lv_filename.
    move lv_filename to lv_filestr.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_filestr
    tables
    data_tab = it_data
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    message e901(zt) with 'INVALID DIRECTORY'.
    endif.
    endform. " CHECK_DIR_EXISTS
    *& Form GET_BSPAPPL_COMPO
    * To get the BSP Applciation Component Details
    form get_bspappl_compo using p_it_bspappl type t_bspappl.
    data: lv_filestr type string,
    lv_tempstr type string,
    lv_fn type rlgrap-filename.
    refresh it_pagdetl.
    clear it_pagdetl.
    select applname
    pagekey
    pagename
    implclass
    pagetype
    controllerurl
    lifetime
    state
    is_error_page
    error_page
    browser_cache
    server_cache
    author
    createdon
    changedby
    changedon
    into table it_pagdetl
    from o2pagdir
    where applname = p_it_bspappl-applname.
    * Downloading the application Class Details
    if not p_it_bspappl-applclas is initial.
    clear : lv_filestr.
    concatenate v_filestr 'APPLICATIONCLASS' '\' into lv_filestr.
    it_scr_out-appname = p_it_bspappl-applname.
    perform create_directory using lv_filestr.
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_class_details using lv_filestr p_it_bspappl-applclas.
    endif.
    if r_bspall = 'X' or chk_cont = 'X'.
    clear : lv_filestr.
    concatenate v_filestr 'CONTROLLERS' '\' into lv_filestr.
    perform create_directory using lv_filestr.
    * DOWNLOADING THE CONTROLLER DETAILS
    loop at it_pagdetl where pagetype = gc_bsp_ctrl.
    concatenate lv_filestr it_pagdetl-pagename '\' into lv_tempstr.
    perform create_directory using lv_tempstr.
    clear: lv_fn.
    move lv_tempstr to lv_fn.
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_controller_details using lv_tempstr .
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_class_details using lv_tempstr it_pagdetl-implclass.
    endloop.
    endif.
    if r_bspall = 'X' or chk_view = 'X'.
    clear : lv_filestr.
    concatenate v_filestr 'VIEWS' '\' into lv_filestr.
    perform create_directory using lv_filestr.
    * DOWNLOADING THE VIEW DETAILS
    loop at it_pagdetl where pagetype = gc_bsp_view.
    concatenate lv_filestr it_pagdetl-pagename '\' into lv_tempstr.
    perform create_directory using lv_tempstr.
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_html_event_details using it_pagdetl-applname
    it_pagdetl-pagekey
    lv_tempstr.
    endloop.
    endif.
    if r_bspall = 'X' or chk_frag = 'X'.
    clear : lv_filestr.
    concatenate v_filestr 'PAGEFRAGMENTS' '\' into lv_filestr.
    perform create_directory using lv_filestr.
    * DOWNLOADING THE PAGE FRAGMENTS DETAILS.
    loop at it_pagdetl where pagetype = gc_bsp_pgfr.
    concatenate lv_filestr it_pagdetl-pagename '\' into lv_tempstr.
    perform create_directory using lv_tempstr.
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_html_event_details using it_pagdetl-applname
    it_pagdetl-pagekey
    lv_tempstr.
    endloop.
    endif.
    if r_bspall = 'X' or chk_pgfl = 'X'.
    clear : lv_filestr.
    concatenate v_filestr 'PAGEFLOWLOGIC' '\' into lv_filestr.
    perform create_directory using lv_filestr.
    * DOWNLOADING THE PAGES WITH FLOW LOGIC DETAILS.
    loop at it_pagdetl where pagetype = gc_bsp_pgfl.
    concatenate lv_filestr it_pagdetl-pagename '\' into lv_tempstr.
    perform create_directory using lv_tempstr.
    it_scr_out-appname = p_it_bspappl-applname.
    perform download_html_event_details using it_pagdetl-applname
    it_pagdetl-pagekey
    lv_tempstr.
    endloop.
    endif.
    endform. " GET_BSPAPPL_COMPO
    *& Form CREATE_DIRECTORY
    * To Create Directory*----------------------------------------------------------------------*
    form create_directory using p_lv_filestr.
    data: lv_filename type rlgrap-filename.
    move p_lv_filestr to lv_filename.
    call function 'GUI_CREATE_DIRECTORY'
    exporting
    dirname = lv_filename
    exceptions
    failed = 1
    others = 2.
    endform. " CREATE_DIRECTORY
    *& Form DOWNLOAD_CONTROLLER_DETAILS
    * Controller Details
    form download_controller_details using p_lv_tempstr .
    data: lv_temp type n.
    refresh it_data.
    clear : it_data,
    v_cnt_cls.
    concatenate 'CONTROLLER_NAME: ' it_pagdetl-pagekey into it_data.
    append it_data.
    it_data = space.
    append it_data.
    concatenate 'ERROR HANDLING' ':' into it_data.
    append it_data.
    if it_pagdetl-is_error_page is initial.
    concatenate 'IS ERROR PAGE? ' 'NO' into it_data.
    else.
    concatenate 'IS ERROR PAGE? ' 'YES' into it_data.
    endif.
    append it_data.
    concatenate 'ERROR PAGE: ' it_pagdetl-error_page into it_data.
    append it_data.
    concatenate 'CONTROLLER CLASS : ' it_pagdetl-implclass into it_data.
    append it_data.
    it_data = space.
    append it_data.
    it_data = 'STATUS'.
    append it_data.
    case it_pagdetl-state.
    when gc_lft_requ.
    it_data = 'STATE: STATELESS FROM NOW ON'.
    when gc_lft_sess.
    it_data = 'STATE: STATEFUL FROM NOW ON'.
    when others.
    concatenate 'IS ERROR PAGE? ' 'YES' into it_data.
    endif.
    append it_data.
    concatenate 'ERROR PAGE: ' it_pagdetl-error_page into it_data.
    append it_data.
    concatenate 'CONTROLLER CLASS : ' it_pagdetl-implclass into it_data.
    append it_data.
    it_data = space.
    append it_data.
    it_data = 'STATUS'.
    append it_data.
    case it_pagdetl-state.
    when gc_lft_requ.
    it_data = 'STATE: STATELESS FROM NOW ON'.
    when gc_lft_sess.
    it_data = 'STATE: STATEFUL FROM NOW ON'.
    when others.
    it_data = 'STATE: UNCHANGED'.
    endcase.
    append it_data.
    case it_pagdetl-state.
    when gc_lft_requ.
    it_data = 'LIFETIME: REQUEST'.
    when gc_lft_sess.
    it_data = 'LIFETIME: SESSION'.
    when others.
    it_data = 'LIFETIME: UNTIL PAGE CHANGE'.
    endcase.
    append it_data.
    it_data = space.
    append it_data.
    it_data = 'CACHING'.
    append it_data.
    lv_temp = it_pagdetl-browser_cache.
    concatenate 'BROWSER CACHE: ' lv_temp into it_data.
    append it_data.
    lv_temp = it_pagdetl-server_cache.
    concatenate 'SERVER CACHE: ' lv_temp into it_data.
    append it_data.
    it_data = space.
    append it_data.
    it_data = 'LOG DETAILS'.
    append it_data.
    concatenate 'CREATED BY: ' it_pagdetl-author ' ON ' it_pagdetl-createdon into it_data.
    append it_data.
    concatenate 'CHANGED BY: ' it_pagdetl-changedby ' ON ' it_pagdetl-changedon into it_data.
    append it_data.
    concatenate p_lv_tempstr it_pagdetl-pagename into p_lv_tempstr.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = p_lv_tempstr
    tables
    data_tab = it_data
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    concatenate 'CONTROLLER' it_pagdetl-pagekey into it_scr_out-component separated by ':'.
    it_scr_out-path = p_lv_tempstr.
    it_scr_out-status = 'Cntl Class Details Download FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    concatenate 'CONTROLLER' it_pagdetl-pagekey into it_scr_out-component separated by ':'.
    it_scr_out-path = p_lv_tempstr.
    it_scr_out-status = 'SUCCESSFULL'.
    it_scr_out-etype = 'S'.
    append it_scr_out.
    clear it_scr_out.
    endif.
    * Getting the Controller Class Name into Global Variable
    clear v_cnt_cls.
    move it_pagdetl-implclass to v_cnt_cls.
    endform. " DOWNLOAD_CONTROLLER_DETAILS
    *& Form download_class
    * DownLoading the Data to File
    form download_class using lv_filename.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_filename
    tables
    data_tab = it_data
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    it_scr_out-component = lv_filename.
    it_scr_out-status = 'FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_scr_out-component = lv_filename.
    it_scr_out-status = 'SUCCESSFULL'.
    it_scr_out-etype = 'S'.
    append it_scr_out.
    clear it_scr_out.
    endif.
    endform. " download_class
    *& Form DOWNLOAD_HTML_EVENT_DETAILS
    * text
    form download_html_event_details using p_applname
    p_pagekey
    p_lv_tempstr.
    data: lv_tempstr type string,
    lv_count type n.
    refresh it_pagcon.
    clear it_pagcon.
    select applname
    pagekey
    objtype
    version
    into table it_pagcon
    from o2pagcon
    where applname = p_applname and
    pagekey = p_pagekey and
    version = 'A' and
    objtype = 'PD'.
    lv_count = 0.
    loop at it_pagcon.
    clear: lv_tempstr,it_source,wa_source,wa_pagecon_key.
    wa_pagecon_key-applname = it_pagcon-applname.
    wa_pagecon_key-pagekey = it_pagcon-pagekey.
    wa_pagecon_key-objtype = it_pagcon-objtype.
    wa_pagecon_key-version = it_pagcon-version.
    if it_pagcon-objtype = 'PD'. "PAGE
    concatenate p_lv_tempstr p_pagekey into lv_tempstr.
    endif.
    import content to it_source-content from database o2pagcon(tr) id wa_pagecon_key
    accepting padding ignoring conversion errors.
    if not it_source-content[] is initial.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_tempstr
    tables
    data_tab = it_source-content
    exceptions
    file_write_error = 1
    no_batch = 2
    gui_refuse_filetransfer = 3
    invalid_type = 4
    no_authority = 5
    unknown_error = 6
    header_not_allowed = 7
    separator_not_allowed = 8
    filesize_not_allowed = 9
    header_too_long = 10
    dp_error_create = 11
    dp_error_send = 12
    dp_error_write = 13
    unknown_dp_error = 14
    access_denied = 15
    dp_out_of_memory = 16
    disk_full = 17
    dp_timeout = 18
    file_not_found = 19
    dataprovider_exception = 20
    control_flush_error = 21
    others = 22.
    if sy-subrc <> 0.
    it_scr_out-component = p_pagekey.
    it_scr_out-path = lv_tempstr.
    it_scr_out-status = 'FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_scr_out-component = p_pagekey.
    it_scr_out-path = lv_tempstr.
    it_scr_out-status = 'SUCCESSFULL'.
    it_scr_out-etype = 'S'.
    append it_scr_out.
    clear it_scr_out.
    endif.
    endif.
    endloop.
    * NOW DOWNLOAD ALL THE PARAMETERS FOR THAT PAGE
    perform download_params_for_page using p_applname
    p_pagekey
    p_lv_tempstr.
    * NOW DOWNLOAD ALL EVENTS FOR THAT PAGE
    perform download_events_for_page using p_applname
    p_pagekey
    p_lv_tempstr.
    endform. " DOWNLOAD_HTML_EVENT_DETAILS
    *& Form DOWNLOAD_PARAMS_FOR_PAGE
    * text
    form download_params_for_page using p_applname
    p_pagekey
    p_lv_tempstr.
    types: begin of t_dld_params,
    compname type o2param,
    auto(5),
    typtype(15),
    type1 type rs38l_typ,
    parvalue type seovalue,
    end of t_dld_params.
    data: it_params type standard table of o2pagpar with header line.
    data: it_dld_params type standard table of t_dld_params with header line.
    data: lv_tempstr type string.
    refresh: it_params,it_dld_params.
    clear : it_params,it_dld_params.
    concatenate p_lv_tempstr 'PARAMETERS.TXT' into lv_tempstr.
    select * from o2pagpar into table it_params
    where applname = p_applname and
    pagekey = p_pagekey and
    version = 'A'.
    loop at it_params.
    it_dld_params-compname = it_params-compname.
    it_dld_params-type1 = it_params-type.
    it_dld_params-parvalue = it_params-parvalue.
    if it_params-pardecltyp = '0'.
    it_dld_params-auto = 'AUTO'.
    endif.
    if it_params-typtype = '3'.
    it_dld_params-typtype = 'TYPE REF TO'.
    else.
    it_dld_params-typtype = 'TYPE'.
    endif.
    append it_dld_params.
    clear it_dld_params.
    endloop.
    if not it_dld_params[] is initial.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_tempstr
    tables
    data_tab = it_dld_params.
    endif.
    endform. " DOWNLOAD_PARAMS_FOR_PAGE
    *& Form DOWNLOAD_EVENTS_FOR_PAGE
    * To Download the Events data
    form download_events_for_page using p_applname
    p_pagekey
    p_lv_tempstr.
    data: lv_tempstr type string,
    it_events type standard table of o2pagevh with header line,
    lv_count type i.
    types: begin of t_ev_handler,
    name type o2evhandlr,
    source type rswsourcet,
    end of t_ev_handler.
    types : it_ev_handler type sorted table of t_ev_handler with unique key name.
    data : it_ev_sources type it_ev_handler with header line.
    field-symbols : <fs_ev_handler> type it_ev_handler.
    refresh it_events.
    clear : it_events,lv_count.
    select * from o2pagevh into table it_events
    where applname = p_applname and
    pagekey = p_pagekey and
    version = 'A'.
    describe table it_events lines lv_count.
    if lv_count > 0.
    concatenate p_lv_tempstr 'EVENTS' '\' into lv_tempstr.
    perform create_directory using lv_tempstr.
    p_lv_tempstr = lv_tempstr.
    endif.
    refresh: it_ev_sources.
    clear: lv_tempstr,it_source,wa_source,wa_pagecon_key,it_ev_sources.
    wa_pagecon_key-applname = p_applname.
    wa_pagecon_key-pagekey = p_pagekey.
    wa_pagecon_key-objtype = 'EV'.
    wa_pagecon_key-version = 'A'.
    import evhandler to it_ev_sources from database o2pagcon(tr) id wa_pagecon_key
    accepting padding ignoring conversion errors.
    loop at it_ev_sources.
    concatenate p_lv_tempstr it_ev_sources-name '.TXT' into lv_tempstr.
    call function 'GUI_DOWNLOAD'
    exporting
    filename = lv_tempstr
    tables
    data_tab = it_ev_sources-source.
    endloop.
    endform. " DOWNLOAD_EVENTS_FOR_PAGE
    *& Form download_cnt_class
    * Perform to Download the Controller Class Details
    form download_class_details using p_lv_filestr pclassname.
    data : v_cnt_cls_name type string,
    v_cnt_lines type i.
    clear : v_cnt_cls_name.
    * As We need to call the common perform which is used for Downloading
    * Class . Before doing that we need to Set Some varibles.
    if pclassname is not initial.
    clear : r_temp_all,chk_attr,chk_meth,chk_evts,chk_type,it_class.
    move 'X' to r_temp_all.
    refresh it_class.
    concatenate p_lv_filestr pclassname into v_cnt_cls_name.
    * get the class name and Class Description from the table SEOCLASS
    * for all the classes which user entered in selection screen based on
    * the system language
    select a~clsname b~descript
    into table it_class
    from seoclass as a left outer join seoclasstx as b
    on a~clsname = b~clsname and
    b~langu = v_langu
    where a~clsname = pclassname.
    describe table it_class lines v_cnt_lines.
    if v_cnt_lines > 0.
    loop at it_class.
    perform get_class_details using it_class-clsname 'X' v_cnt_cls_name .
    endloop.
    endif.
    endif.
    endform. " download_cnt_class
    *& Form download_class_implementation
    * To Down Load the Class Implementaions
    form download_class_implementation tables p_implementation type seok_int_typeinfos.
    data : x_imp type line of seok_int_typeinfos.
    loop at p_implementation into x_imp.
    perform get_inferface_data using x_imp.
    endloop.
    endform. " download_class_implementation
    *& Form get_inferface_data
    * Getting the Interface Data
    form get_inferface_data using p_x_imp type line of seok_int_typeinfos.
    data : x_inmeth type line of seoo_methods_r,
    v_methodname type string,
    v_classname type string.
    it_data = 'INTERFACE'.
    append it_data.
    it_data = '----------'.
    append it_data.
    * Interface Name
    clear it_data.
    concatenate 'Interface Name : ' p_x_imp-interface-clsname into it_data.
    append it_data.
    * Interface Description
    clear it_data.
    concatenate 'Interface Description : ' p_x_imp-interface-descript into it_data.
    append it_data.
    * Interace Methods
    it_data = '-----------------'.
    append it_data.
    clear it_data.
    it_data = 'Interface Methods'.
    append it_data.
    clear it_data.
    it_data = '-----------------'.
    append it_data.
    loop at p_x_imp-methods into x_inmeth where clsname eq p_x_imp-interface-clsname .
    data : temp_str type string.
    * Adding Class Name & Class Description
    concatenate x_inmeth-cmpname cl_abap_char_utilities=>horizontal_tab x_inmeth-descript
    cl_abap_char_utilities=>horizontal_tab into temp_str.
    * Declaration Type
    if x_inmeth-mtddecltyp eq 0.
    concatenate temp_str 'Instance Method' into temp_str.
    else.
    concatenate temp_str 'Static Method' into temp_str.
    endif.
    * Visibility
    case x_inmeth-exposure.
    when 0.
    concatenate temp_str cl_abap_char_utilities=>horizontal_tab 'PRIVATE' into temp_str.
    when 2.
    concatenate temp_str cl_abap_char_utilities=>horizontal_tab 'PUBLIC' into temp_str.
    when 1.
    concatenate temp_str cl_abap_char_utilities=>horizontal_tab 'PROTECTED' into temp_str.
    endcase.
    it_data = temp_str.
    append it_data.
    * To Get Corresponding Paramenters.
    perform get_int_meth_parameters using p_x_imp x_inmeth-cmpname.
    * To Get Source Code for Interface methods.
    clear v_methodname.
    clear v_classname.
    concatenate p_x_imp-interface-clsname '~' x_inmeth-cmpname into v_methodname.
    v_classname = it_class-clsname.
    perform download_method_source using v_classname
    v_methodname.
    clear temp_str.
    clear it_data.
    append it_data.
    endloop.
    endform. " get_inferface_data
    *& Form GET_INT_METH_PARAMETERS
    * To get the method Parameters
    form get_int_meth_parameters using p_x_imp type line of seok_int_typeinfos
    p_x_inmeth_cmpname.
    data: x_parameters type line of seos_parameters_r,
    temp_str type string.
    it_data = '^^^^PARAMETERS'.
    append it_data.
    clear it_data.
    loop at p_x_imp-parameters into x_parameters where clsname eq p_x_imp-interface-clsname and
    cmpname eq p_x_inmeth_cmpname.
    concatenate cl_abap_char_utilities=>horizontal_tab
    cl_abap_char_utilities=>horizontal_tab
    x_parameters-sconame
    cl_abap_char_utilities=>horizontal_tab into temp_str.
    case x_parameters-pardecltyp.
    when 0.
    concatenate temp_str 'Importing' cl_abap_char_utilities=>horizontal_tab into temp_str.
    when 1.
    concatenate temp_str 'Exporting' cl_abap_char_utilities=>horizontal_tab into temp_str.
    when 2.
    concatenate temp_str 'Changing' cl_abap_char_utilities=>horizontal_tab into temp_str.
    when 3.
    concatenate temp_str 'Returning' cl_abap_char_utilities=>horizontal_tab into temp_str.
    endcase.
    case x_parameters-typtype.
    when 0.
    concatenate temp_str 'Like' cl_abap_char_utilities=>horizontal_tab into temp_str.
    when 1.
    concatenate temp_str 'Type' cl_abap_char_utilities=>horizontal_tab into temp_str.
    when 2.
    concatenate temp_str 'Type Ref To' cl_abap_char_utilities=>horizontal_tab into temp_str.
    endcase.
    concatenate temp_str x_parameters-type cl_abap_char_utilities=>horizontal_tab x_parameters-parvalue into temp_str.
    it_data = temp_str.
    append it_data.
    clear it_data.
    clear temp_str.
    endloop.
    endform. " GET_INT_METH_PARAMETERS
    *& Form DOWNLOAD_CLASS_OTHERDETAILS
    * Downloading Class Implementation , Types & Macros
    form download_class_otherdetails using p_p_clsname
    p_inctype.
    data : lv_inctype type string,
    l_clsname type seoclskey,
    cl_source type seop_source,
    cl_exsource type seop_source_string,
    x_source type line of seop_source.
    move p_p_clsname to l_clsname.
    case p_inctype.
    when seop_ext_class_locals_imp.
    lv_inctype = 'CLASS IMPLEMENTAION'.
    when seop_incextapp_definition.
    lv_inctype = 'CLASS TYPES'.
    when seop_incextapp_macros.
    lv_inctype = 'CLASS MACROS'.
    endcase.
    call function 'SEO_CLASS_GET_INCLUDE_SOURCE'
    exporting
    clskey = l_clsname
    inctype = p_inctype
    importing
    source = cl_source
    source_expanded = cl_exsource
    exceptions
    _internal_class_not_existing = 1
    not_existing = 2
    others = 3.
    if sy-subrc <> 0.
    it_scr_out-component = lv_inctype.
    it_scr_out-status = 'FAILED'.
    it_scr_out-etype = 'E'.
    append it_scr_out.
    clear it_scr_out.
    else.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    it_data = lv_inctype .
    append it_data.
    clear it_data.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    loop at cl_source into x_source.
    move x_source to it_data.
    append it_data.
    clear it_data.
    endloop.
    it_data = '@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@'.
    append it_data.
    clear it_data.
    endif.
    endform. " DOWNLOAD_CLASS_OTHERDETAILS
    Regards,
    Anubhav.

  • GUI_DOWNLOAD inside a BSP METHOD

    Hi all!
    I have a BSP application and, in the application class, I have a method named TXT_FACTURA.
    Inside of it, I need to save a txt file to local machine, so I tried to use the FM:
    GUI_DOWNLOAD
    or
    WS_DOWNLOAD
    but when the BSP arrives to execute this FM, a HTTP 500 error raise me... anybody knows why???
    I tested this FM with the same data in a separated report, and all is ok!
    Thanks!

    You cant use GUI_DOWNLOAD or WS_DOWNLOAD in BSP.
    Look at the below link to know how to upload & download..
    /people/thomas.jung3/blog/2004/08/09/bsp-download-to-excel-in-unicode-format
    /people/thomas.jung3/blog/2004/09/02/creating-a-bsp-extension-for-downloading-a-table
    /people/mark.finnern/blog/2003/09/23/bsp-programming-handling-of-non-html-documents
    <i>*Reward each useful answer</i>
    Raja T

  • Internal table to be downloaded into excel is empty

    Hi everybody,
    I created a page where I'm displaying in a table all the records. OnInitialization, I set my RFC needed to get the data from the Prod.Server and so far is displaying fine the data when I test it.
    Now, I want to download that table into excel so I created a buttom in the Layout and in the same page OnInputProcessing I'm checking the event (IF event_id = CL_HTMLB_MANAGER=>EVENT_ID) to check if the new button was trigered. Next, I copied the solution given by Thomas in the weblogs "BSP Download to Excel in Unicode Format" but when I check my table already displayed and needed by the function 'SCMS_STRING_TO_XSTRING', now is empty.
    I set the Automatic Page Attribute for my table ON but still is empty.
    Do I have to set something else to retain or get my table OnInputProcessing?
    Thanks in advance for your quick answer.
    Juan

    Thanks everybody for your quick answers.
    You are all rights, when I set my page Stateful it solve my problem and I'm getting my table with Data.
    Now, I'm having a second problem.
    As I told you before, I only have one page where in OnInitialization I'm displaying a table, that's fine. I include a button to download the table into excel and I copied the Thomas code into the same page OnInputProcessing Event. I test it in debug mode and it's going fine thrue all the statements: executing the Funtion 'SCMS_STRING_TO_XSTRING' and executing the following statements response->set_header_field and so on..
    The problem is when getting the last statement:
    response->set_data( data = l_xstring
    length = l_len ).
    navigation->response_complete( ).
    My current page becomes blank with no dialog to download the file.
    Here is my code from OnInputProcessing event, sorry for the long message.
    CLASS CL_HTMLB_MANAGER DEFINITION LOAD.
    DATA: WA LIKE LINE OF ZIMSLOC.
    DATA: UNRESTQ(17) TYPE C,
          KLABS(17) TYPE C.
    data: name(60) type C,
          l_string type STRING,
          l_xstring type XSTRING,
          l_len type I,
          APP_TYPE(60) type C.
    DATA: response TYPE REF TO if_http_response.
    create object response type cl_http_response exporting add_c_msg = 1.
    constants: crlf type string value cl_abap_char_utilities=>cr_lf,
               tab type string value cl_abap_char_utilities=>horizontal_tab.
    Optional: test that this is an event from HTMLB library.
    IF event_id = CL_HTMLB_MANAGER=>EVENT_ID.
    See if download is triggered from button
      DATA: event TYPE REF TO CL_HTMLB_EVENT.
      event = CL_HTMLB_MANAGER=>get_event( runtime->server->request ).
      IF event->name = 'button' AND event->event_type = 'click'.
        DATA: button_event TYPE REF TO CL_HTMLB_EVENT_BUTTON.
        button_event ?= event.
      ENDIF.
      CASE event->id.
        WHEN 'download'.
          LOOP AT zimsloc INTO WA.
            UNRESTQ = WA-UNRESTRICTEDQ.
            KLABS = WA-KLABS.
            CONCATENATE l_string
            WA-WERKS tab
            WA-MATNR tab
            WA-CHARG tab
            WA-LICHA tab
            WA-MAKTX tab
            KLABS tab
            UNRESTQ tab
            WA-SOBKZ tab
            WA-SONUM tab
            WA-MEINS tab
            crlf
            INTO l_string SEPARATED BY SPACE.
          ENDLOOP.
          APP_TYPE = 'APPLICATION/MSEXCEL; charset=utf-16le'.
          call function 'SCMS_STRING_TO_XSTRING'
            EXPORTING
              text     = l_string
              MIMETYPE = APP_TYPE
            IMPORTING
              BUFFER   = l_xstring.
    Add the Byte Order Mark - UTF-16 Little Endian
          concatenate  cl_abap_char_utilities=>byte_order_mark_little
                       l_xstring
                       into l_xstring in byte mode.
          response->set_header_field( name = 'content-type'
          value = 'APPLICATION/MSEXCEL; charset=utf-16le' ).
    some Browsers have caching problems when loading Excel format
          response->delete_header_field( name =
          if_http_header_fields=>cache_control ).
          response->delete_header_field( name =
          if_http_header_fields=>expires ).
          response->delete_header_field( name =
          if_http_header_fields=>pragma ).
    start Excel viewer either in the Browser or as a separate window
          response->set_header_field( name = 'content-disposition' value =
    'attachment; filename=webforms.xls' ).
    finally display Excel format in Browser
          l_len = xstrlen( l_xstring ).
          response->set_data( data = l_xstring
          length = l_len ).
          navigation->response_complete( ).
        WHEN others.
      ENDCASE.
    ENDIF.
    Thanks againg for your help.
    Juan

  • How can I export Discoverer reports automatically from within PLUS ?

    Hi,
    I want to export Discoverer Repors it to PDF file. I can manually export my report as an PDF file, Now I would like to run this report and export the
    PDF once a day automatically. Has anyone done something like this on
    a Windows server?
    I am using Discoverer (Oracle Discoverer 10g Release 2 (10.1.2.1), there is no Desktop version anymore, so I am using PLUS version, how can I apply this through PLUS version.
    Any help.
    Thanks,
    Hani

    Do NOT attempt to use CL_GUI_FRONTEND_SERVICES=>GUI_DOWNLOAD.  This class and method is for use through the SAPGui and will NOT work within BSP.  This information is completely incorrect!
    There are lots of existing Weblogs on this subject.  Have a look through them for solutions that do work.
    /people/thomas.jung3/blog/2004/09/02/creating-a-bsp-extension-for-downloading-a-table
    /people/thomas.jung3/blog/2004/08/09/bsp-download-to-excel-in-unicode-format
    /people/mark.finnern/blog/2003/09/23/bsp-programming-handling-of-non-html-documents

  • Question for cl_gui_frontend_services= file_save_dialog

    Hi Expert.
    I made simple test page.
    there is nothing but this code in oninitlization
    * event handler for data retrieval
      DATA: ld_filename TYPE string,
            ld_path TYPE string,
            ld_fullpath TYPE string,
            ld_result TYPE i.
    * Display save dialog window
      CALL METHOD cl_gui_frontend_services=>file_save_dialog
        EXPORTING
    *      window_title      = ' '
          DEFAULT_EXTENSION = 'XLS'
          default_file_name = 'accountsdata'
          INITIAL_DIRECTORY = 'c:temp'
        CHANGING
          filename          = ld_filename
          path              = ld_path
          fullpath          = ld_fullpath
    * Check user did not cancel request
      CHECK ld_result EQ '0'.
    and that shows
    "method:FILE_SAVE_DIALOG ,line : 164
    An attempt was made to execute a dynamic method callon an initial(NULL-) object reference. The reference must refer to an object."
    why this error caught?
    Did I miss something or made mistake BSP code above?
    should I create some object before call cl_gui_frontend_services=>file_save_dialog?
    I don't have any clue on this.
    help me please. thanks .

    Oh yes - this most certainly will not work from BSP.  This class and any other that uses the control framework are written as proxy objects to code that actually executes as part of the SAPGui on the client machine.
    BSP is completly web centric.  Its output can only be ran in a browser.  To the browser the output of BSP doesn't look any different than any other web page that might come from ASP, JSP, PHP, etc. 
    Also because BSP runs in a browser - the amount of interaction that can occur with the client (particularly around file downloads) is somewhat limited. There is no file download element or a file save as dialog object. There are other ways to attach content to an HTTP Response or place it in a hidden iFrame - the browser is then responsible for intrepting this information and offering the file save as or open dialog based upon the appropriate MIME Type. 
    This weblog is the primer on BSP downloads written by the Jedi Master himself:
    <a href="/people/mark.finnern/blog/2003/09/23/bsp-programming-handling-of-non-html-documents:///people/mark.finnern/blog/2003/09/23/bsp-programming-handling-of-non-html-documents
    If you search you will find other examples in the older BSP weblogs as well.

  • Pdf conversion from a non unicode system to a unicode system

    Hi,
    I have a BSP application that runs on a unicode system which retrieves data to be output in pdf from a non unicode sap system.
    We get the data from the non unicode system through a RFC call and store data in table otfdata type itcoo, then we perform the conversion through the following:
    perform pdfcnv_convertotf in program saplstxw
    tables otfdata
    pdf
    using
    'T'
    archive_index
    1
    'T'
    pdf_bytecount
    app_tot_xstring
    and then perform the hex conversion, but the printout is full of # chars. The good characters are followed by the # char. It looks like the unicode conversion is not good.
    Thank you in advance for your help.
    Best regards,
    Donatella

    Welcome to SDN
    check out this weblog where Thomas Jung explains unicode conversion for excel, the same thing could be applied in your case as well
    /people/thomas.jung3/blog/2004/08/09/bsp-download-to-excel-in-unicode-format
    Regards
    Raja

  • Japanese characters showing Junk when opened in MS Excel

    Hello Friends,
       I am working on a BSP project but this one is a little of ABAP as we are allowing some download reports via ABAP but all other interfaces via BSP..BUT eventually, we will be converting them to BSP download features.
    At this point, I am facing a strange issue while downloading via normal ABAP but I am speculating I may face this issue even if I download via a BSP Download option. Here is my issue:
    I have a ABAP report which displays vendor name and address as a list.  Some of the vendor address are in Japanese Language and they are displayed properly on the report output ie on screen. (We have logged in as language JA). Now, when the user uses the SAP standard menu ie SYSTEM->LIST->SAVE->Local File-> and selects SPREADSHEET and saves the file as a .XLS on his desktop. When he opens this MS Excel spreadsheet from the desktop...all the Japanese characters are displaying as JUNK!
    Since it is displaying properly on SAP, I am assuming this is something to do either with MS Excel or there is something going wrong when SAP downloads to Excel.
    How can I get the Japanese characters displayed properly via the spreadsheet. Could anyone kindly help me to resolve this issue.
    Our SAP is NON UNICODE enabled. We are on SAP ECC 5 ie 6.40.
    Your help is much appreciated.
    Thanks
    Shan

    kumar,
        I wrote to SAP about this issue and here is what they have to say and the solution they suggested.
    the files which are created by the download as spreadsheet option are
    no true Excel files (see note 569537).
    Therefore the automatic import into Excel fails sometimes, and Excel
    needs additional parameters to import such a file.
    Could you try the following:
    1. Rename the file so that the extension is .txt - not .xls.
    2. Open the file in Excel via the File->Open dialog.
    3. In the import wizard, choose encoding "932 - Japanese (Shift Jis)"
    In my case (Excel 2007) the files were displayed correctly. The problem
    is that Excel does not know the original encoding of the file, so the
    encoding must be specified by the user.
    We followed the same.
    Hope this helps.
    PK

  • Answer to Weblog Question for Sumith Rajagopalan

    Sumith Rajagopalan I hope that you read the BSP question forum as well as the weblogs.  You posted a question in the discussion forum on the following weblog:
    /people/thomas.jung3/blog/2004/08/09/bsp-download-to-excel-in-unicode-format
    For some reason I can no longer post comments to this or any other weblog right now.  I assume there is problem on the SDN side.  Therefore I thought I would post the answer here until the problem is resolved. 
    It appears to be a simple typo in your code. You had:
    response->set_header_field(
    name = 'content_disposition'
    value = 'attachment;filename=webforms.xls' ).
    The correct code is:
      response->set_header_field(
          name = 'content-disposition'
          value = 'attachment;
          filename=webforms.xls' ).
    Please note that is is a dash not an underscore in the content-disposition header field name.

    Yes Thomas, it was the typo.  Thanks.  It is working perfectly now.

  • IE - Right Mouse - Export to MS Excel

    If you right click on any HTML table on any webpage, IE shows an entry "Export to MS Excel".
    Have you ever tried this out and do you know why it is usually not working?

    Daniel,
    Yes i tried couple of times back, but it never worked for me.
    use the below link which shows how to download into excel
    /people/thomas.jung3/blog/2004/08/09/bsp-download-to-excel-in-unicode-format
    /people/thomas.jung3/blog/2004/09/02/creating-a-bsp-extension-for-downloading-a-table
    /people/mark.finnern/blog/2003/09/23/bsp-programming-handling-of-non-html-documents
    Raja T

  • How to create downloadable pdf report as hyperlink within BSP application

    Hi,
    I'm developing a BSP application using MVC and htmlb extensions on a WAS 6.40. One of the requirements of my webapplication is:
    - the ability to generate a report in pdf format at runtime, using data retrieved from a backend SAP CRM 3.0 system
    and
    - make this report available/downloadable via a hyperlink in the application.
    I am aware of tools like Smartforms and Adobe interactive forms but need some help to get started and choose the right tool.
    regards, Roelof Jan

    Hi,
    we've done that by firstly building a RFC which prints the report to sap-spool:
    call function 'GET_PRINT_PARAMETERS'
          exporting
            expiration     = 1
            immediately    = ' '
            new_list_id    = 'X'
            line_count     = 65
            line_size      = 132
            report         = sy-repid
            no_dialog      = 'X'
          importing
            out_parameters = wf_params
            valid          = valid_flag.
        if sy-subrc ne 0 or valid_flag eq false.
        endif.
        new-page no-heading no-title print on parameters wf_params
                          no dialog .
    ... list processing ...
    new-page print off.
      concatenate programname sy-uname+0(3) into lc_rq2name separated by '_'.
      select * from tsp01 into tsp01_wa
                          where rq2name = lc_rq2name
                          and rqowner   = sy-uname
                          order by rqcretime descending.
        wf_spono = tsp01_wa-rqident.
        exit.
      endselect.
      if sy-subrc ne 0.
        clear wf_spono.
      endif.
    Then convert the spooljob:
      call function 'CONVERT_ABAPSPOOLJOB_2_PDF'
        exporting
          src_spoolid              = wf_spono
          no_dialog                = 'X'
        tables
          pdf                      = witab
        exceptions
          err_no_abap_spooljob     = 1
          err_no_spooljob          = 2
          err_no_permission        = 3
          err_conv_not_possible    = 4
          err_bad_destdevice       = 5
          user_cancelled           = 6
          err_spoolerror           = 7
          err_temseerror           = 8
          err_btcjob_open_failed   = 8
          err_btcjob_submit_failed = 9
          err_btcjob_close_failed  = 10
          others                   = 11.
      if sy-subrc ne 0.
        return.
      endif.
    Delete Spooljob and generate cached response:
      data del_spono type  tsp01_sp0r-rqid_char.
      del_spono = wf_spono.
      call function 'RSPO_R_RDELETE_SPOOLREQ'
        exporting
          spoolid = del_spono.
      if witab is not initial.
        loop at witab into itab .
          translate itab using ' ~'.
          concatenate output itab into output in character mode.
        endloop.
        translate output using '~ ' .
        create object cached_response
               type cl_http_response
               exporting add_c_msg = 1.
        l_pdf_len = strlen( output ).
        cached_response->set_cdata( data   = output
                                    length = l_pdf_len ).
        cached_response->set_header_field( name  = if_http_header_fields=>content_type
                                           value = 'application/pdf' ).
        cached_response->set_status( code = 200 reason = 'OK' ).
        cached_response->server_cache_expire_rel( expires_rel = 180 ).
        data: guid type guid_32,
              display_url type string.
        call function 'GUID_CREATE'
          importing
            ev_guid_32 = guid.
        concatenate runtime->application_url '/' guid '.pdf'
                    into display_url.
        cl_http_server=>server_cache_upload( url      = display_url
                                             response = cached_response ).
        app ?= application.
        app->print_url = display_url.
      endif .
    The display_url has to be used in the normal response-view:
    <script type="text/javascript">
    var param = 'width=700'
          + ',height=550'
          + ',left=0'
          + ',top=0'
          + ',menubar=no'
          + ',location=no'
          + ',resizable=yes'
          + ',status=no';
      window.open('<%= application->print_url%>', 'DRUCK', param ).focus();
    </script>

  • CIC0 -- BSP in R/3 -- Download File -- SSO not working

    Hi SDN Gurus,
    I have a peculiar situation and am hoping for some guidance.
    We are running several BSP's internally via CIC0 in CRM. These BSP's are actually developed in the R/3 backed system. One of the BSP's downloads a file from the SAP system.
    When the BSP is called via CIC0, it opens up the SAP simple browser. This browser contains a download link which when clicked opens a local (on the users PC) IE browser which then calls the standard download dialog for IE. Before this however, it asks for the R/3 user login and Password.
    Since users are logging in via a portal they dont necessarily know their userid and password.
    Is there anyway of avoiding the BSP or browser asking for a user id and password before download?
    We are using SSO with logon tickets which works for all other BSP's except this particular one with download option.
    Any help is highly appreciated and points will be awarded for helpful answers.
    Many Thanks,

    Did you check http://help.sap.com/saphelp_webas620/helpdata/en/99/15ee3adcf1913fe10000000a11405a/frameset.htm and
    http://help.sap.com/saphelp_webas620/helpdata/en/d2/91553b4d53273de10000000a114084/frameset.htm
    Other useful threads:
    WebAS SOAP Runtime - Transaction Commit Issue
    /people/sap.user72/blog/2004/10/25/sap-logon-ticket-based-single-sign-on
    /people/thomas.jung3/blog/2004/08/03/bsp-150-a-developer146s-journal-part-viii--user-authentication-single-sign-on
    http://help.sap.com/saphelp_me21sp2/helpdata/en/5c/b7d53ae8ab9248e10000000a114084/frameset.htm
    http://help.sap.com/saphelp_nw04/helpdata/en/14/252f4069702d22e10000000a1550b0/frameset.htm
    Raja T
    Message was edited by:
            Raja T

  • Upload/download excel from BSP

    Hi all
    I am new to BSP's and and need to investigate the following:
    Is it possible to create an excel file, manipulate certain cells (e.g. read only, format colours etc.) then export the file to a supplier via the portal. Then read the file and update R3. As the file will be quite large is it possible to compress it?
    Thanks
    Zane

    Hi look at these blogs:
    /people/thomas.jung3/blog/2004/09/02/creating-a-bsp-extension-for-downloading-a-table
    /people/sap.user72/blog/2006/02/07/downloading-data-into-excel-with-format-options
    But I don't know any way of communication from the excel-sheet back to the R/3.
    Regards,
    Steffen

Maybe you are looking for