程序字符串的搜索引擎

TABLES: d020s,
        tadir,
        trdir,
        tuchk3,
        rsrepl.
TYPES:  BEGIN OF result_ln,
          repname LIKE sy-repid,
          dynnr   LIKE sy-dynnr,
          line_no(6) TYPE n,
*         text    like rstxp-tdline,
          text TYPE string,
          sstring ,
          del_flag,
       END OF result_ln,

       result_tab TYPE result_ln OCCURS 0.

DATA: disptype   VALUE 'A',
      dtab       TYPE result_tab WITH HEADER LINE,
      ftab       TYPE result_tab WITH HEADER LINE,
      hit_count  TYPE i,
      tabix      LIKE sy-tabix,
*     text_line  like rstxp-tdline,
      text_line  TYPE string,
      top_flag.

DATA: BEGIN OF dyn OCCURS 0,
        prog  LIKE d020s-prog,
        dnum  LIKE d020s-dnum,
      END OF dyn,

      BEGIN OF fm OCCURS 0,
        obj_name LIKE tadir-obj_name,
      END OF fm,

      BEGIN OF irdir OCCURS 50,
        name LIKE trdir-name,
      END OF irdir,

      BEGIN OF itab OCCURS 50,
        repname LIKE sy-repid,
      END OF itab,

      itab_ii LIKE itab OCCURS 50 WITH HEADER LINE,

     BEGIN OF rtab OCCURS 0,
*      text like rpy_dyflow-line,
       text(1000),
     END OF rtab,

     rtab_lcase LIKE LINE OF rtab,
     rtab_tmp   LIKE LINE OF rtab.

SELECTION-SCREEN: BEGIN OF BLOCK a10 WITH FRAME TITLE a10.
SELECT-OPTIONS:   repname  FOR trdir-name MEMORY ID scan_repid OBLIGATORY,
                  dynnr    FOR d020s-dnum,
                  subc     FOR trdir-subc,
                  appl     FOR trdir-appl,
                  cnam     FOR trdir-cnam,
                  unam     FOR trdir-unam,
                  devclass FOR tadir-devclass.
SELECTION-SCREEN: END OF BLOCK a10,
                  BEGIN OF BLOCK a20 WITH FRAME TITLE a20.
*SELECT-OPTIONS:   sstring     FOR tuchk3-object NO INTERVALS.
SELECT-OPTIONS:   sstring     FOR rsrepl-tdfind NO INTERVALS OBLIGATORY.
PARAMETERS:       plusminu(2) TYPE n DEFAULT 2,
                  inclu       AS CHECKBOX DEFAULT 'X',
                  modiass     AS CHECKBOX,
                  comment     AS CHECKBOX,
                  mask        AS CHECKBOX.
SELECTION-SCREEN: END OF BLOCK a20,
                  BEGIN OF BLOCK a30 WITH FRAME TITLE a30.
PARAMETERS:       rb_code  RADIOBUTTON GROUP r10,
                  rb_dyn   RADIOBUTTON GROUP r10,
                  rb_all   RADIOBUTTON GROUP r10.
SELECTION-SCREEN: END OF BLOCK a30.

DATA: string LIKE sstring-low.

INITIALIZATION.
  a10 = '報表/屏幕選擇'.
  a20 = '搜索標準'.
  a30 = '搜索區域'.

TOP-OF-PAGE.
  PERFORM top_of_page.

TOP-OF-PAGE DURING LINE-SELECTION.
  PERFORM top_of_page.

START-OF-SELECTION.
  IF NOT modiass IS INITIAL.
    sstring-sign    = 'I'.
    sstring-option  = 'EQ'.
    sstring-low     = '{'.
    APPEND sstring.
    sstring-low     = '}'.
    APPEND sstring.
  ENDIF.

  READ TABLE sstring INDEX 1.
  DESCRIBE TABLE sstring LINES sy-tfill.
  IF sy-tfill = 1.
    string = sstring-low.
  ELSE.
    CONCATENATE sstring-low
               '...'
                INTO string SEPARATED BY space.
  ENDIF.

  SET PF-STATUS 'MAIN'.

  IF NOT devclass[] IS INITIAL.
    SELECT obj_name INTO TABLE irdir
      FROM tadir
      WHERE pgmid  = 'R3TR'
      AND   object = 'PROG'
      AND   devclass IN devclass .


    SELECT obj_name INTO TABLE fm
      FROM tadir
      WHERE pgmid  = 'R3TR'
      AND   object = 'FUGR'
      AND   devclass IN devclass.

    LOOP AT fm.
      CONCATENATE 'SAPL' fm-obj_name INTO irdir.
      APPEND irdir.
    ENDLOOP.
  ENDIF.

  IF NOT repname[] IS INITIAL.
    SELECT name APPENDING TABLE irdir
      FROM trdir
      WHERE name IN repname
      AND   cnam IN cnam
      AND   unam IN unam
      AND   subc IN subc
      AND   appl IN appl.
  ENDIF.

  CHECK NOT irdir[] IS INITIAL.

  IF rb_code IS INITIAL.
*   Also scan dynpro flow logic
    SELECT prog dnum INTO TABLE dyn
      FROM d020s FOR ALL ENTRIES IN irdir
      WHERE prog = irdir-name
      AND   dnum IN dynnr.
  ENDIF.

  IF NOT inclu IS INITIAL.
    LOOP AT irdir.
      REFRESH itab_ii.
      CALL FUNCTION 'GET_INCLUDES'
        EXPORTING
          progname = irdir-name
        TABLES
          incltab  = itab_ii.

      APPEND LINES OF itab_ii TO itab.
    ENDLOOP.
  ENDIF.

  APPEND LINES OF irdir TO itab.
  SORT itab.
  DELETE ADJACENT DUPLICATES FROM itab.

  IF rb_dyn IS INITIAL.
    LOOP AT itab.
      READ REPORT itab-repname INTO rtab.
      CHECK sy-subrc = 0.
*      IF NOT comment IS INITIAL.
*        DELETE rtab
*          WHERE text(1) = '*'.
*      ENDIF.

      LOOP AT sstring.
        IF mask IS INITIAL.
          SEARCH rtab FOR sstring-low.
          CHECK sy-subrc = 0.
        ELSE.
          sy-tabix = 1.
        ENDIF.

        LOOP AT rtab FROM sy-tabix.
          tabix      = sy-tabix.
          rtab_lcase = rtab.
          TRANSLATE rtab TO UPPER CASE.

          CASE mask.
            WHEN space.
              IF rtab-text CS sstring-low.
                PERFORM: get_hit_set USING rtab_lcase tabix space.
              ENDIF.

            WHEN OTHERS.
              IF rtab-text CP sstring-low.
                PERFORM: get_hit_set USING rtab_lcase tabix space.
              ENDIF.
          ENDCASE.
        ENDLOOP.
      ENDLOOP.
    ENDLOOP.
  ENDIF.

  FREE: itab.

  IF rb_code IS INITIAL.
    LOOP AT dyn.
      PERFORM get_dynpro_flow_logic.

*      IF NOT comment IS INITIAL.
*        DELETE rtab
*          WHERE text(1) = '*'.
*      ENDIF.

      LOOP AT sstring.
        IF mask IS INITIAL.
          SEARCH rtab FOR sstring-low.
          CHECK sy-subrc = 0.
        ELSE.
          sy-tabix = 1.
        ENDIF.

        LOOP AT rtab FROM sy-tabix.
          tabix      = sy-tabix.
          rtab_lcase = rtab.
          TRANSLATE rtab TO UPPER CASE.

          CASE mask.
            WHEN space.
              IF rtab-text CS sstring-low.
                PERFORM: get_hit_set USING rtab_lcase tabix 'D'.
              ENDIF.

            WHEN OTHERS.
              IF rtab-text CP sstring-low.
                PERFORM: get_hit_set USING rtab_lcase tabix 'D'.
              ENDIF.
          ENDCASE.
        ENDLOOP.
      ENDLOOP.
    ENDLOOP.
  ENDIF.

  FREE: dyn.

END-OF-SELECTION.
  IF ftab[] IS INITIAL AND dtab[] IS INITIAL.
    MESSAGE s016 WITH '字符串' string '未找到'.
    EXIT.
  ENDIF.

  SORT: ftab BY repname line_no sstring DESCENDING,
        dtab BY repname dynnr line_no sstring DESCENDING.

  DELETE ADJACENT DUPLICATES FROM: ftab COMPARING repname line_no,
                                   dtab COMPARING repname dynnr line_no.

  MESSAGE s016 WITH hit_count '命中字符串' string.

  PERFORM: display_ftab_alt,
           display_dtab_alt.

AT LINE-SELECTION.
  PERFORM call_editor.

AT USER-COMMAND.
  CASE sy-ucomm.
    WHEN 'TOGL'.
      CASE disptype.
        WHEN 'M' OR 'L'.
          disptype = 'A'.
          PERFORM: display_ftab_alt,
                   display_dtab_alt.
        WHEN 'A' OR 'L'.
          disptype = 'M'.
          PERFORM: display_ftab,
                   display_dtab.
      ENDCASE.
      sy-lsind = sy-lsind - 1.
    WHEN 'REPT'.
      PERFORM: display_rep_list.
      sy-lsind = sy-lsind - 1.
    WHEN 'DOWN'.
      PERFORM download_list.
    WHEN 'EXIT'.
      LEAVE SCREEN.
  ENDCASE.

*---------------------------------------------------------------------*
*       FORM APPEND_FTAB                                              *
*---------------------------------------------------------------------*
FORM append_ftab USING text    LIKE rtab_lcase
                       line_no LIKE sy-tabix
                       sstring TYPE c
                       source  TYPE c.

  DATA: ln TYPE result_ln.

  ln-line_no = line_no.
  ln-text    = text.
  ln-sstring = sstring.

  IF source IS INITIAL.
    ln-repname = itab-repname.
    APPEND ln TO ftab.
  ELSE.
    ln-repname = dyn-prog.
    ln-dynnr   = dyn-dnum.
    APPEND ln TO dtab.
    CLEAR: ln-dynnr.
  ENDIF.

  IF NOT ln-sstring IS INITIAL.
    ADD 1 TO hit_count.
  ENDIF.
ENDFORM.                    "append_ftab

*---------------------------------------------------------------------*
*       FORM TOP_OF_PAGE                                              *
*---------------------------------------------------------------------*
FORM top_of_page.
  DATA: repname(50).
  DATA: title LIKE trdirt-text .

  FORMAT INTENSIFIED OFF.
  ULINE /(150).
  WRITE: /  sy-vline,
           '源掃描字符串:',
            string  COLOR COL_NEGATIVE INVERSE,
        78 '日期:',
            sy-datum DD/MM/YYYY,
        96  '時間:',
            sy-uzeit,
      150   sy-vline.
  ULINE /(150).
  FORMAT INTENSIFIED ON.
  WRITE: / sy-vline.

  IF top_flag = 'A'.
    repname = ftab-repname.
    CLEAR title.
    SELECT SINGLE text INTO title FROM trdirt
                       WHERE name = repname AND sprsl = sy-langu.
  ELSEIF top_flag = 'D' .
    CONCATENATE dtab-repname
               '屏幕'
                dtab-dynnr
                INTO repname SEPARATED BY space.
  ENDIF.

  CASE disptype.
    WHEN 'A'.
      CONCATENATE '行     源代碼 ['
                   repname
                   ']' '    程序描述 [' title ']' INTO text_line.
      WRITE: text_line.
    WHEN 'M'.
      IF top_flag = 'A'.
        WRITE: '源代碼', 102 '行     報表'.
      ELSE.
        WRITE: '源代碼', 102 '行     屏幕'.
      ENDIF.
    WHEN 'L'.
      WRITE '程序列表'.
  ENDCASE.
  WRITE: 150 sy-vline.
  ULINE (150).
ENDFORM.                    "top_of_page
*---------------------------------------------------------------------*
*       FORM DISPLAY_FTAB                                             *
*---------------------------------------------------------------------*
*       Display search results
*---------------------------------------------------------------------*
FORM display_ftab.
  CHECK rb_dyn IS INITIAL.

  top_flag = 'A'.

  NEW-PAGE.

  LOOP AT ftab.
    IF ftab-sstring IS INITIAL.
      WRITE: / sy-vline,
               ftab-text INTENSIFIED OFF.
    ELSE.
      FORMAT HOTSPOT ON.
      WRITE: / sy-vline .
*               ftab-text INTENSIFIED OFF COLOR COL_TOTAL.
      IF ftab-text+0(1) <> '*'.
        WRITE: ftab-text      INTENSIFIED OFF COLOR COL_TOTAL.
      ELSE.
        WRITE: ftab-text      INTENSIFIED OFF COLOR COL_KEY.
      ENDIF.

      FORMAT HOTSPOT OFF.
    ENDIF.
    WRITE: 100  sy-vline       NO-GAP,
             ftab-line_no   NO-GAP INTENSIFIED,
             sy-vline       NO-GAP,
             ftab-repname   NO-GAP INTENSIFIED,
        150  sy-vline       NO-GAP.

    HIDE: ftab-repname,
          ftab-line_no.

    AT END OF repname.
      ULINE /(150).
    ENDAT.
  ENDLOOP.
ENDFORM.                    "display_ftab
*---------------------------------------------------------------------*
*       FORM DISPLAY_DTAB                                             *
*---------------------------------------------------------------------*
*       Display search results (dynpro)
*---------------------------------------------------------------------*
FORM display_dtab.
  CHECK rb_code IS INITIAL.

  top_flag = 'D'.

  NEW-PAGE.

  LOOP AT dtab.
    IF dtab-sstring IS INITIAL.
      WRITE: / sy-vline,
               dtab-text INTENSIFIED OFF.
    ELSE.
      FORMAT HOTSPOT ON.
      WRITE: / sy-vline,
               dtab-text INTENSIFIED OFF COLOR COL_TOTAL.
      FORMAT HOTSPOT OFF.
    ENDIF.
    WRITE:   sy-vline       NO-GAP,
             dtab-line_no   NO-GAP INTENSIFIED,
             sy-vline       NO-GAP,
             dtab-repname   NO-GAP INTENSIFIED,
             dtab-dynnr     NO-GAP INTENSIFIED,
        150  sy-vline       NO-GAP.

    HIDE:    dtab-repname,
             dtab-dynnr,
             dtab-line_no.

    AT END OF repname.
      ULINE /(150).
    ENDAT.
  ENDLOOP.
ENDFORM.                    "display_dtab

*---------------------------------------------------------------------*
*       FORM DISPLAY_FTAB_ALT
*---------------------------------------------------------------------*
*       Display hit list without report name on every line
*---------------------------------------------------------------------*
FORM display_ftab_alt.
  CHECK rb_dyn IS INITIAL.

  top_flag = 'A'.

  NEW-PAGE.
  IF comment = 'X'.
    LOOP AT ftab.
      IF ftab-text <> '' .
        IF ftab-text+0(1) = '*'.
          ftab-del_flag = 'X'.
          MODIFY ftab.
        ENDIF.
      ENDIF.
    ENDLOOP.
    DELETE ftab WHERE del_flag = 'X'.
  ENDIF.
  LOOP AT ftab.
    AT NEW repname.
      IF sy-tabix > 1.
        NEW-PAGE.
      ENDIF.
    ENDAT.

    WRITE: / sy-vline       NO-GAP,
             ftab-line_no   NO-GAP,
             sy-vline       NO-GAP.

    IF ftab-sstring IS INITIAL.
      WRITE: ftab-text      INTENSIFIED OFF.
    ELSE.
      FORMAT HOTSPOT ON.
      IF ftab-text+0(1) <> '*'.
        WRITE: ftab-text      INTENSIFIED OFF COLOR COL_TOTAL.
      ELSE.
        WRITE: ftab-text      INTENSIFIED OFF COLOR COL_KEY.
      ENDIF.
      FORMAT HOTSPOT OFF.
    ENDIF.

    WRITE: 150 sy-vline.

    HIDE:    ftab-repname,
             ftab-line_no.

    AT END OF repname.
      ULINE /(150).
    ENDAT.
  ENDLOOP.
ENDFORM.                    "display_ftab_alt
*---------------------------------------------------------------------*
*       FORM DISPLAY_DTAB_ALT
*---------------------------------------------------------------------*
*       Display dynpro hit list without report name on every line
*---------------------------------------------------------------------*
FORM display_dtab_alt.
  CHECK rb_code IS INITIAL.

  IF comment = 'X'.
    LOOP AT dtab.
      IF dtab-text <> '' .
        IF dtab-text+0(1) = '*'.
          dtab-del_flag = 'X'.
          MODIFY dtab.
        ENDIF.
      ENDIF.
    ENDLOOP.
    DELETE dtab WHERE del_flag = 'X'.
  ENDIF.

  top_flag = 'D'.

  NEW-PAGE.

  LOOP AT dtab.

    AT NEW repname.
      IF sy-tabix > 1.
        NEW-PAGE.
      ENDIF.
    ENDAT.

    WRITE: / sy-vline       NO-GAP,
             dtab-line_no   NO-GAP,
             sy-vline       NO-GAP.

    IF dtab-sstring IS INITIAL.
      WRITE: dtab-text      INTENSIFIED OFF.
    ELSE.
      FORMAT HOTSPOT ON.
      WRITE: dtab-text      INTENSIFIED OFF COLOR COL_TOTAL.
      FORMAT HOTSPOT OFF.
    ENDIF.

    WRITE: 150 sy-vline.

    HIDE:    dtab-repname,
             dtab-dynnr,
             dtab-line_no.

    AT END OF repname.
      ULINE /(150).
    ENDAT.
  ENDLOOP.
ENDFORM.                    "display_dtab_alt
*----------------------------------------------------------------------*
*       Form  GET_PLUS_MINUS_X_LINES
*----------------------------------------------------------------------*
*       Get x lines before the found string and x lines after
*----------------------------------------------------------------------*
FORM get_hit_set USING value(ctext)   LIKE rtab_lcase
                       value(line_no) LIKE sy-tabix
                       srce_type      TYPE c.

  DATA: end    TYPE i,
        start  TYPE i,
        xtabix LIKE sy-tabix.

  IF plusminu <= 0.
    PERFORM append_ftab USING ctext line_no 'X' srce_type.
    EXIT.
  ENDIF.

  start = line_no - plusminu .
  end   = line_no + plusminu.

  IF start < 1.
    start = 1.
  ENDIF.

  WHILE start <= end.
    READ TABLE rtab INTO ctext INDEX start.
    IF sy-subrc <> 0.
      EXIT.
    ENDIF.
    xtabix = sy-tabix.
    IF start = line_no.
      PERFORM append_ftab USING ctext xtabix 'X' srce_type.
    ELSE.
      PERFORM append_ftab USING ctext xtabix space srce_type.
    ENDIF.
    ADD 1 TO start.
  ENDWHILE.
ENDFORM.                               " GET_HIT_SET
*----------------------------------------------------------------------*
*       Form  CALL_EDITOR
*----------------------------------------------------------------------*
*       Call ABAP or screen painter editor
*----------------------------------------------------------------------*
FORM call_editor.
  CLEAR: ftab,
         dtab.

  READ LINE sy-lilli
       FIELD VALUE ftab-repname
                   ftab-line_no
                   dtab-repname
                   dtab-dynnr
                   dtab-line_no.

  IF ftab-repname IS INITIAL AND dtab-repname IS INITIAL.
    MESSAGE s016 WITH '無效的光標定位'.
    EXIT.
  ENDIF.

  IF dtab-dynnr IS INITIAL.
*   Call ABAP editor
    CALL FUNCTION 'EDITOR_PROGRAM'
      EXPORTING
        display = ''
        program = ftab-repname
        topline = ftab-line_no
      EXCEPTIONS
        OTHERS  = 1.

    SET PARAMETER ID 'RID' FIELD sy-repid.
  ELSE.
    CALL FUNCTION 'RS_SCRP'
      EXPORTING
        abl_line       = dtab-line_no
        dynnr          = dtab-dynnr
        progname       = dtab-repname
        wanted_mode    = 'MODIFY'
      EXCEPTIONS
        already_exists = 1
        not_found      = 2
        not_executed   = 3
        OTHERS         = 4.
  ENDIF.
ENDFORM.                               " CALL_EDITOR
*----------------------------------------------------------------------*
*       Form  GET_DYNPRO_FLOW_LOGIC
*----------------------------------------------------------------------*
*       Get flow logic of the dynpro
*----------------------------------------------------------------------*
FORM get_dynpro_flow_logic.
  DATA: dhead  LIKE d020s,
        dfield LIKE d021s OCCURS 0,
        dflow  LIKE d022s OCCURS 0,
        dmatch LIKE d023s OCCURS 0,

        BEGIN OF dynp_id,
          prog LIKE d020s-prog,
          dnum LIKE d020s-dnum,
       END OF dynp_id.

  dynp_id-prog = dyn-prog.
  dynp_id-dnum = dyn-dnum.

  IMPORT DYNPRO dhead dfield dflow dmatch ID dynp_id.

  rtab[] = dflow[].
ENDFORM.                               " GET_DYNPRO_FLOW_LOGIC
*&---------------------------------------------------------------------*
*&      Form  display_rep_list
*&---------------------------------------------------------------------*
FORM display_rep_list .
  DATA: lineno TYPE i .
  top_flag = 'L'.
  disptype = 'L'.
  CLEAR lineno.
  LOOP AT ftab.
    AT NEW repname.
      lineno = lineno + 1.
      WRITE /(6) lineno .
      WRITE  ftab-repname .
      HIDE ftab-repname.  "可以不要
    ENDAT.
  ENDLOOP.
ENDFORM.                    " display_rep_list
*&---------------------------------------------------------------------*
*&      Form  download_list
*&---------------------------------------------------------------------*
FORM download_list .
  sy-lsind = sy-lsind - 1.
  CALL FUNCTION 'LIST_DOWNLOAD' .
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
            WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.
ENDFORM.                    " download_list 

發佈了58 篇原創文章 · 獲贊 0 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章