Monday, September 24, 2018

cp_analyzer

SET SERVEROUTPUT ON SIZE 1000000
SET ECHO OFF
SET VERIFY OFF
SET DEFINE '~'
SET ESCAPE ON
WHENEVER SQLERROR EXIT
REM $Id: cp_analyzer.sql, 200.24 2017/03/31 09:10:25 WILLIAM.BURBAGE@ORACLE.COM Exp $
REM +=========================================================================+
REM |                 Copyright (c) 2001 Oracle Corporation                   |
REM |                    Redwood Shores, California, USA                      |
REM |                         All rights reserved.                            |
REM +=========================================================================+
REM | Framework 4.0.1                                                         |
REM |                                                                         |
REM | FILENAME                                                                |
REM |    cp_analyzer.sql                                                      |
REM |                                                                         |
REM | DESCRIPTION                                                             |
REM |                                                                         |
REM | HISTORY                                                                 |
REM +=========================================================================+
REM REM
REM ANALYZER_BUNDLE_START
REM
REM COMPAT: 11i 12.0 12.1 12.2
REM
REM MENU_TITLE: Concurrent Processing Analyzer
REM
REM MENU_START
REM
REM SQL: Run Concurrent Processing Analyzer
REM FNDLOAD: Load Concurrent Processing Analyzer as a Concurrent Program
REM
REM MENU_END
REM
REM
REM HELP_START 
REM
REM  Concurrent Processing Analyzer Help [Doc ID: 1411723.1]
REM
REM  Compatible with: [11i|12.0|12.1|12.2]
REM
REM  Explanation of available options:
REM
REM    (1) Runs cp_analyzer.sql as APPS user to create an HTML report
REM
REM    (2) Install Concurrent Processing Analyzer as Concurrent Program
REM        o Runs FNDLOAD as APPS
REM        o Defines the analyzer as a concurrent executable/program
REM        o Adds the analyzer to default request group: "System Administrator Reports"
REM
REM HELP_END
REM
REM FNDLOAD_START
REM
REM PROD_TOP: FND_TOP
REM PROG_NAME: CP_ANALYZER_SQL
REM DEF_REQ_GROUP: System Administrator Reports
REM PROG_TEMPLATE: CPAZ.ldt
REM PROD_SHORT_NAME: FND
REM CP_FILE: cp_analyzer_cp.sql
REM APP_NAME: Application Object Library
REM 
REM FNDLOAD_END
REM
REM DEPENDENCIES_START
REM
REM 
REM
REM DEPENDENCIES_END
REM
REM OUTPUT_TYPE: UTL_FILE
REM
REM ANALYZER_BUNDLE_END

declare
apps_version FND_PRODUCT_GROUPS.RELEASE_NAME%TYPE;

BEGIN
 SELECT max(release_name) INTO apps_version
 FROM fnd_product_groups;
 apps_version := substr(apps_version,1,4);
  
 -- Validation to verify analyzer is run on proper e-Business application version
 if apps_version NOT IN ('11.5','12.0','12.1','12.2') then
 dbms_output.put_line('***************************************************************');
    dbms_output.put_line('*** WARNING WARNING WARNING WARNING WARNING WARNING WARNING ***');
    dbms_output.put_line('***************************************************************');
    dbms_output.put_line('*** This instance is eBusiness Suite version '|| apps_version ||'           ');
    dbms_output.put_line('*** This Analyzer script is compatible for following version(s): ');
 dbms_output.put_line('***   11i,12.0,12.1,12.2 ');
    dbms_output.put_line('*** Note: the error below is intentional                    ');
    raise_application_error(-20001, 'ERROR: The script requires eBusiness versions 11i,12.0,12.1,12.2');
 end if;
END;
/
PROMPT ===========================================================================
PROMPT (Optional) Minimum acceptable volume of closed runtime FND_CONCURRENT_REQUEST data
PROMPT ===========================================================================
PROMPT
ACCEPT p_min_volume NUMBER  DEFAULT '3500' PROMPT 'Enter the Minimum acceptable volume of FND_CONCURRENT_REQUEST data (3500): '
PROMPT
PROMPT ===========================================================================
PROMPT (Optional) Maximum acceptable volume of closed runtime FND_CONCURRENT_REQUEST data
PROMPT ===========================================================================
PROMPT
ACCEPT p_max_volume NUMBER  DEFAULT '5000' PROMPT 'Enter the Maximum acceptable volume of FND_CONCURRENT_REQUEST data (5000): '
PROMPT
PROMPT

PROMPT
Prompt Concurrent Processing Analyzer is running...
PROMPT
DECLARE
   l_debug_mode VARCHAR2(1) := 'Y';
   p_min_volume                   NUMBER         := '~p_min_volume';
   p_max_volume                   NUMBER         := '~p_max_volume';


TYPE section_rec IS RECORD(
  name           VARCHAR2(255),
  result         VARCHAR2(1), -- E,W,S
  error_count    NUMBER,
  warn_count     NUMBER,
  success_count  NUMBER,
  print_count    NUMBER);
TYPE rep_section_tbl IS TABLE OF section_rec INDEX BY BINARY_INTEGER;
TYPE hash_tbl_2k     IS TABLE OF VARCHAR2(2000) INDEX BY VARCHAR2(255);
TYPE hash_tbl_4k     IS TABLE OF VARCHAR2(4000) INDEX BY VARCHAR2(255);
TYPE hash_tbl_8k     IS TABLE OF VARCHAR2(8000) INDEX BY VARCHAR2(255);
TYPE col_list_tbl    IS TABLE OF DBMS_SQL.VARCHAR2_TABLE;
TYPE varchar_tbl     IS TABLE OF VARCHAR2(255);
TYPE results_hash    IS TABLE OF NUMBER INDEX BY VARCHAR(1);
TYPE parameter_rec   IS RECORD(
  pname        VARCHAR2(255),
  pvalue       VARCHAR2(2000));
TYPE parameter_hash IS TABLE OF parameter_rec;

TYPE signature_rec IS RECORD(
  sig_sql          VARCHAR2(32000),
  title            VARCHAR2(255),
  fail_condition   VARCHAR2(4000),
  problem_descr    VARCHAR2(32000),
  solution         VARCHAR2(4000),
  success_msg      VARCHAR2(4000),
  print_condition  VARCHAR2(8),
  fail_type        VARCHAR2(1),
  print_sql_output VARCHAR2(2),
  limit_rows       VARCHAR2(1),
  extra_info       HASH_TBL_4K,
  child_sigs       VARCHAR_TBL := VARCHAR_TBL(),
  include_in_xml   VARCHAR2(1));
TYPE signature_tbl IS TABLE OF signature_rec INDEX BY VARCHAR2(255);
TYPE colsType      IS TABLE OF VARCHAR(126) INDEX BY VARCHAR(126);
TYPE hyperlinkColType IS RECORD(
   cols    colsType
);  
TYPE sourceToDestType IS TABLE OF hyperlinkColType INDEX BY VARCHAR2(126);
TYPE destToSourceType IS TABLE OF hyperlinkColType INDEX BY VARCHAR2(126);
TYPE resultType      IS TABLE OF VARCHAR2(32) INDEX BY VARCHAR2(32);
TYPE sig_record IS RECORD(
   sig_id      VARCHAR2(320),
   sig_name    VARCHAR2(320),
   sig_result  VARCHAR2(10)
);
TYPE signatures_tbl IS TABLE OF sig_record;
TYPE section_record IS RECORD(
   name          VARCHAR2(320),
   title         VARCHAR (320),
   sigs          signatures_tbl,
   results       results_hash
);
TYPE section_record_tbl IS TABLE OF section_record;

----------------------------------
-- Global Variables             --
----------------------------------
g_sect_no NUMBER := 1;
g_log_file         UTL_FILE.FILE_TYPE;
g_out_file         UTL_FILE.FILE_TYPE;
g_is_concurrent    BOOLEAN := (to_number(nvl(FND_GLOBAL.CONC_REQUEST_ID,0)) >  0);
g_debug_mode       VARCHAR2(1);
g_max_output_rows  NUMBER := 10;
g_family_result    VARCHAR2(1);
g_errbuf           VARCHAR2(1000);
g_retcode          VARCHAR2(1);
g_section_id       VARCHAR2(300);

g_query_start_time TIMESTAMP;
g_query_elapsed    INTERVAL DAY(2) TO SECOND(3);
g_analyzer_start_time TIMESTAMP;
g_analyzer_elapsed    INTERVAL DAY(2) TO SECOND(3);
g_signatures      SIGNATURE_TBL;
g_sections        REP_SECTION_TBL;
g_sql_tokens      HASH_TBL_2K;
g_rep_info        HASH_TBL_2K;
g_parameters      parameter_hash := parameter_hash();
g_exec_summary      HASH_TBL_2K;
g_item_id         INTEGER := 0;
g_sig_id        INTEGER := 0;
g_parent_sig_id   VARCHAR2(320);
analyzer_title VARCHAR2(255);
g_mos_patch_url   VARCHAR2(255) :=
  'https://support.oracle.com/epmos/faces/ui/patch/PatchDetail.jspx?patchId=';
g_mos_doc_url     VARCHAR2(255) :=
  'https://support.oracle.com/epmos/faces/DocumentDisplay?parent=ANALYZER&sourceId=1411723.1&id=';
g_hidden_xml      XMLDOM.DOMDocument;
g_dx_summary_error VARCHAR2(4000);
g_preserve_trailing_blanks BOOLEAN := false;
g_sec_detail   section_record_tbl := section_record_tbl();
g_level            NUMBER := 1;
g_result           resulttype;
g_cloud_flag       BOOLEAN := FALSE;
g_sig_count        NUMBER := 0;
g_hypercount       NUMBER := 1;
g_dest_to_source  destToSourceType;
g_source_to_dest  sourceToDestType;
g_results         results_hash;

beginmin        number;
beginmax  number;
maxitems number;
cls_cnt  number;
g_reqid_cnt      number;
g_min_vol            number;
g_max_vol            number;
g_cp_status      VARCHAR2(15);
g_nodename      VARCHAR2(30);
g_cp_start_date      DATE;
g_logfile_name       VARCHAR2(240);
g_last_update_date   DATE;
g_apps_invalid_cnt   number;
g_fnd_invalid_cnt    number;
g_CU1                varchar2(15);
g_CU2                varchar2(15);
g_RUP4               varchar2(15);
g_RUP6               varchar2(15);
g_run_alone_cnt      number;
g_run_alone_now_cnt  number;
g_std_mgr            VARCHAR2(30);
g_enabled            VARCHAR2(1);
g_cache              NUMBER(3);

----------------------------------------------------------------
-- Debug, log and output procedures                          --
----------------------------------------------------------------
PROCEDURE enable_debug IS
BEGIN
  g_debug_mode := 'Y';
END enable_debug;
PROCEDURE disable_debug IS
BEGIN
  g_debug_mode := 'N';
END disable_debug;
PROCEDURE print_log(p_msg IN VARCHAR2) is
BEGIN
  -- print only when debug flag is 'Y'
    IF g_debug_mode = 'Y' THEN
        IF NOT g_is_concurrent THEN
          utl_file.put_line(g_log_file, p_msg);
          utl_file.fflush(g_log_file);
        ELSE
          fnd_file.put_line(FND_FILE.LOG, p_msg);
        END IF;
   END IF;
EXCEPTION WHEN OTHERS THEN
  dbms_output.put_line(substr('Error in print_log: '||sqlerrm,1,254));
  raise;
END print_log;

PROCEDURE debug(p_msg VARCHAR2) is
 l_time varchar2(25);
BEGIN
  -- print only when debug flag is 'Y'
  IF (g_debug_mode = 'Y') THEN
    l_time := to_char(sysdate,'DD-MON-YY HH24:MI:SS');
    IF NOT g_is_concurrent THEN
      utl_file.put_line(g_log_file, l_time||'-'||p_msg);
    ELSE
      fnd_file.put_line(FND_FILE.LOG, l_time||'-'||p_msg);
    END IF;
  END IF;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in debug');
  raise;
END debug;

PROCEDURE print_out(p_msg IN VARCHAR2
                   ,p_newline IN VARCHAR  DEFAULT 'Y' ) is
BEGIN
  IF NOT g_is_concurrent THEN
    IF (p_newline = 'N') THEN
       utl_file.put(g_out_file, p_msg);
    ELSE
       utl_file.put_line(g_out_file, p_msg);
    END IF;
    utl_file.fflush(g_out_file);
  ELSE
     IF (p_newline = 'N') THEN
        fnd_file.put(FND_FILE.OUTPUT, p_msg);
     ELSE
        fnd_file.put_line(FND_FILE.OUTPUT, p_msg);
     END IF;
  END IF;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_out');
  raise;
END print_out;

PROCEDURE print_error
         (p_msg             VARCHAR2,
          p_sig_id          VARCHAR2 DEFAULT '',
          p_section_id      VARCHAR2 DEFAULT '')
IS
BEGIN
  print_out('<div class="data sigcontainer signature E section print analysis" level="1"  id="'||p_sig_id||'" style="display: none;">'||p_msg); 
  print_out('</div>');
 
  -- ER #124 Show in unix session the error if parameter or additional validation failed.
  IF NOT g_is_concurrent THEN
 IF p_msg LIKE 'INVALID ARGUMENT:%' THEN
  -- from Parameters validations if exist
  dbms_output.put_line('**************************************************');
  dbms_output.put_line('**** ERROR  ERROR  ERROR  ERROR  ERROR  ERROR ****');
  dbms_output.put_line('**************************************************');
  dbms_output.put_line('**** The analyzer did not run to completion!');
  dbms_output.put_line('**** '||p_msg);
  dbms_output.put_line('**** Please rerun the analyzer with proper parameter value.');
 ELSIF p_msg LIKE 'PROGRAM ERROR%' THEN
  -- from calls in run_sig_sql and run_stored_sig which are seen in output only
  null;
 ELSE
  -- from Additional Validation if exist
  dbms_output.put_line('**************************************************');
  dbms_output.put_line('**** ERROR  ERROR  ERROR  ERROR  ERROR  ERROR ****');
  dbms_output.put_line('**************************************************');
  dbms_output.put_line('**** The analyzer did not run to completion!');
  dbms_output.put_line('**** '||p_msg);
    END IF;
   END IF;
   
END print_error;

----------------------------------------------------------------
--- Time Management                                          ---
----------------------------------------------------------------
PROCEDURE get_current_time (p_time IN OUT TIMESTAMP) IS
BEGIN
  SELECT localtimestamp(3) INTO p_time
  FROM   dual;
END get_current_time;
FUNCTION stop_timer(p_start_time IN TIMESTAMP) RETURN INTERVAL DAY TO SECOND IS
  l_elapsed INTERVAL DAY(2) TO SECOND(3);
BEGIN
  SELECT localtimestamp - p_start_time  INTO l_elapsed
  FROM   dual;
  RETURN l_elapsed;
END stop_timer;
FUNCTION format_elapsed (p_elapsed IN INTERVAL DAY TO SECOND) RETURN VARCHAR2 IS
  l_days         VARCHAR2(3);
  l_hours        VARCHAR2(2);
  l_minutes      VARCHAR2(2);
  l_seconds      VARCHAR2(6);
  l_fmt_elapsed  VARCHAR2(80);
BEGIN
  l_days := EXTRACT(DAY FROM p_elapsed);
  IF to_number(l_days) > 0 THEN
    l_fmt_elapsed := l_days||' days';
  END IF;
  l_hours := EXTRACT(HOUR FROM p_elapsed);
  IF to_number(l_hours) > 0 THEN
    IF length(l_fmt_elapsed) > 0 THEN
      l_fmt_elapsed := l_fmt_elapsed||', ';
    END IF;
    l_fmt_elapsed := l_fmt_elapsed || l_hours||' Hrs';
  END IF;
  l_minutes := EXTRACT(MINUTE FROM p_elapsed);
  IF to_number(l_minutes) > 0 THEN
    IF length(l_fmt_elapsed) > 0 THEN
      l_fmt_elapsed := l_fmt_elapsed||', ';
    END IF;
    l_fmt_elapsed := l_fmt_elapsed || l_minutes||' Min';
  END IF;
  l_seconds := EXTRACT(SECOND FROM p_elapsed);
  IF length(l_fmt_elapsed) > 0 THEN
    l_fmt_elapsed := l_fmt_elapsed||', ';
  END IF;
  l_fmt_elapsed := l_fmt_elapsed || l_seconds||' Sec';
  RETURN(l_fmt_elapsed);
END format_elapsed;
----------------------------------------------------------------
--- Set Cloud flag                                           ---
----------------------------------------------------------------
PROCEDURE set_cloud_flag IS
    l_response VARCHAR2(2000);
BEGIN
    BEGIN
        SELECT '1'
        INTO l_response
           FROM dual
           WHERE EXISTS (
             SELECT 1
             FROM (SELECT db_domain AS domain FROM fnd_databases
                          UNION ALL
                          SELECT domain AS domain FROM fnd_nodes) domains
             WHERE UPPER(domains.domain) LIKE '%ORACLECLOUD.%');
       
        -- If a row is selected we are on the cloud
        IF SQL%ROWCOUNT > 0 THEN
            g_cloud_flag := TRUE;
      RETURN;
        END IF;   
 EXCEPTION
        WHEN NO_DATA_FOUND THEN
            g_cloud_flag := FALSE;
        WHEN OTHERS THEN  
      g_cloud_flag := FALSE;
      dbms_output.put_line('Exception: '||sqlerrm||' in initialize_files');
    END;
    BEGIN
       -- set transfertimeout to 15 seconds, we don’t want the analyzer waiting more than that
       UTL_HTTP.set_transfer_timeout(15);   
       SELECT Utl_http.request('http://192.0.0.192/latest/meta-data')
       INTO l_response
       FROM dual;
       -- Check if the response is indeed from an Oracle cloud 192.0.0.192 service
    IF lower(l_response) LIKE '%local-hostname%' THEN
           g_cloud_flag := TRUE;
           RETURN;
    END IF;   
    EXCEPTION
        WHEN OTHERS THEN
           -- we are NOT on the cloud
     g_cloud_flag := FALSE;
           RETURN;
    END;

END set_cloud_flag;
----------------------------------------------------------------
--- File Management                                          ---
----------------------------------------------------------------
PROCEDURE initialize_files is
  l_date_char        VARCHAR2(20);
  l_log_file         VARCHAR2(200);
  l_out_file         VARCHAR2(200);
  l_file_location    V$PARAMETER.VALUE%TYPE;
  l_instance         VARCHAR2(40);
  l_host         VARCHAR2(40);
  NO_UTL_DIR         EXCEPTION;
 
BEGIN
get_current_time(g_analyzer_start_time);
  IF NOT g_is_concurrent THEN
    SELECT to_char(sysdate,'YYYY-MM-DD_hh_mi') INTO l_date_char from dual;

 SELECT instance_name, host_name
    INTO l_instance, l_host
    FROM v$instance;
    l_log_file := 'CP_Analyzer_'||l_instance||'_'||l_date_char||'.log';
    l_out_file := 'CP_Analyzer_'||l_instance||'_'||l_date_char||'.html';
    SELECT decode(instr(value,','),0,value,
           SUBSTR (value,1,instr(value,',') - 1))
    INTO   l_file_location
    FROM   v$parameter
    WHERE  name = 'utl_file_dir';
 -- Set maximum line size to 10000 for encoding of base64 icon
    IF l_file_location IS NULL THEN
      RAISE NO_UTL_DIR;
    ELSE
      g_out_file := utl_file.fopen(l_file_location, l_out_file, 'w',32000);
   IF g_debug_mode = 'Y' THEN
         g_log_file := utl_file.fopen(l_file_location, l_log_file, 'w',10000);
   END IF; 
    END IF;
    dbms_output.put_line('Files are located on Host : '||l_host);
 dbms_output.put_line('Output file : '||l_file_location||'/'||l_out_file);
 IF g_debug_mode = 'Y' THEN
       dbms_output.put_line('Log file : '||l_file_location||'/'||l_log_file);
 END IF;  
  END IF;
EXCEPTION
  WHEN NO_UTL_DIR THEN
    dbms_output.put_line('Exception: Unable to identify a valid output '||
      'directory for UTL_FILE in initialize_files');
    raise;
  WHEN OTHERS THEN
    dbms_output.put_line('Exception: '||sqlerrm||' in initialize_files');
    raise;
END initialize_files;

PROCEDURE close_files IS
BEGIN
  debug('Entered close_files');
  print_out('</BODY></HTML>');
  IF NOT g_is_concurrent THEN
    debug('Closing files');
 IF g_debug_mode = 'Y' THEN
       utl_file.fclose(g_log_file);
 END IF;  
    utl_file.fclose(g_out_file);
  END IF;
END close_files;

----------------------------------------------------------------
-- REPORTING PROCEDURES                                       --
----------------------------------------------------------------
----------------------------------------------------------------
-- UTILITIES                                                  --
----------------------------------------------------------------
----------------------------------------------------------------
-- Replace invalid chars in the sig name (so we can use the   --
-- the sig name as CSS class                                  --
----------------------------------------------------------------
FUNCTION replace_chars(p_name VARCHAR2) RETURN VARCHAR2 IS
    l_name         VARCHAR2(512);
BEGIN
-- replace existing _ with double _ and spaces with _ (to avoid multi-word section and signature names)   
-- replace also existing - with double - and . with _ (as Firefox does not accept . in the css class name)   
    l_name := REPLACE(p_name, '%', '_PERCENT_');
    l_name := REPLACE(l_name, ':', '_COLON_');
    l_name := REPLACE(l_name, '/', '_SLASH_');
    l_name := REPLACE(l_name, '&', '_AMP_');
    l_name := REPLACE(l_name, '<', '_LT_');
    l_name := REPLACE(l_name, '>', '_GT_');
    l_name := REPLACE(l_name, '(', '__');
    l_name := REPLACE(l_name, ')', '__');
    l_name := REPLACE(l_name, '_', '__');
    l_name := REPLACE(l_name, '-', '--');
    l_name := REPLACE(l_name, '.', '-');   
    l_name := REPLACE(l_name, ',', '----');   
    RETURN REPLACE(l_name, ' ', '_');
 
EXCEPTION WHEN OTHERS THEN
    print_log('Error in print_page_header: '||sqlerrm);
    return p_name;  
END replace_chars;
----------------------------------------------------------------
--- Escape HTML characters (< , > )                          ---
----------------------------------------------------------------
FUNCTION escape_html_chars(p_text VARCHAR2) RETURN VARCHAR2 IS
    l_out_text   VARCHAR2(32767);
BEGIN
    l_out_text := REPLACE(REPLACE(p_text, '>', '&gt;'), '<', '&lt;');
    RETURN l_out_text;
EXCEPTION
  WHEN OTHERS THEN
    print_log('Exception: '||sqlerrm||' in escape_html_chars');
END escape_html_chars;  
----------------------------------------------------------------
-- Prints the Cloud image in the page header and              --
-- also in the Execution Details pop-up page,                 --
-- if the domain like “%oraclecloud.internal%”                --
----------------------------------------------------------------
PROCEDURE print_cloud_image IS
BEGIN
  IF (g_cloud_flag = TRUE) THEN
       print_out ('<img src="" class="smallimg" title="This is a Cloud instance">');
  END IF;
EXCEPTION WHEN OTHERS THEN
    print_log('Error in print_cloud_image: '||sqlerrm);
END print_cloud_image;

----------------------------------------------------------------
-- Prints HTML page header and auxiliary Javascript functions --
-- Notes:                                                     --
-- Looknfeel styles for the o/p must be changed here          --
----------------------------------------------------------------
PROCEDURE print_page_header is
BEGIN
  -- HTML header
  print_out('
<HTML><HEAD>
  <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1">
  <meta http-equiv="X-UA-Compatible" content="IE=9">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">');
  -- Page Title
  print_out('<TITLE>CP Analyzer Report</TITLE>');
  -- Styles
  print_out('
<STYLE type="text/css">
* {
  font-family: "Segoe UI";
  color: #505050;
  font-size: inherit;
}
a {
    color: #3973ac;
    border: none;
    text-decoration: none;
}
img {
    border: none;
}
a.hypersource {
  color: blue;
  text-decoration: underline;
}
a.nolink {
  color: #505050;
  text-decoration: none;
}
.successcount {
   color: #76b418;
   font-size: 20px;
   font-weight: bold;
}  
.warncount {
   color: #fcce4b;
   font-size: 20px;
   font-weight: bold;
}  
.errcount {
   color: #e5001e;
   font-size: 20px;
   font-weight: bold;
}  
.infocount {
   color: #000000;
   font-size: 20px;
   font-weight: bold;
}  
input[type=checkbox] {
  cursor: pointer;
  border: 0;
  display:none;
}
.exportcheck {
    margin-bottom: 0;
    padding-bottom: 0;
}
.export2Txt {
    padding-left: 2px;
}
.pageheader {
    position: fixed;
    top: 0;
    width: 100%;
    height: 75px;
    background-color: #F5F5F5;
    color: #505050;
    margin: 0px;
    border: 0;
    padding: 0;
    box-shadow: 10px 0px 5px #888888;
    z-index: 1;
}
.header_s1 {
    margin-top: 6px;
}
.header_img {
    float: left;
 margin-top: 8px;
 margin-right: 8px;
}
.header_title {
    display: inline;
 font-weight: 600;
 font-size: 20px;
}
.header_subtitle {
 font-weight: 300;
 font-size: 13px;
}
.menubox_subtitle {
 font-weight: 300;
 font-size: 13px;
}
.header_version {
    height: 16px;
 lenght: 32px;
 opacity: 0.85;
}
td.hlt {
  padding: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: bold;
  color: #333333;
  background-color: #FFE864;
  text-indent: 0px;
}
.blacklink:link, .blacklink:visited, .blacklink:link:active, .blacklink:visited:active {
   color: #505050;
}
.blacklink:hover{
   color: #808080;
}
.error_small, .success_small, .warning_small {
   vertical-align:middle;
   display: inline-block;
   width: 24px;
   height: 24px;
}  
.h1 {
    font-size: 20px;
    font-weight: bold;
}
.background {
    background-image: url("");  
}

.body {
    top: 30px;
    width: 100%;
    padding: 0;
    font-size: 14px;
}
.footerarea {
    height: 35px;
    bottom: 0;
    position: fixed;
    width: 100%;
    background-color: #F5F5F5;
    border-top: 1px solid #D9DFE3;
    z-index:100;
}
.footer {
    visibility: visible;
    max-height: 29px;
    min-height: 29px;
    background-color: #F5F5F5;
    color: #145c9e;
    font-weight: normal;
    font-size: 14px;
}
.separator {
    border-left: 1px solid #D6DFE6;
    margin-left: 10px;
    margin-right: 10px;
    height: 22px;
    width: 0px;
    vertical-align: middle;
    display: inline-block;
}   
body {
    color: #505050;
    margin: 0;
    padding: 0;
    background-color: #F5F5F5;
    overflow-y: auto;   
    background-image: url("");  
}
.header, .footer { padding: 0 1em;}
.icon {
    border: none;
    vertical-align:middle;
    width: 32px;
    height: 32px;
    display: inline-block;   
}
.table1 {
    vertical-align: middle;
    text-align: left;
    padding: 3px;
    margin: 1px;
    min-width: 1200px;
    font-size: small;
    border-spacing: 1px;
    border-collapse: collapse;
}
tr.tdata td{
    border: 1px solid #f2f4f7;
}
.topmenu {
    position: absolute;
    right: 50px;
    float: right;
    bottom: 10;
    font-size: 12px;
    color: #505050;
    font-weight: bold;
    text-shadow: none;
    background-color: #f7f8f9;
    background-image: none;  
}
.fullsection {
    padding-right: 5px;
}
.menubutton {
    border: 1px solid;
    cursor: pointer;
    style: inline;
    float: left;
    background-color: #fafafa;
    background-image: none;
    padding: 4px 15px 1px 10px;
    height: 28px;
    border-color: #d9dfe3;
    filter: none;
    border-left-color: rgba(217, 223, 227, 0.7);
    border-right-color: rgba(217, 223, 227, 0.7);
    text-shadow: none;
    vertical-align: middle;
 font-weight: 600;
 font-size: 14px;
}
.menubutton:hover {
    background-color: #EEEEEE;
}
.smallimg {
    padding: 0px 2px 1px 0px;
    vertical-align: middle;
 height: 18px;
 width: 18px;
 opacity: 0.75;
}
.menubox {
    border: 1px solid lightblue;  
    background-color: #FFFFFF;
    style: inline;
    width: 250px;
    height: 290px;
    float: left;
    padding: 10px;
    border-radius:2px;
    border: 1px solid #E7E7E9;
}
.menuboxitem {
    white-space: nowrap;
    font-size: 18px;  
    cursor: pointer;
    padding: 10px 0 10px 0;
}
.menuboxitem:hover {
    background-color: #EEEEEE;
}
.menuboxitemt {
    white-space: nowrap;
    font-size: 18px;  
    padding: 10px 0 10px 0;
}
.mboxelem {
    margin-left:8px;
 text-align:left;
    display:inline-block;
}
.mboxinner {
    margin-left: 15px;
 margin-top: 6px;
}
.mainmenu {
    scroll-y: auto;
    padding: 50px 100px 50px 100px;
}
.maindata {
    display: none;
    width: auto;
    overflow: visible;
    min-height: 600px;
    height: 100%;
}
.leftcell {
   width:200px;
   vertical-align:top;
   padding: 0;
}
.rightcell {
   vertical-align:top;
   padding: 0;
}
.floating-box {
    display: inline-block;
    width: 277px;
    height: 120px;
    margin: 5px;
    padding: 10px;
    border: 1px solid #E7E7E9;;
    background-color: #FFFFFF;
    text-align: center;
    border-radius:2px;
    font-size: 16px;     
}       
.floating-box:hover {
    background-color: #bfdde5;
    font-weight: 600;
}
.textbox {
    text-align: center;
    height: 60px;
    width: 100%;
}              
.counternumber {
    padding: 5px;
    vertical-align: top;
    height: 100%;
    display: inline;
    vertical-align:middle;
}
.counterbox {   
    padding-top: 10px;
    height: 30px;
    font-size:20px;
    font-weight:bold;
    width: 100%;
    border: none;
}
.popup {
    width:100%;
    height:100%;
    display:none;
    position:fixed;
    top:0px;
    left:0px;
    background:rgba(0,0,0,0.75);
    border: solid 1px #8794A3;
    border-color: #c4ced7;
    color: #333333;
}
.popup-inner {
    max-width:700px;
    width:90%;
    padding:0;
    position:absolute;
    top:50%;
    left:50%;
    -webkit-transform:translate(-50%, -50%);
    transform:translate(-50%, -50%);
    box-shadow:0px 2px 6px rgba(0,0,0,1);
    border-radius:3px;
    background:#fff;
    font-size: 14px;   
    background-image: url("");  

');
print_out('
.popup-title {
    display: table-cell;
    vertical-align: top;  
    top: 10px;
    padding: 10px;
    border-bottom: 1px solid lightblue;
    background-color: #F5F5F5;
}
.close-button {
    display: inline-block;
    padding: 4px 7px 1px 7px;
    margin-right:20px;
    margin-bottom:20px;
    float:right;
    vertical-align: bottom;
    min-height: 18px;
    border: 1px solid #c4ced7;
    border-radius: 2px;
    background-color: #E4E8EA;
    font-size: 12px;
    color: #000000;
    text-shadow: 0px 1px 0px #FFFFFF;
    font-weight: bold;
}
.close-button:hover {
    background-color: #FFFFFF;
}
.popup-paramname {
    display: table-cell;
    width: 33%;
    text-align: left;
    vertical-align: top;  
    padding: 10px 5px 5px 10px;
}
.popup-paramval {
    display: table-cell;
    width: 67%;
    text-align: left;
    vertical-align: top;  
    padding: 10px 10px 5px 5px;
}
.close-link {
    padding: 0 12px 10px 10px;
    text-align: right;
    float: right;
    font-color: blue;
}
.popup-value {
    display: table-cell;
    vertical-align: top;  
    top: 10px;
    border-bottom: 1px solid lightblue;
    background-color: #F5F5F5;
}

.sectionmenu {
    border-top: 1px solid #E7E7E9;
    border-radius: 5px 0 0 5px;
    margin: 0 0 2px 7px;
    left:0px;
    width:200px;
    z-index: 3;
}
.sectionbutton {
    cursor: pointer;
    background-color: #e7ecf0;
    border-left: 1px solid #D6DFE6;
    border-bottom: 1px solid #D6DFE6;
    border:right: 2px solid white
    font-weight: normal;
    font-size: 14px;   
    border-top: 0;
    border-right: 0;
    border-radius: 5px 0 0 5px;
    padding: 5px;
    display: none;
    margin-right: 0;
    word-wrap: break-word;
}
.sigcontainer {
    font-weight: normal;
    font-size: 12px;
    background-color: #FFFFFF;
    border: 1px solid #D6DFE6;
    border-radius: 3px;
    padding: 5px;
    margin: 5px 5px 5px 5px;
    width: auto;
    display: block;
    z-index:2;
}
.containertitle {
   font-weight: bold;
   font-size: 25px;  
   text-align: center;
   padding-bottom: 10px;
   padding-top: 5px;
}
.searchbox {
   width:100%;
   font-size: 14px;  
   display:block;
   padding-left: 5px;
}
.search{
   display:block;
   font-weight: normal;
   font-size: 12px;
   color: #333333;
   border-radius: 2px;
   background-color: #FCFDFE;
   border: 1px solid #DFE4E7;
   padding: 6px 5px 5px 5px;
   height: 28px;
   margin-top: 5px;
}  
.expcoll {
   display:block;
   padding-left:5px;
   padding-top:5px;
   padding-bottom:5px;
   margin-left:10px;  
   float:left;
   font-size: 12px;
}
.sigtitle {
    font-size: small;
}
.sigdetails {
    font-size: 12px;
    margin-bottom: 2px;
    padding: 6px;
}
.signature {
    border-style: 1px solid #EAEAEA;
    padding: 6px;
    font-size: 12px;
    font-weight: normal;
}       
.divtable {
    overflow-x: hidden;
    width: 100%;
    z-index:3;
    margin: 3px;
    margin-right: 10px;
}          
.results {
    z-index:4;
    margin: 5px;
}
.divitemtitle{
    text-align: left;
 font-size: 18px;
    font-weight: 600;
    color: #336699;
    border-bottom-style: dotted;
    border-bottom-width: 1px;
    border-bottom-color: #336699;
    margin-bottom: 9px;
    padding-bottom: 2px;
    margin-left: 3px;
    margin-right: 3px;
}
.divitemtitlet{
 font-size: 16px;
 font-weight: 600;
 color: #336699;
    border-bottom-style: none;
}
.arrowright, .arrowdown {
    display: inline-block;
    cursor: context-menu;
 font-size: 12px;
 color: #336699;
    padding: 2px 0px 10px 2px;
    vertical-align: middle;
    height: 18px;
    width: 18px;
}
.divwarn {
  color: #333333;
  background-color: #FFEF95;
  border: 0px solid #FDC400;
  padding: 9px;
  margin: 0px;
  font-size: small;
  min-width:1200px;
}
.divwarn1 {
  font-size: small;
  font-weight: bold;
  color: #9B7500;
  margin-bottom: 9px;
  padding-bottom: 2px;
  margin-left: 3px;
  margin-right: 3px;
}
.solution {
  font-weight: normal;
  color: #0572ce;
 font-size: small;
  font-weight: bold
}
.detailsmall {
  text-decoration:none;
  font-size: xx-small;
  cursor: pointer;
  display: inline;
}
.divuar {
  border: 1px none #00CC99;
  font-size: small;
  font-weight: normal;
  background-color: #ffd6cc;
  color: #333333;
  padding: 9px;
  margin: 3px;
  min-width:1200px;
}
.divuar1 {
  font-size: small;
  font-weight: bold;
  color: #CC0000;
  margin-bottom: 9px;
  padding-bottom: 2px;
  margin-left: 3px;
  margin-right: 3px;
}
.divok {
  border: 1px none #00CC99;
  font-size: small;
  font-weight: normal;
  background-color: #d9f2d9;
  color: #333333;
  padding: 9px;
  margin: 3px;
  min-width:1200px;
}
.divok1 {
  font-size: small;
  font-weight: bold;
  color: #006600;
  margin-bottom: 9px;
  padding-bottom: 2px;
  margin-left: 3px;
  margin-right: 3px;
}
.anchor{
  padding-top: 100px;
  color: #505050;
}
.tabledata tr[visible=''false''],
.no-result{
  display:none;
}
.exportAll {
  display:inline;
}
.exportAllImg {
  display:inline;
}
.tabledata tr[visible=''true'']{
  display:table-row;
}
.counter{
  padding:8px;
  color:#ccc;
}
.tablesorter-default .header,
.tablesorter-default .tablesorter-header {
    background-image: url();
    background-position: center right;
    background-repeat: no-repeat;
    cursor: pointer;
    white-space: normal;
    padding: 4px 20px 4px 4px;
}
.tablesorter-default thead .headerSortUp,
.tablesorter-default thead .tablesorter-headerSortUp,
.tablesorter-default thead .tablesorter-headerAsc {
    background-image: url();
    border-bottom: #CC6666 1px solid;
}
.tablesorter-default thead .headerSortDown,
.tablesorter-default thead .tablesorter-headerSortDown,
.tablesorter-default thead .tablesorter-headerDesc {
    background-image: url();
    border-bottom: #CC6666 1px solid;
}
.tablesorter-default thead .sorter-false {
    background-image: none;
    cursor: default;
    padding: 4px;
}
');
print_out('
.brokenlink {
    display: inline-block;
    height: 15px;
    width: 10px;
    background-image: url("");
}
');
print_out('
.siginfo_ico {
    display: inline-block;
    height: 16px;
    width: 16px;
    background-image: url("");
}
');
print_out('
.export_ico {
    display: inline-block;
    height: 16px;
    width: 16px;
    background-image: url("");
}
');
print_out('
.export_txt_ico {
    display: inline-block;
    height: 16px;
    width: 16px;
    background-image: url("");

');
print_out('
.sort_ico {
    display: inline-block;
    height: 16px;
    width: 16px;
    background-image: url("");
}   
');
 
print_out('
.information_ico {
    display: inline-block;
    height: 32px;
    width: 32px;
    background-image:  url("");
}
');
print_out('
.warn_ico {    
    background-image:  url("");
}   
');
print_out('
.error_ico {
    background-image:   url("");
}   
');
print_out('
.success_ico {
    background-image:   url("");
}   
');
print_out('
.error_small {
    background-image:   url("");
}   
');
print_out('
.warning_small {    
    background-image:  url("");
}   
');
print_out('
.success_small {
    background-image:   url("");
}
</STYLE>');
  -- JS and end of header
print_out('<script type="text/javascript">
/*! jQuery v1.11.1 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */');
print_out('!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l="1.11.1",m=function(a,b){return new m.fn.init(a,b)},n=/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g,o=/^-ms-/,p=/-([\\da-z])/gi,q=function(a,b){return b.toUpperCase()};m.fn=m.prototype={jquery:l,constructor:m,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=m.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return m.each(this,a,b)},map:function(a){return this.pushStack(m.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},m.extend=m.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||m.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(e=arguments[h]))for(d in e)a=g[d],c=e[d],g!==c&&(j&&c&&(m.isPlainObject(c)||(b=m.isArray(c)))?(b?(b=!1,f=a&&m.isArray(a)?a:[]):f=a&&m.isPlainObject(a)?a:{},g[d]=m.extend(j,f,c)):void 0!==c&&(g[d]=c));return g},m.extend({expando:"jQuery"+(l+Math.random()).replace(/\\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===m.type(a)},isArray:Array.isArray||function(a){return"array"===m.type(a)},isWindow:function(a){return null!=a&&a==a.window},isNumeric:function(a){return!m.isArray(a)&&a-parseFloat(a)>=0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},isPlainObject:function(a){var b;if(!a||"object"!==m.type(a)||a.nodeType||m.isWindow(a))return!1;try{if(a.constructor&&!j.call(a,"constructor")&&!j.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}if(k.ownLast)for(b in a)return j.call(a,b);');
print_out('for(b in a);return void 0===b||j.call(a,b)},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(b){b&&m.trim(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(o,"ms-").replace(p,q)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=r(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(n,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(r(Object(a))?m.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){var d;if(b){if(g)return g.call(b,a,c);for(d=b.length,c=c?0>c?Math.max(0,d+c):c:0;d>c;c++)if(c in b&&b[c]===a)return c}return-1},merge:function(a,b){var c=+b.length,d=0,e=a.length;while(c>d)a[e++]=b[d++];if(c!==c)while(void 0!==b[d])a[e++]=b[d++];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=r(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(f=a[b],b=a,a=f),m.isFunction(a)?(c=d.call(arguments,2),e=function(){return a.apply(b||this,c.concat(d.call(arguments)))},e.guid=a.guid=a.guid||m.guid++,e):void 0},now:function(){return+new Date},support:k}),m.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function r(a){var b=a.length,c=m.type(a);return"function"===c||m.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var s=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+-new Date,v=a.document,w=0,x=0,y=gb(),z=gb(),A=gb(),B=function(a,b){return a===b&&(l=!0),0},C="undefined",D=1<<31,E={}.hasOwnProperty,F=[],G=F.pop,H=F.push,I=F.push,J=F.slice,K=F.indexOf||function(a){for(var b=0,c=this.length;c>b;b++)');
print_out('if(this[b]===a)return b;return-1},L="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\\\x20\\\\t\\\\r\\\\n\\\\f]",N="(?:\\\\\\\\.|[\\\\w-]|[^\\\\x00-\\\\xa0])+",O=N.replace("w","w#"),P="\\\\["+M+"*("+N+")(?:"+M+"*([*^$|!\~]?=)"+M+"*(?:''((?:\\\\\\\\.|[^\\\\\\\\''])*)''|\\"((?:\\\\\\\\.|[^\\\\\\\\\\"])*)\\"|("+O+"))|)"+M+"*\\\\]",Q=":("+N+")(?:\\\\(((''((?:\\\\\\\\.|[^\\\\\\\\''])*)''|\\"((?:\\\\\\\\.|[^\\\\\\\\\\"])*)\\")|((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|"+P+")*)|.*)\\\\)|)",R=new RegExp("^"+M+"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)"+M+"+$","g"),S=new RegExp("^"+M+"*,"+M+"*"),T=new RegExp("^"+M+"*([>+\~]|"+M+")"+M+"*"),U=new RegExp("="+M+"*([^\\\\]''\\"]*?)"+M+"*\\\\]","g"),V=new RegExp(Q),W=new RegExp("^"+O+"$"),X={ID:new RegExp("^#("+N+")"),CLASS:new RegExp("^\\\\.("+N+")"),TAG:new RegExp("^("+N.replace("w","w*")+")"),ATTR:new RegExp("^"+P),PSEUDO:new RegExp("^"+Q),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\("+M+"*(even|odd|(([+-]|)(\\\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\\\d+)|))"+M+"*\\\\)|)","i"),bool:new RegExp("^(?:"+L+")$","i"),needsContext:new RegExp("^"+M+"*[>+\~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\("+M+"*((?:-\\\\d)?\\\\d*)"+M+"*\\\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\\d$/i,$=/^[^{]+\\{\\s*\\[native \\w/,_=/^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,ab=/[+\~]/,bb=/''|\\\\/g,cb=new RegExp("\\\\\\\\([\\\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),db=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)};try{I.apply(F=J.call(v.childNodes),v.childNodes),F[v.childNodes.length].nodeType}catch(eb){I={apply:F.length?function(a,b){H.apply(a,J.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function fb(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],!a||"string"!=typeof a)return d;if(1!==(k=b.nodeType)&&9!==k)return[];if(p&&!e){if(f=_.exec(a))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return I.apply(d,b.getElementsByTagName(a)),d;');
print_out('if((j=f[3])&&c.getElementsByClassName&&b.getElementsByClassName)return I.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=9===k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute("id"))?s=r.replace(bb,"\\\\$&"):b.setAttribute("id",s),s="[id=''"+s+"''] ",l=o.length;while(l--)o[l]=s+qb(o[l]);w=ab.test(a)&&ob(b.parentNode)||b,x=o.join(",")}if(x)try{return I.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function gb(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function hb(a){return a[u]=!0,a}function ib(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function jb(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function kb(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(\~b.sourceIndex||D)-(\~a.sourceIndex||D);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function lb(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function mb(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function nb(a){return hb(function(b){return b=+b,hb(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function ob(a){return a&&typeof a.getElementsByTagName!==C&&a}c=fb.support={},f=fb.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=fb.setDocument=function(a){var b,e=a?a.ownerDocument||a:v,g=e.defaultView;return e!==n&&9===e.nodeType&&e.documentElement?(n=e,o=e.documentElement,p=!f(e),g&&g!==g.top&&(g.addEventListener?g.addEventListener("unload",function(){m()},!1):g.attachEvent&&g.attachEvent("onunload",function(){m()})),c.attributes=ib(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ib(function(a){return a.appendChild(e.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(e.getElementsByClassName)&&ib(');
print_out('function(a){return a.innerHTML="<div class=''a''></div><div class=''a i''></div>",a.firstChild.className="i",2===a.getElementsByClassName("i").length}),c.getById=ib(function(a){return o.appendChild(a).id=u,!e.getElementsByName||!e.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if(typeof b.getElementById!==C&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){var c=typeof a.getAttributeNode!==C&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return typeof b.getElementsByTagName!==C?b.getElementsByTagName(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return typeof b.getElementsByClassName!==C&&p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(e.querySelectorAll))&&(ib(function(a){a.innerHTML="<select msallowclip=''''><option selected=''''></option></select>",a.querySelectorAll("[msallowclip^='''']").length&&q.push("[*^$]="+M+"*(?:''''|\\"\\")"),a.querySelectorAll("[selected]").length||q.push("\\\\["+M+"*(?:value|"+L+")"),a.querySelectorAll(":checked").length||q.push(":checked")}),ib(function(a){var b=e.createElement("input");');
print_out('b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+M+"*[*^$|!\~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ib(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='''']:x"),r.push("!=",Q)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===e||a.ownerDocument===v&&t(v,a)?-1:b===e||b.ownerDocument===v&&t(v,b)?1:k?K.call(k,a)-K.call(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,f=a.parentNode,g=b.parentNode,h=[a],i=[b];if(!f||!g)return a===e?-1:b===e?1:f?-1:g?1:k?K.call(k,a)-K.call(k,b):0;if(f===g)return kb(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);');
print_out('while(h[d]===i[d])d++;return d?kb(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},e):n},fb.matches=function(a,b){return fb(a,null,null,b)},fb.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"=''$1'']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return fb(b,n,null,[a]).length>0},fb.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},fb.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&E.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},fb.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},fb.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=fb.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=fb.selectors={cacheLength:50,createPseudo:hb,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"\~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(cb,db),a[3]=(a[3]||a[4]||a[5]||"").replace(cb,db),"\~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||fb.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&fb.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];');
print_out('return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(cb,db).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+M+")"+a+"("+M+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||typeof a.getAttribute!==C&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=fb.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"\~="===b?(" "+e+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(s&&((l[u]||(l[u]={}))[a]=[w,m]),l===b))break;');
print_out('return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||fb.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?hb(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=K.call(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:hb(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?hb(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:hb(function(a){return function(b){return fb(a,b).length>0}}),contains:hb(function(a){return function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:hb(function(a){return W.test(a||"")||fb.error("unsupported lang: "+a),a=a.replace(cb,db).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||\~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();');
print_out('return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:nb(function(){return[0]}),last:nb(function(a,b){return[b-1]}),eq:nb(function(a,b,c){return[0>c?c+b:c]}),even:nb(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:nb(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:nb(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:nb(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=lb(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=mb(b);function pb(){}pb.prototype=d.filters=d.pseudos,d.setFilters=new pb,g=fb.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?fb.error(a):z(a,i).slice(0)};function qb(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}');
print_out('function rb(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function sb(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function tb(a,b,c){for(var d=0,e=b.length;e>d;d++)fb(a,b[d],c);return c}function ub(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function vb(a,b,c,d,e,f){return d&&!d[u]&&(d=vb(d)),e&&!e[u]&&(e=vb(e,f)),hb(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||tb(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:ub(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=ub(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?K.call(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=ub(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):I.apply(g,r)})}function wb(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=rb(function(a){return a===b},h,!0),l=rb(function(a){return K.call(b,a)>-1},h,!0),m=[function(a,c,d){return!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d))}];f>i;i++)if(c=d.relative[a[i].type])m=[rb(sb(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;');
print_out('return vb(i>1&&sb(m),i>1&&qb(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&wb(a.slice(i,e)),f>e&&wb(a=a.slice(e)),f>e&&qb(a))}m.push(c)}return sb(m)}function xb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=G.call(i));s=ub(s)}I.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&fb.uniqueSort(i)}return k&&(w=v,j=t),r};return c?hb(f):f}return h=fb.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=wb(b[c]),f[u]?d.push(f):e.push(f);f=A(a,xb(e,d)),f.selector=a}return f},i=fb.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(cb,db),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--)');
print_out('{if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(cb,db),ab.test(j[0].type)&&ob(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&qb(j),!a)return I.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,ab.test(a)&&ob(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ib(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ib(function(a){return a.innerHTML="<a href=''#''></a>","#"===a.firstChild.getAttribute("href")})||jb("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ib(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||jb("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ib(function(a){return null==a.getAttribute("disabled")})||jb(L,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),fb}(a);m.find=s,m.expr=s.selectors,m.expr[":"]=m.expr.pseudos,m.unique=s.uniqueSort,m.text=s.getText,m.isXMLDoc=s.isXML,m.contains=s.contains;var t=m.expr.match.needsContext,u=/^<(\\w+)\\s*\\/?>(?:<\\/\\1>|)$/,v=/^.[^:#\\[\\.,]*$/;function w(a,b,c){if(m.isFunction(b))return m.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return m.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(v.test(b))return m.filter(b,a,c);b=m.filter(b,a)}return m.grep(a,function(a){return m.inArray(a,b)>=0!==c})}m.filter=function(a,b,c){var d=b[0];');
print_out('return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?m.find.matchesSelector(d,a)?[d]:[]:m.find.matches(a,m.grep(b,function(a){return 1===a.nodeType}))},m.fn.extend({find:function(a){var b,c=[],d=this,e=d.length;if("string"!=typeof a)return this.pushStack(m(a).filter(function(){for(b=0;e>b;b++)if(m.contains(d[b],this))return!0}));for(b=0;e>b;b++)m.find(a,d[b],c);return c=this.pushStack(e>1?m.unique(c):c),c.selector=this.selector?this.selector+" "+a:a,c},filter:function(a){return this.pushStack(w(this,a||[],!1))},not:function(a){return this.pushStack(w(this,a||[],!0))},is:function(a){return!!w(this,"string"==typeof a&&t.test(a)?m(a):a||[],!1).length}});var x,y=a.document,z=/^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]*))$/,A=m.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a.charAt(0)&&">"===a.charAt(a.length-1)&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||x).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof m?b[0]:b,m.merge(this,m.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:y,!0)),u.test(c[1])&&m.isPlainObject(b))for(c in b)m.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}if(d=y.getElementById(c[2]),d&&d.parentNode){if(d.id!==c[2])return x.find(a);this.length=1,this[0]=d}return this.context=y,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):m.isFunction(a)?"undefined"!=typeof x.ready?x.ready(a):a(m):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),m.makeArray(a,this))};A.prototype=m.fn,x=m(y);');
print_out('var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};m.extend({dir:function(a,b,c){var d=[],e=a[b];while(e&&9!==e.nodeType&&(void 0===c||1!==e.nodeType||!m(e).is(c)))1===e.nodeType&&d.push(e),e=e[b];return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),m.fn.extend({has:function(a){var b,c=m(a,this),d=c.length;return this.filter(function(){for(b=0;d>b;b++)if(m.contains(this,c[b]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=t.test(a)||"string"!=typeof a?m(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&m.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?m.unique(f):f)},index:function(a){return a?"string"==typeof a?m.inArray(this[0],m(a)):m.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(m.unique(m.merge(this.get(),m(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){do a=a[b];while(a&&1!==a.nodeType);return a}m.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return m.dir(a,"parentNode")},parentsUntil:function(a,b,c){return m.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return m.dir(a,"nextSibling")},prevAll:function(a){return m.dir(a,"previousSibling")},nextUntil:function(a,b,c)');
print_out('{return m.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return m.dir(a,"previousSibling",c)},siblings:function(a){return m.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return m.sibling(a.firstChild)},contents:function(a){return m.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:m.merge([],a.childNodes)}},function(a,b){m.fn[a]=function(c,d){var e=m.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=m.filter(d,e)),this.length>1&&(C[a]||(e=m.unique(e)),B.test(a)&&(e=e.reverse())),this.pushStack(e)}});var E=/\\S+/g,F={};function G(a){var b=F[a]={};return m.each(a.match(E)||[],function(a,c){b[c]=!0}),b}m.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):m.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(c=a.memory&&l,d=!0,f=g||0,g=0,e=h.length,b=!0;h&&e>f;f++)if(h[f].apply(l[0],l[1])===!1&&a.stopOnFalse){c=!1;break}b=!1,h&&(i?i.length&&j(i.shift()):c?h=[]:k.disable())},k={add:function(){if(h){var d=h.length;!function f(b){m.each(b,function(b,c){var d=m.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&f(c)})}(arguments),b?e=h.length:c&&(g=d,j(c))}return this},remove:function(){return h&&m.each(arguments,function(a,c){var d;while((d=m.inArray(c,h,d))>-1)h.splice(d,1),b&&(e>=d&&e--,f>=d&&f--)}),this},has:function(a){return a?m.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],e=0,this},disable:function(){return h=i=c=void 0,this},disabled:');
print_out('function(){return!h},lock:function(){return i=void 0,c||k.disable(),this},locked:function(){return!i},fireWith:function(a,c){return!h||d&&!i||(c=c||[],c=[a,c.slice?c.slice():c],b?i.push(c):j(c)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!d}};return k},m.extend({Deferred:function(a){var b=[["resolve","done",m.Callbacks("once memory"),"resolved"],["reject","fail",m.Callbacks("once memory"),"rejected"],["notify","progress",m.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return m.Deferred(function(c){m.each(b,function(b,f){var g=m.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&m.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?m.extend(a,d):d}},e={};return d.pipe=d.then,m.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&m.isFunction(a.promise)?e:0,g=1===f?a:m.Deferred(),h=function(a,b,c)');
print_out('{return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&m.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;m.fn.ready=function(a){return m.ready.promise().done(a),this},m.extend({isReady:!1,readyWait:1,holdReady:function(a){a?m.readyWait++:m.ready(!0)},ready:function(a){if(a===!0?!--m.readyWait:!m.isReady){if(!y.body)return setTimeout(m.ready);m.isReady=!0,a!==!0&&--m.readyWait>0||(H.resolveWith(y,[m]),m.fn.triggerHandler&&(m(y).triggerHandler("ready"),m(y).off("ready")))}}});function I(){y.addEventListener?(y.removeEventListener("DOMContentLoaded",J,!1),a.removeEventListener("load",J,!1)):(y.detachEvent("onreadystatechange",J),a.detachEvent("onload",J))}function J(){(y.addEventListener||"load"===event.type||"complete"===y.readyState)&&(I(),m.ready())}m.ready.promise=function(b){if(!H)if(H=m.Deferred(),"complete"===y.readyState)setTimeout(m.ready);else if(y.addEventListener)y.addEventListener("DOMContentLoaded",J,!1),a.addEventListener("load",J,!1);else{y.attachEvent("onreadystatechange",J),a.attachEvent("onload",J);var c=!1;try{c=null==a.frameElement&&y.documentElement}catch(d){}c&&c.doScroll&&!function e(){if(!m.isReady){try{c.doScroll("left")}catch(a){return setTimeout(e,50)}I(),m.ready()}}()}return H.promise(b)};var K="undefined",L;for(L in m(k))break;k.ownLast="0"!==L,k.inlineBlockNeedsLayout=!1,m(function(){var a,b,c,d;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1",k.inlineBlockNeedsLayout=a=3===b.offsetWidth,a&&(c.style.zoom=1)),c.removeChild(d))}),function(){var a=y.createElement("div");');
print_out('if(null==k.deleteExpando){k.deleteExpando=!0;try{delete a.test}catch(b){k.deleteExpando=!1}}a=null}(),m.acceptData=function(a){var b=m.noData[(a.nodeName+" ").toLowerCase()],c=+a.nodeType||1;return 1!==c&&9!==c?!1:!b||b!==!0&&a.getAttribute("classid")===b};var M=/^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,N=/([A-Z])/g;function O(a,b,c){if(void 0===c&&1===a.nodeType){var d="data-"+b.replace(N,"-$1").toLowerCase();if(c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:M.test(c)?m.parseJSON(c):c}catch(e){}m.data(a,b,c)}else c=void 0}return c}function P(a){var b;for(b in a)if(("data"!==b||!m.isEmptyObject(a[b]))&&"toJSON"!==b)return!1;return!0}function Q(a,b,d,e){if(m.acceptData(a)){var f,g,h=m.expando,i=a.nodeType,j=i?m.cache:a,k=i?a[h]:a[h]&&h;if(k&&j[k]&&(e||j[k].data)||void 0!==d||"string"!=typeof b)return k||(k=i?a[h]=c.pop()||m.guid++:h),j[k]||(j[k]=i?{}:{toJSON:m.noop}),("object"==typeof b||"function"==typeof b)&&(e?j[k]=m.extend(j[k],b):j[k].data=m.extend(j[k].data,b)),g=j[k],e||(g.data||(g.data={}),g=g.data),void 0!==d&&(g[m.camelCase(b)]=d),"string"==typeof b?(f=g[b],null==f&&(f=g[m.camelCase(b)])):f=g,f}}function R(a,b,c){if(m.acceptData(a)){var d,e,f=a.nodeType,g=f?m.cache:a,h=f?a[m.expando]:m.expando;if(g[h]){if(b&&(d=c?g[h]:g[h].data)){m.isArray(b)?b=b.concat(m.map(b,m.camelCase)):b in d?b=[b]:(b=m.camelCase(b),b=b in d?[b]:b.split(" ")),e=b.length;while(e--)delete d[b[e]];if(c?!P(d):!m.isEmptyObject(d))return}(c||(delete g[h].data,P(g[h])))&&(f?m.cleanData([a],!0):k.deleteExpando||g!=g.window?delete g[h]:g[h]=null)}}}m.extend({cache:{},noData:{"applet ":!0,"embed ":!0,"object ":"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(a)');
print_out('{return a=a.nodeType?m.cache[a[m.expando]]:a[m.expando],!!a&&!P(a)},data:function(a,b,c){return Q(a,b,c)},removeData:function(a,b){return R(a,b)},_data:function(a,b,c){return Q(a,b,c,!0)},_removeData:function(a,b){return R(a,b,!0)}}),m.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=m.data(f),1===f.nodeType&&!m._data(f,"parsedAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=m.camelCase(d.slice(5)),O(f,d,e[d])));m._data(f,"parsedAttrs",!0)}return e}return"object"==typeof a?this.each(function(){m.data(this,a)}):arguments.length>1?this.each(function(){m.data(this,a,b)}):f?O(f,a,m.data(f,a)):void 0},removeData:function(a){return this.each(function(){m.removeData(this,a)})}}),m.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=m._data(a,b),c&&(!d||m.isArray(c)?d=m._data(a,b,m.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=m.queue(a,b),d=c.length,e=c.shift(),f=m._queueHooks(a,b),g=function(){m.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return m._data(a,c)||m._data(a,c,{empty:m.Callbacks("once memory").add(function(){m._removeData(a,b+"queue"),m._removeData(a,c)})})}}),m.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?m.queue(this[0],a):void 0===b?this:this.each(function(){var c=m.queue(this,a,b);');
print_out('m._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&m.dequeue(this,a)})},dequeue:function(a){return this.each(function(){m.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=m.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=m._data(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var S=/[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/.source,T=["Top","Right","Bottom","Left"],U=function(a,b){return a=b||a,"none"===m.css(a,"display")||!m.contains(a.ownerDocument,a)},V=m.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===m.type(c)){e=!0;for(h in c)m.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,m.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(m(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},W=/^(?:checkbox|radio)$/i;!function(){var a=y.createElement("input"),b=y.createElement("div"),c=y.createDocumentFragment();');
print_out('if(b.innerHTML="  <link/><table></table><a href=''/a''>a</a><input type=''checkbox''/>",k.leadingWhitespace=3===b.firstChild.nodeType,k.tbody=!b.getElementsByTagName("tbody").length,k.htmlSerialize=!!b.getElementsByTagName("link").length,k.html5Clone="<:nav></:nav>"!==y.createElement("nav").cloneNode(!0).outerHTML,a.type="checkbox",a.checked=!0,c.appendChild(a),k.appendChecked=a.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue,c.appendChild(b),b.innerHTML="<input type=''radio'' checked=''checked'' name=''t''/>",k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,k.noCloneEvent=!0,b.attachEvent&&(b.attachEvent("onclick",function(){k.noCloneEvent=!1}),b.cloneNode(!0).click()),null==k.deleteExpando){k.deleteExpando=!0;try{delete b.test}catch(d){k.deleteExpando=!1}}}(),function(){var b,c,d=y.createElement("div");for(b in{submit:!0,change:!0,focusin:!0})c="on"+b,(k[b+"Bubbles"]=c in a)||(d.setAttribute(c,"t"),k[b+"Bubbles"]=d.attributes[c].expando===!1);d=null}();var X=/^(?:input|select|textarea)$/i,Y=/^key/,Z=/^(?:mouse|pointer|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=/^([^.]*)(?:\\.(.+)|)$/;function ab(){return!0}');
print_out('function bb(){return!1}function cb(){try{return y.activeElement}catch(a){}}m.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m._data(a);if(r){c.handler&&(i=c,c=i.handler,e=i.selector),c.guid||(c.guid=m.guid++),(g=r.events)||(g=r.events={}),(k=r.handle)||(k=r.handle=function(a){return typeof m===K||a&&m.event.triggered===a.type?void 0:m.event.dispatch.apply(k.elem,arguments)},k.elem=a),b=(b||"").match(E)||[""],h=b.length;while(h--)f=_.exec(b[h])||[],o=q=f[1],p=(f[2]||"").split(".").sort(),o&&(j=m.event.special[o]||{},o=(e?j.delegateType:j.bindType)||o,j=m.event.special[o]||{},l=m.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&m.expr.match.needsContext.test(e),namespace:p.join(".")},i),(n=g[o])||(n=g[o]=[],n.delegateCount=0,j.setup&&j.setup.call(a,d,p,k)!==!1||(a.addEventListener?a.addEventListener(o,k,!1):a.attachEvent&&a.attachEvent("on"+o,k))),j.add&&(j.add.call(a,l),l.handler.guid||(l.handler.guid=c.guid)),e?n.splice(n.delegateCount++,0,l):n.push(l),m.event.global[o]=!0);a=null}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m.hasData(a)&&m._data(a);if(r&&(k=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=_.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=m.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,n=k[o]||[],h=h[2]&&new RegExp("(^|\\\\.)"+p.join("\\\\.(?:.*\\\\.|)")+"(\\\\.|$)"),i=f=n.length;while(f--)g=n[f],!e&&q!==g.origType||c&&c.guid!==g.guid||h&&!h.test(g.namespace)||d&&d!==g.selector&&("**"!==d||!g.selector)||(n.splice(f,1),g.selector&&n.delegateCount--,l.remove&&l.remove.call(a,g));');
print_out('i&&!n.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||m.removeEvent(a,o,r.handle),delete k[o])}else for(o in k)m.event.remove(a,o+b[j],c,d,!0);m.isEmptyObject(k)&&(delete r.handle,m._removeData(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,l,n,o=[d||y],p=j.call(b,"type")?b.type:b,q=j.call(b,"namespace")?b.namespace.split("."):[];if(h=l=d=d||y,3!==d.nodeType&&8!==d.nodeType&&!$.test(p+m.event.triggered)&&(p.indexOf(".")>=0&&(q=p.split("."),p=q.shift(),q.sort()),g=p.indexOf(":")<0&&"on"+p,b=b[m.expando]?b:new m.Event(p,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=q.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\\\.)"+q.join("\\\\.(?:.*\\\\.|)")+"(\\\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:m.makeArray(c,[b]),k=m.event.special[p]||{},e||!k.trigger||k.trigger.apply(d,c)!==!1)){if(!e&&!k.noBubble&&!m.isWindow(d)){for(i=k.delegateType||p,$.test(i+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),l=h;l===(d.ownerDocument||y)&&o.push(l.defaultView||l.parentWindow||a)}n=0;while((h=o[n++])&&!b.isPropagationStopped())b.type=n>1?i:k.bindType||p,f=(m._data(h,"events")||{})[b.type]&&m._data(h,"handle"),f&&f.apply(h,c),f=g&&h[g],f&&f.apply&&m.acceptData(h)&&(b.result=f.apply(h,c),b.result===!1&&b.preventDefault());if(b.type=p,!e&&!b.isDefaultPrevented()&&(!k._default||k._default.apply(o.pop(),c)===!1)&&m.acceptData(d)&&g&&d[p]&&!m.isWindow(d)){l=d[g],l&&(d[g]=null),m.event.triggered=p;try{d[p]()}catch(r){}m.event.triggered=void 0,l&&(d[g]=l)}return b.result}},dispatch:function(a){a=m.event.fix(a);');
print_out('var b,c,e,f,g,h=[],i=d.call(arguments),j=(m._data(this,"events")||{})[a.type]||[],k=m.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=m.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,g=0;while((e=f.handlers[g++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(e.namespace))&&(a.handleObj=e,a.data=e.data,c=((m.event.special[e.origType]||{}).handle||e.handler).apply(f.elem,i),void 0!==c&&(a.result=c)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!=this;i=i.parentNode||this)if(1===i.nodeType&&(i.disabled!==!0||"click"!==a.type)){for(e=[],f=0;h>f;f++)d=b[f],c=d.selector+" ",void 0===e[c]&&(e[c]=d.needsContext?m(c,this).index(i)>=0:m.find(c,this,null,[i]).length),e[c]&&e.push(d);e.length&&g.push({elem:i,handlers:e})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},fix:function(a){if(a[m.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];g||(this.fixHooks[e]=g=Z.test(e)?this.mouseHooks:Y.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new m.Event(f),b=d.length;while(b--)c=d[b],a[c]=f[c];return a.target||(a.target=f.srcElement||y),3===a.target.nodeType&&(a.target=a.target.parentNode),a.metaKey=!!a.metaKey,g.filter?g.filter(a,f):a},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button,g=b.fromElement;');
print_out('return null==a.pageX&&null!=b.clientX&&(d=a.target.ownerDocument||y,e=d.documentElement,c=d.body,a.pageX=b.clientX+(e&&e.scrollLeft||c&&c.scrollLeft||0)-(e&&e.clientLeft||c&&c.clientLeft||0),a.pageY=b.clientY+(e&&e.scrollTop||c&&c.scrollTop||0)-(e&&e.clientTop||c&&c.clientTop||0)),!a.relatedTarget&&g&&(a.relatedTarget=g===a.target?b.toElement:g),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==cb()&&this.focus)try{return this.focus(),!1}catch(a){}},delegateType:"focusin"},blur:{trigger:function(){return this===cb()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return m.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):void 0},_default:function(a){return m.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=m.extend(new m.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?m.event.trigger(e,null,b):m.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},m.removeEvent=y.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){var d="on"+b;a.detachEvent&&(typeof a[d]===K&&(a[d]=null),a.detachEvent(d,c))},m.Event=function(a,b){return this instanceof m.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?ab:bb):this.type=a,b&&m.extend(this,b),this.timeStamp=a&&a.timeStamp||m.now(),void(this[m.expando]=!0)):new m.Event(a,b)},m.Event.prototype={isDefaultPrevented:bb,isPropagationStopped:bb,isImmediatePropagationStopped:bb,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=ab,a&&(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=ab,a&&(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){var a=this.originalEvent;');
print_out('this.isImmediatePropagationStopped=ab,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},m.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){m.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!m.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.submitBubbles||(m.event.special.submit={setup:function(){return m.nodeName(this,"form")?!1:void m.event.add(this,"click._submit keypress._submit",function(a){var b=a.target,c=m.nodeName(b,"input")||m.nodeName(b,"button")?b.form:void 0;c&&!m._data(c,"submitBubbles")&&(m.event.add(c,"submit._submit",function(a){a._submit_bubble=!0}),m._data(c,"submitBubbles",!0))})},postDispatch:function(a){a._submit_bubble&&(delete a._submit_bubble,this.parentNode&&!a.isTrigger&&m.event.simulate("submit",this.parentNode,a,!0))},teardown:');
print_out('function(){return m.nodeName(this,"form")?!1:void m.event.remove(this,"._submit")}}),k.changeBubbles||(m.event.special.change={setup:function(){return X.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(m.event.add(this,"propertychange._change",function(a){"checked"===a.originalEvent.propertyName&&(this._just_changed=!0)}),m.event.add(this,"click._change",function(a){this._just_changed&&!a.isTrigger&&(this._just_changed=!1),m.event.simulate("change",this,a,!0)})),!1):void m.event.add(this,"beforeactivate._change",function(a){var b=a.target;X.test(b.nodeName)&&!m._data(b,"changeBubbles")&&(m.event.add(b,"change._change",function(a){!this.parentNode||a.isSimulated||a.isTrigger||m.event.simulate("change",this.parentNode,a,!0)}),m._data(b,"changeBubbles",!0))})},handle:function(a){var b=a.target;return this!==b||a.isSimulated||a.isTrigger||"radio"!==b.type&&"checkbox"!==b.type?a.handleObj.handler.apply(this,arguments):void 0},teardown:function(){return m.event.remove(this,"._change"),!X.test(this.nodeName)}}),k.focusinBubbles||m.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){m.event.simulate(b,a.target,m.event.fix(a),!0)};');
print_out('m.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=m._data(d,b);e||d.addEventListener(a,c,!0),m._data(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=m._data(d,b)-1;e?m._data(d,b,e):(d.removeEventListener(a,c,!0),m._removeData(d,b))}}}),m.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(f in a)this.on(f,b,c,a[f],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=bb;else if(!d)return this;return 1===e&&(g=d,d=function(a){return m().off(a),g.apply(this,arguments)},d.guid=g.guid||(g.guid=m.guid++)),this.each(function(){m.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,m(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);');
print_out('return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=bb),this.each(function(){m.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){m.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?m.event.trigger(a,b,c,!0):void 0}});function db(a){var b=eb.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}var eb="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",fb=/ jQuery\\d+="(?:null|\\d+)"/g,gb=new RegExp("<(?:"+eb+")[\\\\s/>]","i"),hb=/^\\s+/,ib=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\\w:]+)[^>]*)\\/>/gi,jb=/<([\\w:]+)/,kb=/<tbody/i,lb=/<|&#?\\w+;/,mb=/<(?:script|style|link)/i,nb=/checked\\s*(?:[^=]|=\\s*.checked.)/i,ob=/^$|\\/(?:java|ecma)script/i,pb=/^true\\/(.*)/,qb=/^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g,rb={option:[1,"<select multiple=''multiple''>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:k.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},sb=db(y),tb=sb.appendChild(y.createElement("div"));rb.optgroup=rb.option,rb.tbody=rb.tfoot=rb.colgroup=rb.caption=rb.thead,rb.th=rb.td;function ub(a,b){var c,d,e=0,f=typeof a.getElementsByTagName!==K?a.getElementsByTagName(b||"*"):typeof a.querySelectorAll!==K?a.querySelectorAll(b||"*"):void 0;if(!f)for(f=[],c=a.childNodes||a;null!=(d=c[e]);');
print_out('e++)!b||m.nodeName(d,b)?f.push(d):m.merge(f,ub(d,b));return void 0===b||b&&m.nodeName(a,b)?m.merge([a],f):f}function vb(a){W.test(a.type)&&(a.defaultChecked=a.checked)}function wb(a,b){return m.nodeName(a,"table")&&m.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function xb(a){return a.type=(null!==m.find.attr(a,"type"))+"/"+a.type,a}function yb(a){var b=pb.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function zb(a,b){for(var c,d=0;null!=(c=a[d]);d++)m._data(c,"globalEval",!b||m._data(b[d],"globalEval"))}function Ab(a,b){if(1===b.nodeType&&m.hasData(a)){var c,d,e,f=m._data(a),g=m._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;e>d;d++)m.event.add(b,c,h[c][d])}g.data&&(g.data=m.extend({},g.data))}}function Bb(a,b){var c,d,e;if(1===b.nodeType){if(c=b.nodeName.toLowerCase(),!k.noCloneEvent&&b[m.expando]){e=m._data(b);for(d in e.events)m.removeEvent(b,d,e.handle);b.removeAttribute(m.expando)}"script"===c&&b.text!==a.text?(xb(b).text=a.text,yb(b)):"object"===c?(b.parentNode&&(b.outerHTML=a.outerHTML),k.html5Clone&&a.innerHTML&&!m.trim(b.innerHTML)&&(b.innerHTML=a.innerHTML)):"input"===c&&W.test(a.type)?(b.defaultChecked=b.checked=a.checked,b.value!==a.value&&(b.value=a.value)):"option"===c?b.defaultSelected=b.selected=a.defaultSelected:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}}');
print_out('m.extend({clone:function(a,b,c){var d,e,f,g,h,i=m.contains(a.ownerDocument,a);if(k.html5Clone||m.isXMLDoc(a)||!gb.test("<"+a.nodeName+">")?f=a.cloneNode(!0):(tb.innerHTML=a.outerHTML,tb.removeChild(f=tb.firstChild)),!(k.noCloneEvent&&k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||m.isXMLDoc(a)))for(d=ub(f),h=ub(a),g=0;null!=(e=h[g]);++g)d[g]&&Bb(e,d[g]);if(b)if(c)for(h=h||ub(a),d=d||ub(f),g=0;null!=(e=h[g]);g++)Ab(e,d[g]);else Ab(a,f);return d=ub(f,"script"),d.length>0&&zb(d,!i&&ub(a,"script")),d=h=e=null,f},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,l,n=a.length,o=db(b),p=[],q=0;n>q;q++)if(f=a[q],f||0===f)if("object"===m.type(f))m.merge(p,f.nodeType?[f]:f);else if(lb.test(f)){h=h||o.appendChild(b.createElement("div")),i=(jb.exec(f)||["",""])[1].toLowerCase(),l=rb[i]||rb._default,h.innerHTML=l[1]+f.replace(ib,"<$1></$2>")+l[2],e=l[0];while(e--)h=h.lastChild;if(!k.leadingWhitespace&&hb.test(f)&&p.push(b.createTextNode(hb.exec(f)[0])),!k.tbody){f="table"!==i||kb.test(f)?"<table>"!==l[1]||kb.test(f)?0:h:h.firstChild,e=f&&f.childNodes.length;while(e--)m.nodeName(j=f.childNodes[e],"tbody")&&!j.childNodes.length&&f.removeChild(j)}m.merge(p,h.childNodes),h.textContent="";while(h.firstChild)h.removeChild(h.firstChild);h=o.lastChild}else p.push(b.createTextNode(f));');
print_out('h&&o.removeChild(h),k.appendChecked||m.grep(ub(p,"input"),vb),q=0;while(f=p[q++])if((!d||-1===m.inArray(f,d))&&(g=m.contains(f.ownerDocument,f),h=ub(o.appendChild(f),"script"),g&&zb(h),c)){e=0;while(f=h[e++])ob.test(f.type||"")&&c.push(f)}return h=null,o},cleanData:function(a,b){for(var d,e,f,g,h=0,i=m.expando,j=m.cache,l=k.deleteExpando,n=m.event.special;null!=(d=a[h]);h++)if((b||m.acceptData(d))&&(f=d[i],g=f&&j[f])){if(g.events)for(e in g.events)n[e]?m.event.remove(d,e):m.removeEvent(d,e,g.handle);j[f]&&(delete j[f],l?delete d[i]:typeof d.removeAttribute!==K?d.removeAttribute(i):d[i]=null,c.push(f))}}}),m.fn.extend({text:function(a){return V(this,function(a){return void 0===a?m.text(this):this.empty().append((this[0]&&this[0].ownerDocument||y).createTextNode(a))},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wb(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wb(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,');
print_out('function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?m.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||m.cleanData(ub(c)),c.parentNode&&(b&&m.contains(c.ownerDocument,c)&&zb(ub(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++){1===a.nodeType&&m.cleanData(ub(a,!1));while(a.firstChild)a.removeChild(a.firstChild);a.options&&m.nodeName(a,"select")&&(a.options.length=0)}return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return m.clone(this,a,b)})},html:function(a){return V(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a)return 1===b.nodeType?b.innerHTML.replace(fb,""):void 0;if(!("string"!=typeof a||mb.test(a)||!k.htmlSerialize&&gb.test(a)||!k.leadingWhitespace&&hb.test(a)||rb[(jb.exec(a)||["",""])[1].toLowerCase()])){a=a.replace(ib,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(m.cleanData(ub(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];');
print_out('return this.domManip(arguments,function(b){a=this.parentNode,m.cleanData(ub(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,n=this,o=l-1,p=a[0],q=m.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&nb.test(p))return this.each(function(c){var d=n.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(i=m.buildFragment(a,this[0].ownerDocument,!1,this),c=i.firstChild,1===i.childNodes.length&&(i=c),c)){for(g=m.map(ub(i,"script"),xb),f=g.length;l>j;j++)d=i,j!==o&&(d=m.clone(d,!0,!0),f&&m.merge(g,ub(d,"script"))),b.call(this[j],d,j);if(f)for(h=g[g.length-1].ownerDocument,m.map(g,yb),j=0;f>j;j++)d=g[j],ob.test(d.type||"")&&!m._data(d,"globalEval")&&m.contains(h,d)&&(d.src?m._evalUrl&&m._evalUrl(d.src):m.globalEval((d.text||d.textContent||d.innerHTML||"").replace(qb,"")));i=c=null}return this}}),m.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){m.fn[a]=function(a){for(var c,d=0,e=[],g=m(a),h=g.length-1;h>=d;d++)c=d===h?this:this.clone(!0),m(g[d])[b](c),f.apply(e,c.get());return this.pushStack(e)}});var Cb,Db={};');
print_out('function Eb(b,c){var d,e=m(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:m.css(e[0],"display");return e.detach(),f}function Fb(a){var b=y,c=Db[a];return c||(c=Eb(a,b),"none"!==c&&c||(Cb=(Cb||m("<iframe frameborder=''0'' width=''0'' height=''0''/>")).appendTo(b.documentElement),b=(Cb[0].contentWindow||Cb[0].contentDocument).document,b.write(),b.close(),c=Eb(a,b),Cb.detach()),Db[a]=c),c}!function(){var a;k.shrinkWrapBlocks=function(){if(null!=a)return a;a=!1;var b,c,d;return c=y.getElementsByTagName("body")[0],c&&c.style?(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1",b.appendChild(y.createElement("div")).style.width="5px",a=3!==b.offsetWidth),c.removeChild(d),a):void 0}}();');
print_out('var Gb=/^margin/,Hb=new RegExp("^("+S+")(?!px)[a-z%]+$","i"),Ib,Jb,Kb=/^(top|right|bottom|left)$/;a.getComputedStyle?(Ib=function(a){return a.ownerDocument.defaultView.getComputedStyle(a,null)},Jb=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ib(a),g=c?c.getPropertyValue(b)||c[b]:void 0,c&&(""!==g||m.contains(a.ownerDocument,a)||(g=m.style(a,b)),Hb.test(g)&&Gb.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0===g?g:g+""}):y.documentElement.currentStyle&&(Ib=function(a){return a.currentStyle},Jb=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ib(a),g=c?c[b]:void 0,null==g&&h&&h[b]&&(g=h[b]),Hb.test(g)&&!Kb.test(b)&&(d=h.left,e=a.runtimeStyle,f=e&&e.left,f&&(e.left=a.currentStyle.left),h.left="fontSize"===b?"1em":g,g=h.pixelLeft+"px",h.left=d,f&&(e.left=f)),void 0===g?g:g+""||"auto"});function Lb(a,b){return{get:');
print_out('function(){var c=a();if(null!=c)return c?void delete this.get:(this.get=b).apply(this,arguments)}}}!function(){var b,c,d,e,f,g,h;if(b=y.createElement("div"),b.innerHTML="  <link/><table></table><a href=''/a''>a</a><input type=''checkbox''/>",d=b.getElementsByTagName("a")[0],c=d&&d.style){c.cssText="float:left;opacity:.5",k.opacity="0.5"===c.opacity,k.cssFloat=!!c.cssFloat,b.style.backgroundClip="content-box",b.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===b.style.backgroundClip,k.boxSizing=""===c.boxSizing||""===c.MozBoxSizing||""===c.WebkitBoxSizing,m.extend(k,{reliableHiddenOffsets:function(){return null==g&&i(),g},boxSizingReliable:function(){return null==f&&i(),f},pixelPosition:function(){return null==e&&i(),e},reliableMarginRight:function(){return null==h&&i(),h}});function i(){var b,c,d,i;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),b.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",e=f=!1,h=!0,a.getComputedStyle&&(e="1%"!==(a.getComputedStyle(b,null)||{}).top,f="4px"===(a.getComputedStyle(b,null)||{width:"4px"}).width,i=b.appendChild(y.createElement("div")),i.style.cssText=b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",i.style.marginRight=i.style.width="0",b.style.width="1px",h=!parseFloat((a.getComputedStyle(i,null)||{}).marginRight)),b.innerHTML="<table><tr><td></td><td>t</td></tr></table>",i=b.getElementsByTagName("td"),i[0].style.cssText="margin:0;border:0;padding:0;display:none",g=0===i[0].offsetHeight,g&&(i[0].style.display="",i[1].style.display="none",g=0===i[0].offsetHeight),c.removeChild(d))}}}(),m.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var Mb=/alpha\\([^)]*\\)/i,Nb=/opacity\\s*=\\s*([^)]*)/,Ob=/^(none|table(?!-c[ea]).+)/,Pb=new RegExp("^("+S+")(.*)$","i"),Qb=new RegExp("^([+-])=("+S+")","i"),Rb={position:"absolute",visibility:"hidden",display:"block"},Sb={letterSpacing:"0",fontWeight:"400"},Tb=["Webkit","O","Moz","ms"];function Ub(a,b){if(b in a)return b;var c=b.charAt(0).');
print_out('toUpperCase()+b.slice(1),d=b,e=Tb.length;while(e--)if(b=Tb[e]+c,b in a)return b;return d}function Vb(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=m._data(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&U(d)&&(f[g]=m._data(d,"olddisplay",Fb(d.nodeName)))):(e=U(d),(c&&"none"!==c||!e)&&m._data(d,"olddisplay",e?c:m.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Wb(a,b,c){var d=Pb.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Xb(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=m.css(a,c+T[f],!0,e)),d?("content"===c&&(g-=m.css(a,"padding"+T[f],!0,e)),"margin"!==c&&(g-=m.css(a,"border"+T[f]+"Width",!0,e))):(g+=m.css(a,"padding"+T[f],!0,e),"padding"!==c&&(g+=m.css(a,"border"+T[f]+"Width",!0,e)));return g}function Yb(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=Ib(a),g=k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=Jb(a,b,f),(0>e||null==e)&&(e=a.style[b]),Hb.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Xb(a,b,c||(g?"border":"content"),d,f)+"px"}m.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Jb(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":k.cssFloat?"cssFloat":"styleFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=m.camelCase(b),i=a.style;');
print_out('if(b=m.cssProps[h]||(m.cssProps[h]=Ub(i,h)),g=m.cssHooks[b]||m.cssHooks[h],void 0===c)return g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b];if(f=typeof c,"string"===f&&(e=Qb.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(m.css(a,b)),f="number"),null!=c&&c===c&&("number"!==f||m.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),!(g&&"set"in g&&void 0===(c=g.set(a,c,d)))))try{i[b]=c}catch(j){}}},css:function(a,b,c,d){var e,f,g,h=m.camelCase(b);return b=m.cssProps[h]||(m.cssProps[h]=Ub(a.style,h)),g=m.cssHooks[b]||m.cssHooks[h],g&&"get"in g&&(f=g.get(a,!0,c)),void 0===f&&(f=Jb(a,b,d)),"normal"===f&&b in Sb&&(f=Sb[b]),""===c||c?(e=parseFloat(f),c===!0||m.isNumeric(e)?e||0:f):f}}),m.each(["height","width"],function(a,b){m.cssHooks[b]={get:function(a,c,d){return c?Ob.test(m.css(a,"display"))&&0===a.offsetWidth?m.swap(a,Rb,function(){return Yb(a,b,d)}):Yb(a,b,d):void 0},set:function(a,c,d){var e=d&&Ib(a);return Wb(a,c,d?Xb(a,b,d,k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,e),e):0)}}}),k.opacity||(m.cssHooks.opacity={get:function(a,b){');
print_out('return Nb.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=m.isNumeric(b)?"alpha(opacity="+100*b+")":"",f=d&&d.filter||c.filter||"";c.zoom=1,(b>=1||""===b)&&""===m.trim(f.replace(Mb,""))&&c.removeAttribute&&(c.removeAttribute("filter"),""===b||d&&!d.filter)||(c.filter=Mb.test(f)?f.replace(Mb,e):f+" "+e)}}),m.cssHooks.marginRight=Lb(k.reliableMarginRight,function(a,b){return b?m.swap(a,{display:"inline-block"},Jb,[a,"marginRight"]):void 0}),m.each({margin:"",padding:"",border:"Width"},function(a,b){m.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+T[d]+b]=f[d]||f[d-2]||f[0];return e}},Gb.test(a)||(m.cssHooks[a+b].set=Wb)}),m.fn.extend({css:function(a,b){return V(this,function(a,b,c){var d,e,f={},g=0;if(m.isArray(b)){for(d=Ib(a),e=b.length;e>g;g++)f[b[g]]=m.css(a,b[g],!1,d);return f}return void 0!==c?m.style(a,b,c):m.css(a,b)},a,b,arguments.length>1)},show:function(){return Vb(this,!0)},hide:function(){return Vb(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){U(this)?m(this).show():m(this).hide()})}});function Zb(a,b,c,d,e){return new Zb.prototype.init(a,b,c,d,e)}m.Tween=Zb,Zb.prototype={constructor:Zb,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(m.cssNumber[c]?"":"px")');
print_out('},cur:function(){var a=Zb.propHooks[this.prop];return a&&a.get?a.get(this):Zb.propHooks._default.get(this)},run:function(a){var b,c=Zb.propHooks[this.prop];return this.pos=b=this.options.duration?m.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Zb.propHooks._default.set(this),this}},Zb.prototype.init.prototype=Zb.prototype,Zb.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=m.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){m.fx.step[a.prop]?m.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[m.cssProps[a.prop]]||m.cssHooks[a.prop])?m.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Zb.propHooks.scrollTop=Zb.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},m.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},m.fx=Zb.prototype.init,m.fx.step={};var $b,_b,ac=/^(?:toggle|show|hide)$/,bc=new RegExp("^(?:([+-])=|)("+S+")([a-z%]*)$","i"),cc=/queueHooks$/,dc=[ic],ec={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=bc.exec(b),f=e&&e[3]||(m.cssNumber[a]?"":"px"),g=(m.cssNumber[a]||"px"!==f&&+d)&&bc.exec(m.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do h=h||".5",g/=h,m.style(c.elem,a,g+f);while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};function fc(){return setTimeout(function(){$b=void 0}),$b=m.now()}function gc(a,b){var c,d={height:a},e=0;for(b=b?1:0;4>e;e+=2-b)c=T[e],d["margin"+c]=d["padding"+c]=a;return b&&(d.opacity=d.width=a),d}');
print_out('function hc(a,b,c){for(var d,e=(ec[b]||[]).concat(ec["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function ic(a,b,c){var d,e,f,g,h,i,j,l,n=this,o={},p=a.style,q=a.nodeType&&U(a),r=m._data(a,"fxshow");c.queue||(h=m._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,n.always(function(){n.always(function(){h.unqueued--,m.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[p.overflow,p.overflowX,p.overflowY],j=m.css(a,"display"),l="none"===j?m._data(a,"olddisplay")||Fb(a.nodeName):j,"inline"===l&&"none"===m.css(a,"float")&&(k.inlineBlockNeedsLayout&&"inline"!==Fb(a.nodeName)?p.zoom=1:p.display="inline-block")),c.overflow&&(p.overflow="hidden",k.shrinkWrapBlocks()||n.always(function(){p.overflow=c.overflow[0],p.overflowX=c.overflow[1],p.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],ac.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(q?"hide":"show")){if("show"!==e||!r||void 0===r[d])continue;q=!0}o[d]=r&&r[d]||m.style(a,d)}else j=void 0;if(m.isEmptyObject(o))"inline"===("none"===j?Fb(a.nodeName):j)&&(p.display=j);else{r?"hidden"in r&&(q=r.hidden):r=m._data(a,"fxshow",{}),f&&(r.hidden=!q),q?m(a).show():n.done(function(){m(a).hide()}),n.done(function(){var b;m._removeData(a,"fxshow");for(b in o)m.style(a,b,o[b])});for(d in o)g=hc(q?r[d]:0,d,n),d in r||(r[d]=g.start,q&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function jc(a,b){var c,d,e,f,g;for(c in a)if(d=m.camelCase(c),e=b[d],f=a[c],m.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=m.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function kc(a,b,c){var d,e,f=0,g=dc.length,h=m.Deferred().always(function(){delete i.elem}),i=function()');
print_out('{if(e)return!1;for(var b=$b||fc(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:m.extend({},b),opts:m.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:$b||fc(),duration:c.duration,tweens:[],createTween:function(b,c){var d=m.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(jc(k,j.opts.specialEasing);g>f;f++)if(d=dc[f].call(j,a,k,j.opts))return d;return m.map(k,hc,j),m.isFunction(j.opts.start)&&j.opts.start.call(a,j),m.fx.timer(m.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}m.Animation=m.extend(kc,{tweener:function(a,b){m.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],ec[c]=ec[c]||[],ec[c].unshift(b)},prefilter:function(a,b){b?dc.unshift(a):dc.push(a)}}),m.speed=function(a,b,c){var d=a&&"object"==typeof a?m.extend({},a):{complete:c||!c&&b||m.isFunction(a)&&a,duration:a,easing:c&&b||b&&!m.isFunction(b)&&b};return d.duration=m.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in m.fx.speeds?m.fx.speeds[d.duration]:m.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function()');
print_out('{m.isFunction(d.old)&&d.old.call(this),d.queue&&m.dequeue(this,d.queue)},d},m.fn.extend({fadeTo:function(a,b,c,d){return this.filter(U).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=m.isEmptyObject(a),f=m.speed(b,c,d),g=function(){var b=kc(this,m.extend({},a),f);(e||m._data(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=m.timers,g=m._data(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&cc.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&m.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=m._data(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=m.timers,g=d?d.length:0;for(c.finish=!0,m.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),m.each(["toggle","show","hide"],function(a,b){var c=m.fn[b];m.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(gc(b,!0),a,d,e)}}),m.each({slideDown:gc("show"),slideUp:gc("hide"),slideToggle:gc("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){m.fn[a]=');
print_out('function(a,c,d){return this.animate(b,a,c,d)}}),m.timers=[],m.fx.tick=function(){var a,b=m.timers,c=0;for($b=m.now();c<b.length;c++)a=b[c],a()||b[c]!==a||b.splice(c--,1);b.length||m.fx.stop(),$b=void 0},m.fx.timer=function(a){m.timers.push(a),a()?m.fx.start():m.timers.pop()},m.fx.interval=13,m.fx.start=function(){_b||(_b=setInterval(m.fx.tick,m.fx.interval))},m.fx.stop=function(){clearInterval(_b),_b=null},m.fx.speeds={slow:600,fast:200,_default:400},m.fn.delay=function(a,b){return a=m.fx?m.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},function(){var a,b,c,d,e;b=y.createElement("div"),b.setAttribute("className","t"),b.innerHTML="  <link/><table></table><a href=''/a''>a</a><input type=''checkbox''/>",d=b.getElementsByTagName("a")[0],c=y.createElement("select"),e=c.appendChild(y.createElement("option")),a=b.getElementsByTagName("input")[0],d.style.cssText="top:1px",k.getSetAttribute="t"!==b.className,k.style=/top/.test(d.getAttribute("style")),k.hrefNormalized="/a"===d.getAttribute("href"),k.checkOn=!!a.value,k.optSelected=e.selected,k.enctype=!!y.createElement("form").enctype,c.disabled=!0,k.optDisabled=!e.disabled,a=y.createElement("input"),a.setAttribute("value",""),k.input=""===a.getAttribute("value"),a.value="t",a.setAttribute("type","radio"),k.radioValue="t"===a.value}();var lc=/\\r/g;m.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=m.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,m(this).val()):a,null==e?e="":"number"==typeof e?e+="":m.isArray(e)&&(e=m.map(e,function(a){return null==a?"":a+""})),b=m.valHooks[this.type]||m.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=m.valHooks[e.type]||m.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(lc,""):null==c?"":c)}}}),m.extend({valHooks:{option:{get:');
print_out('function(a){var b=m.find.attr(a,"value");return null!=b?b:m.trim(m.text(a))}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],!(!c.selected&&i!==e||(k.optDisabled?c.disabled:null!==c.getAttribute("disabled"))||c.parentNode.disabled&&m.nodeName(c.parentNode,"optgroup"))){if(b=m(c).val(),f)return b;g.push(b)}return g},set:function(a,b){var c,d,e=a.options,f=m.makeArray(b),g=e.length;while(g--)if(d=e[g],m.inArray(m.valHooks.option.get(d),f)>=0)try{d.selected=c=!0}catch(h){d.scrollHeight}else d.selected=!1;return c||(a.selectedIndex=-1),e}}}}),m.each(["radio","checkbox"],function(){m.valHooks[this]={set:function(a,b){return m.isArray(b)?a.checked=m.inArray(m(a).val(),b)>=0:void 0}},k.checkOn||(m.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var mc,nc,oc=m.expr.attrHandle,pc=/^(?:checked|selected)$/i,qc=k.getSetAttribute,rc=k.input;m.fn.extend({attr:function(a,b){return V(this,m.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){m.removeAttr(this,a)})}}),m.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(a&&3!==f&&8!==f&&2!==f)return typeof a.getAttribute===K?m.prop(a,b,c):(1===f&&m.isXMLDoc(a)||(b=b.toLowerCase(),d=m.attrHooks[b]||(m.expr.match.bool.test(b)?nc:mc)),void 0===c?d&&"get"in d&&null!==(e=d.get(a,b))?e:(e=m.find.attr(a,b),null==e?void 0:e):null!==c?d&&"set"in d&&void 0!==(e=d.set(a,c,b))?e:(a.setAttribute(b,c+""),c):void m.removeAttr(a,b))},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)while(c=f[e++])d=m.propFix[c]||c,m.expr.match.bool.test(c)?rc&&qc||!pc.test(c)?a[d]=!1:a[m.camelCase("default-"+c)]=a[d]=!1:m.attr(a,c,""),a.removeAttribute(qc?c:d)},attrHooks:{type:{set:');
print_out('function(a,b){if(!k.radioValue&&"radio"===b&&m.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}}}),nc={set:function(a,b,c){return b===!1?m.removeAttr(a,c):rc&&qc||!pc.test(c)?a.setAttribute(!qc&&m.propFix[c]||c,c):a[m.camelCase("default-"+c)]=a[c]=!0,c}},m.each(m.expr.match.bool.source.match(/\\w+/g),function(a,b){var c=oc[b]||m.find.attr;oc[b]=rc&&qc||!pc.test(b)?function(a,b,d){var e,f;return d||(f=oc[b],oc[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,oc[b]=f),e}:function(a,b,c){return c?void 0:a[m.camelCase("default-"+b)]?b.toLowerCase():null}}),rc&&qc||(m.attrHooks.value={set:function(a,b,c){return m.nodeName(a,"input")?void(a.defaultValue=b):mc&&mc.set(a,b,c)}}),qc||(mc={set:function(a,b,c){var d=a.getAttributeNode(c);return d||a.setAttributeNode(d=a.ownerDocument.createAttribute(c)),d.value=b+="","value"===c||b===a.getAttribute(c)?b:void 0}},oc.id=oc.name=oc.coords=function(a,b,c){var d;return c?void 0:(d=a.getAttributeNode(b))&&""!==d.value?d.value:null},m.valHooks.button={get:function(a,b){var c=a.getAttributeNode(b);return c&&c.specified?c.value:void 0},set:mc.set},m.attrHooks.contenteditable={set:function(a,b,c){mc.set(a,""===b?!1:b,c)}},m.each(["width","height"],function(a,b){m.attrHooks[b]={set:function(a,c){return""===c?(a.setAttribute(b,"auto"),c):void 0}}})),k.style||(m.attrHooks.style={get:function(a){return a.style.cssText||void 0},set:function(a,b){return a.style.cssText=b+""}});var sc=/^(?:input|select|textarea|button|object)$/i,tc=/^(?:a|area)$/i;m.fn.extend({prop:function(a,b){return V(this,m.prop,a,b,arguments.length>1)},removeProp:function(a){return a=m.propFix[a]||a,this.each(function(){try{this[a]=void 0,delete this[a]}catch(b){}})}}),m.extend({propFix:{"for":"htmlFor","class":"className"},prop:function(a,b,c){var d,e,f,g=a.nodeType;if(a&&3!==g&&8!==g&&2!==g)return f=1!==g||!m.isXMLDoc(a),f&&(b=m.propFix[b]||b,e=m.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=m.find.attr(a,"tabindex");');
print_out('return b?parseInt(b,10):sc.test(a.nodeName)||tc.test(a.nodeName)&&a.href?0:-1}}}}),k.hrefNormalized||m.each(["href","src"],function(a,b){m.propHooks[b]={get:function(a){return a.getAttribute(b,4)}}}),k.optSelected||(m.propHooks.selected={get:function(a){var b=a.parentNode;return b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex),null}}),m.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){m.propFix[this.toLowerCase()]=this}),k.enctype||(m.propFix.enctype="encoding");var uc=/[\\t\\r\\n\\f]/g;m.fn.extend({addClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j="string"==typeof a&&a;if(m.isFunction(a))');
print_out('return this.each(function(b){m(this).addClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(uc," "):" ")){f=0;while(e=b[f++])d.indexOf(" "+e+" ")<0&&(d+=e+" ");g=m.trim(d),c.className!==g&&(c.className=g)}return this},removeClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j=0===arguments.length||"string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).removeClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(uc," "):"")){f=0;while(e=b[f++])while(d.indexOf(" "+e+" ")>=0)d=d.replace(" "+e+" "," ");g=a?m.trim(d):"",c.className!==g&&(c.className=g)}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):this.each(m.isFunction(a)?function(c){m(this).toggleClass(a.call(this,c,this.className,b),b)}:function(){if("string"===c){var b,d=0,e=m(this),f=a.match(E)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else(c===K||"boolean"===c)&&(this.className&&m._data(this,"__className__",this.className),this.className=this.className||a===!1?"":m._data(this,"__className__")||"")})},hasClass:function(a){for(var b=" "+a+" ",c=0,d=this.length;d>c;c++)if(1===this[c].nodeType&&(" "+this[c].className+" ").replace(uc," ").indexOf(b)>=0)return!0;return!1}}),m.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){m.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),m.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:');
print_out('function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}});var vc=m.now(),wc=/\\?/,xc=/(,)|(\\[|{)|(}|])|"(?:[^"\\\\\\r\\n]|\\\\["\\\\\\/bfnrt]|\\\\u[\\da-fA-F]{4})*"\\s*:?|true|false|null|-?(?!0\\d)\\d+(?:\\.\\d+|)(?:[eE][+-]?\\d+|)/g;m.parseJSON=function(b){if(a.JSON&&a.JSON.parse)return a.JSON.parse(b+"");var c,d=null,e=m.trim(b+"");return e&&!m.trim(e.replace(xc,function(a,b,e,f){return c&&b&&(d=0),0===d?a:(c=e||b,d+=!f-!e,"")}))?Function("return "+e)():m.error("Invalid JSON: "+b)},m.parseXML=function(b){var c,d;if(!b||"string"!=typeof b)return null;try{a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b))}catch(e){c=void 0}return c&&c.documentElement&&!c.getElementsByTagName("parsererror").length||m.error("Invalid XML: "+b),c};var yc,zc,Ac=/#.*$/,Bc=/([?&])_=[^&]*/,Cc=/^(.*?):[ \\t]*([^\\r\\n]*)\\r?$/gm,Dc=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Ec=/^(?:GET|HEAD)$/,Fc=/^\\/\\//,Gc=/^([\\w.+-]+:)(?:\\/\\/(?:[^\\/?#]*@|)([^\\/?#:]*)(?::(\\d+)|)|)/,Hc={},Ic={},Jc="*/".concat("*");try{zc=location.href}catch(Kc){zc=y.createElement("a"),zc.href="",zc=zc.href}yc=Gc.exec(zc.toLowerCase())||[];function Lc(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(m.isFunction(c))while(d=f[e++])"+"===d.charAt(0)?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Mc(a,b,c,d){var e={},f=a===Ic;function g(h){var i;return e[h]=!0,m.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Nc(a,b){var c,d,e=m.ajaxSettings.flatOptions||{};for(d in b)void 0!==b[d]&&((e[d]?a:c||(c={}))[d]=b[d]);return c&&m.extend(!0,a,c),a}function Oc(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===e&&(e=a.mimeType||b.getResponseHeader("Content-Type"));');
print_out('if(e)for(g in h)if(h[g]&&h[g].test(e)){i.unshift(g);break}if(i[0]in c)f=i[0];else{for(g in c){if(!i[0]||a.converters[g+" "+i[0]]){f=g;break}d||(d=g)}f=f||d}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function Pc(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}m.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:zc,type:"GET",isLocal:Dc.test(yc[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Jc,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":m.parseJSON,"text xml":m.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Nc(Nc(a,m.ajaxSettings),b):Nc(m.ajaxSettings,a)},ajaxPrefilter:Lc(Hc),ajaxTransport:Lc(Ic),ajax:');
print_out('function(a,b){"object"==typeof a&&(b=a,a=void 0),b=b||{};var c,d,e,f,g,h,i,j,k=m.ajaxSetup({},b),l=k.context||k,n=k.context&&(l.nodeType||l.jquery)?m(l):m.event,o=m.Deferred(),p=m.Callbacks("once memory"),q=k.statusCode||{},r={},s={},t=0,u="canceled",v={readyState:0,getResponseHeader:function(a){var b;if(2===t){if(!j){j={};while(b=Cc.exec(f))j[b[1].toLowerCase()]=b[2]}b=j[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?f:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return t||(a=s[c]=s[c]||a,r[a]=b),this},overrideMimeType:function(a){return t||(k.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>t)for(b in a)q[b]=[q[b],a[b]];else v.always(a[v.status]);return this},abort:function(a){var b=a||u;return i&&i.abort(b),x(0,b),this}};');
print_out('if(o.promise(v).complete=p.add,v.success=v.done,v.error=v.fail,k.url=((a||k.url||zc)+"").replace(Ac,"").replace(Fc,yc[1]+"//"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=m.trim(k.dataType||"*").toLowerCase().match(E)||[""],null==k.crossDomain&&(c=Gc.exec(k.url.toLowerCase()),k.crossDomain=!(!c||c[1]===yc[1]&&c[2]===yc[2]&&(c[3]||("http:"===c[1]?"80":"443"))===(yc[3]||("http:"===yc[1]?"80":"443")))),k.data&&k.processData&&"string"!=typeof k.data&&(k.data=m.param(k.data,k.traditional)),Mc(Hc,k,b,v),2===t)return v;h=k.global,h&&0===m.active++&&m.event.trigger("ajaxStart"),k.type=k.type.toUpperCase(),k.hasContent=!Ec.test(k.type),e=k.url,k.hasContent||(k.data&&(e=k.url+=(wc.test(e)?"&":"?")+k.data,delete k.data),k.cache===!1&&(k.url=Bc.test(e)?e.replace(Bc,"$1_="+vc++):e+(wc.test(e)?"&":"?")+"_="+vc++)),k.ifModified&&(m.lastModified[e]&&v.setRequestHeader("If-Modified-Since",m.lastModified[e]),m.etag[e]&&v.setRequestHeader("If-None-Match",m.etag[e])),(k.data&&k.hasContent&&k.contentType!==!1||b.contentType)&&v.setRequestHeader("Content-Type",k.contentType),v.setRequestHeader("Accept",k.dataTypes[0]&&k.accepts[k.dataTypes[0]]?k.accepts[k.dataTypes[0]]+("*"!==k.dataTypes[0]?", "+Jc+"; q=0.01":""):k.accepts["*"]);for(d in k.headers)v.setRequestHeader(d,k.headers[d]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u="abort";for(d in{success:1,error:1,complete:1})v[d](k[d]);if(i=Mc(Ic,k,b,v)){v.readyState=1,h&&n.trigger("ajaxSend",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort("timeout")},k.timeout));try{t=1,i.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,"No Transport");');
print_out('function x(a,b,c,d){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),i=void 0,f=d||"",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,c&&(u=Oc(k,v,c)),u=Pc(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader("Last-Modified"),w&&(m.lastModified[e]=w),w=v.getResponseHeader("etag"),w&&(m.etag[e]=w)),204===a||"HEAD"===k.type?x="nocontent":304===a?x="notmodified":(x=u.state,r=u.data,s=u.error,j=!s)):(s=x,(a||!x)&&(x="error",0>a&&(a=0))),v.status=a,v.statusText=(b||x)+"",j?o.resolveWith(l,[r,x,v]):o.rejectWith(l,[v,x,s]),v.statusCode(q),q=void 0,h&&n.trigger(j?"ajaxSuccess":"ajaxError",[v,k,j?r:s]),p.fireWith(l,[v,x]),h&&(n.trigger("ajaxComplete",[v,k]),--m.active||m.event.trigger("ajaxStop")))}return v},getJSON:function(a,b,c){return m.get(a,b,c,"json")},getScript:function(a,b){return m.get(a,void 0,b,"script")}}),m.each(["get","post"],function(a,b){m[b]=function(a,c,d,e){return m.isFunction(c)&&(e=e||d,d=c,c=void 0),m.ajax({url:a,type:b,dataType:e,data:c,success:d})}}),m.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){m.fn[b]=function(a){return this.on(b,a)}}),m._evalUrl=function(a){return m.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})},m.fn.extend({wrapAll:function(a){if(m.isFunction(a))return this.each(function(b){m(this).wrapAll(a.call(this,b))});if(this[0]){var b=m(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;');
print_out('while(a.firstChild&&1===a.firstChild.nodeType)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return this.each(m.isFunction(a)?function(b){m(this).wrapInner(a.call(this,b))}:function(){var b=m(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=m.isFunction(a);return this.each(function(c){m(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){m.nodeName(this,"body")||m(this).replaceWith(this.childNodes)}).end()}}),m.expr.filters.hidden=function(a){return a.offsetWidth<=0&&a.offsetHeight<=0||!k.reliableHiddenOffsets()&&"none"===(a.style&&a.style.display||m.css(a,"display"))},m.expr.filters.visible=function(a){return!m.expr.filters.hidden(a)};var Qc=/%20/g,Rc=/\\[\\]$/,Sc=/\\r?\\n/g,Tc=/^(?:submit|button|image|reset|file)$/i,Uc=/^(?:input|select|textarea|keygen)/i;function Vc(a,b,c,d){var e;if(m.isArray(b))m.each(b,function(b,e){c||Rc.test(a)?d(a,e):Vc(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==m.type(b))d(a,b);else for(e in b)Vc(a+"["+e+"]",b[e],c,d)}m.param=function(a,b){var c,d=[],e=function(a,b){b=m.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=m.ajaxSettings&&m.ajaxSettings.traditional),m.isArray(a)||a.jquery&&!m.isPlainObject(a))m.each(a,function(){e(this.name,this.value)});else for(c in a)Vc(c,a[c],b,e);return d.join("&").replace(Qc,"+")},m.fn.extend({serialize:function(){return m.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=m.prop(this,"elements");return a?m.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!m(this).is(":disabled")&&Uc.test(this.nodeName)&&!Tc.test(a)&&(this.checked||!W.test(a))}).map(function(a,b){var c=m(this).val();return null==c?null:m.isArray(c)?m.map(c,');
print_out('function(a){return{name:b.name,value:a.replace(Sc,"\\r\\n")}}):{name:b.name,value:c.replace(Sc,"\\r\\n")}}).get()}}),m.ajaxSettings.xhr=void 0!==a.ActiveXObject?function(){return!this.isLocal&&/^(get|post|head|put|delete|options)$/i.test(this.type)&&Zc()||$c()}:Zc;var Wc=0,Xc={},Yc=m.ajaxSettings.xhr();a.ActiveXObject&&m(a).on("unload",function(){for(var a in Xc)Xc[a](void 0,!0)}),k.cors=!!Yc&&"withCredentials"in Yc,Yc=k.ajax=!!Yc,Yc&&m.ajaxTransport(function(a){if(!a.crossDomain||k.cors){var b;return{send:function(c,d){var e,f=a.xhr(),g=++Wc;if(f.open(a.type,a.url,a.async,a.username,a.password),a.xhrFields)for(e in a.xhrFields)f[e]=a.xhrFields[e];a.mimeType&&f.overrideMimeType&&f.overrideMimeType(a.mimeType),a.crossDomain||c["X-Requested-With"]||(c["X-Requested-With"]="XMLHttpRequest");for(e in c)void 0!==c[e]&&f.setRequestHeader(e,c[e]+"");f.send(a.hasContent&&a.data||null),b=function(c,e){var h,i,j;if(b&&(e||4===f.readyState))if(delete Xc[g],b=void 0,f.onreadystatechange=m.noop,e)4!==f.readyState&&f.abort();else{j={},h=f.status,"string"==typeof f.responseText&&(j.text=f.responseText);try{i=f.statusText}catch(k){i=""}h||!a.isLocal||a.crossDomain?1223===h&&(h=204):h=j.text?200:404}j&&d(h,i,j,f.getAllResponseHeaders())},a.async?4===f.readyState?setTimeout(b):f.onreadystatechange=Xc[g]=b:b()},abort:function(){b&&b(void 0,!0)}}}});');
print_out('function Zc(){try{return new a.XMLHttpRequest}catch(b){}}function $c(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}m.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(a){return m.globalEval(a),a}}}),m.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),m.ajaxTransport("script",function(a){if(a.crossDomain){var b,c=y.head||m("head")[0]||y.documentElement;return{send:function(d,e){b=y.createElement("script"),b.async=!0,a.scriptCharset&&(b.charset=a.scriptCharset),b.src=a.url,b.onload=b.onreadystatechange=function(a,c){(c||!b.readyState||/loaded|complete/.test(b.readyState))&&(b.onload=b.onreadystatechange=null,b.parentNode&&b.parentNode.removeChild(b),b=null,c||e(200,"success"))},c.insertBefore(b,c.firstChild)},abort:function(){b&&b.onload(void 0,!0)}}}});var _c=[],ad=/(=)\\?(?=&|$)|\\?\\?/;m.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=_c.pop()||m.expando+"_"+vc++;return this[a]=!0,a}}),m.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(ad.test(b.url)?"url":"string"==typeof b.data&&!(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&ad.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=m.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(ad,"$1"+e):b.jsonp!==!1&&(b.url+=(wc.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||m.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,_c.push(e)),g&&m.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),m.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||y;var d=u.exec(a),e=!c&&[];');
print_out('return d?[b.createElement(d[1])]:(d=m.buildFragment([a],b,e),e&&e.length&&m(e).remove(),m.merge([],d.childNodes))};var bd=m.fn.load;m.fn.load=function(a,b,c){if("string"!=typeof a&&bd)return bd.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>=0&&(d=m.trim(a.slice(h,a.length)),a=a.slice(0,h)),m.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(f="POST"),g.length>0&&m.ajax({url:a,type:f,dataType:"html",data:b}).done(function(a){e=arguments,g.html(d?m("<div>").append(m.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,e||[a.responseText,b,a])}),this},m.expr.filters.animated=function(a){return m.grep(m.timers,function(b){return a===b.elem}).length};var cd=a.document.documentElement;function dd(a){return m.isWindow(a)?a:9===a.nodeType?a.defaultView||a.parentWindow:!1}m.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=m.css(a,"position"),l=m(a),n={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=m.css(a,"top"),i=m.css(a,"left"),j=("absolute"===k||"fixed"===k)&&m.inArray("auto",[f,i])>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),m.isFunction(b)&&(b=b.call(a,c,h)),null!=b.top&&(n.top=b.top-h.top+g),null!=b.left&&(n.left=b.left-h.left+e),"using"in b?b.using.call(a,n):l.css(n)}},m.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){m.offset.setOffset(this,a,b)});');
print_out('var b,c,d={top:0,left:0},e=this[0],f=e&&e.ownerDocument;if(f)return b=f.documentElement,m.contains(b,e)?(typeof e.getBoundingClientRect!==K&&(d=e.getBoundingClientRect()),c=dd(f),{top:d.top+(c.pageYOffset||b.scrollTop)-(b.clientTop||0),left:d.left+(c.pageXOffset||b.scrollLeft)-(b.clientLeft||0)}):d},position:function(){if(this[0]){var a,b,c={top:0,left:0},d=this[0];return"fixed"===m.css(d,"position")?b=d.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),m.nodeName(a[0],"html")||(c=a.offset()),c.top+=m.css(a[0],"borderTopWidth",!0),c.left+=m.css(a[0],"borderLeftWidth",!0)),{top:b.top-c.top-m.css(d,"marginTop",!0),left:b.left-c.left-m.css(d,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||cd;while(a&&!m.nodeName(a,"html")&&"static"===m.css(a,"position"))a=a.offsetParent;return a||cd})}}),m.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c=/Y/.test(b);m.fn[a]=function(d){return V(this,function(a,d,e){var f=dd(a);return void 0===e?f?b in f?f[b]:f.document.documentElement[d]:a[d]:void(f?f.scrollTo(c?m(f).scrollLeft():e,c?e:m(f).scrollTop()):a[d]=e)},a,d,arguments.length,null)}}),m.each(["top","left"],function(a,b){m.cssHooks[b]=Lb(k.pixelPosition,function(a,c){return c?(c=Jb(a,b),Hb.test(c)?m(a).position()[b]+"px":c):void 0})}),m.each({Height:"height",Width:"width"},function(a,b){m.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){m.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");');
print_out('return V(this,function(b,c,d){var e;return m.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?m.css(b,c,g):m.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),m.fn.size=function(){return this.length},m.fn.andSelf=m.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return m});var ed=a.jQuery,fd=a.$;return m.noConflict=function(b){return a.$===m&&(a.$=fd),b&&a.jQuery===m&&(a.jQuery=ed),m},typeof b===K&&(a.jQuery=a.$=m),m});');
print_out('</script>');
print_out('<script type="text/javascript">
/*!
* TableSorter 2.15.3 min - Client-side table sorting with ease!
* Copyright (c) 2007 Christian Bach
*/');
print_out('!function(g){g.extend({tablesorter:new function(){function d(){var a=arguments[0],b=1<arguments.length?Array.prototype.slice.call(arguments):a;if("undefined"!==typeof console&&"undefined"!==typeof console.log)console[/error/i.test(a)?"error":/warn/i.test(a)?"warn":"log"](b);else alert(b)}function u(a,b){d(a+" ("+((new Date).getTime()-b.getTime())+"ms)")}function m(a){for(var b in a)return!1;return!0}function p(a,b,c){if(!b)return"";var h=a.config,e=h.textExtraction,f="",f="simple"===e?h.supportsTextContent? b.textContent:g(b).text():"function"===typeof e?e(b,a,c):"object"===typeof e&&e.hasOwnProperty(c)?e[c](b,a,c):h.supportsTextContent?b.textContent:g(b).text();return g.trim(f)}function t(a){var b=a.config,c=b.$tbodies=b.$table.children("tbody:not(."+b.cssInfoBlock+")"),h,e,w,k,n,g,l,z="";if(0===c.length)return b.debug?d("Warning: *Empty table!* Not building a parser cache"):"";b.debug&&(l=new Date,d("Detecting parsers for each column"));c=c[0].rows;if(c[0])for(h=[],e=c[0].cells.length,w=0;w<e;w++){k= b.$headers.filter(":not([colspan])");k=k.add(b.$headers.filter(''[colspan="1"]'')).filter(''[data-column="''+w+''"]:last'');n=b.headers[w];g=f.getParserById(f.getData(k,n,"sorter"));b.empties[w]=f.getData(k,n,"empty")||b.emptyTo||(b.emptyToBottom?"bottom":"top");b.strings[w]=f.getData(k,n,"string")||b.stringTo||"max";if(!g)a:{k=a;n=c;g=-1;for(var m=w,y=void 0,x=f.parsers.length,r=!1,t="",y=!0;""===t&&y;)g++,n[g]?(r=n[g].cells[m],t=p(k,r,m),k.config.debug&&d("Checking if value was empty on row "+g+", column: "+ m+'': "''+t+''"'')):y=!1;for(;0<=--x;)if((y=f.parsers[x])&&"text"!==y.id&&y.is&&y.is(t,k,r)){g=y;break a}g=f.getParserById("text")}b.debug&&(z+="column:"+w+"; parser:"+g.id+"; string:"+b.strings[w]+"; empty: "+b.empties[w]+"\\n");h.push(g)}b.debug&&(d(z),u("Completed detecting parsers",l));');
print_out('b.parsers=h}function v(a){var b=a.tBodies,c=a.config,h,e,w=c.parsers,k,n,q,l,z,m,y,x=[];c.cache={};if(!w)return c.debug?d("Warning: *Empty table!* Not building a cache"):"";c.debug&&(y=new Date);c.showProcessing&&f.isProcessing(a, !0);for(l=0;l<b.length;l++)if(c.cache[l]={row:[],normalized:[]},!g(b[l]).hasClass(c.cssInfoBlock)){h=b[l]&&b[l].rows.length||0;e=b[l].rows[0]&&b[l].rows[0].cells.length||0;for(n=0;n<h;++n)if(z=g(b[l].rows[n]),m=[],z.hasClass(c.cssChildRow))c.cache[l].row[c.cache[l].row.length-1]=c.cache[l].row[c.cache[l].row.length-1].add(z);else{c.cache[l].row.push(z);for(q=0;q<e;++q)k=p(a,z[0].cells[q],q),k=w[q].format(k,a,z[0].cells[q],q),m.push(k),"numeric"===(w[q].type||"").toLowerCase()&&(x[q]=Math.max(Math.abs(k)|| 0,x[q]||0));m.push(c.cache[l].normalized.length);c.cache[l].normalized.push(m)}c.cache[l].colMax=x}c.showProcessing&&f.isProcessing(a);c.debug&&u("Building cache for "+h+" rows",y)}function A(a,b){var c=a.config,h=c.widgetOptions,e=a.tBodies,w=[],k=c.cache,d,q,l,z,p,y,x,r,t,s,v;');
print_out('if(m(k))return c.appender?c.appender(a,w):"";c.debug&&(v=new Date);for(r=0;r<e.length;r++)if(d=g(e[r]),d.length&&!d.hasClass(c.cssInfoBlock)){p=f.processTbody(a,d,!0);d=k[r].row;q=k[r].normalized;z=(l=q.length)?q[0].length- 1:0;for(y=0;y<l;y++)if(s=q[y][z],w.push(d[s]),!c.appender||c.pager&&!(c.pager.removeRows&&h.pager_removeRows||c.pager.ajax))for(t=d[s].length,x=0;x<t;x++)p.append(d[s][x]);f.processTbody(a,p,!1)}c.appender&&c.appender(a,w);c.debug&&u("Rebuilt table",v);b||c.appender||f.applyWidget(a);g(a).trigger("sortEnd",a);g(a).trigger("updateComplete",a)}function D(a){var b=[],c={},h=0,e=g(a).find("thead:eq(0), tfoot").children("tr"),f,d,n,q,l,m,u,p,s,r;for(f=0;f<e.length;f++)for(l=e[f].cells,d=0;d<l.length;d++){q= l[d];m=q.parentNode.rowIndex;u=m+"-"+q.cellIndex;p=q.rowSpan||1;s=q.colSpan||1;"undefined"===typeof b[m]&&(b[m]=[]);for(n=0;n<b[m].length+1;n++)if("undefined"===typeof b[m][n]){r=n;break}c[u]=r;h=Math.max(r,h);g(q).attr({"data-column":r});for(n=m;n<m+p;n++)for("undefined"===typeof b[n]&&(b[n]=[]),u=b[n],q=r;q<r+s;q++)u[q]="x"}a.config.columns=h+1;return c}function C(a){return/^d/i.test(a)||1===a}function E(a){var b=D(a),c,h,e,w,k,n,q,l=a.config;');
print_out('l.headerList=[];l.headerContent=[];l.debug&&(q=new Date); w=l.cssIcon?''<i class="''+(l.cssIcon===f.css.icon?f.css.icon:l.cssIcon+" "+f.css.icon)+''"></i>'':"";l.$headers=g(a).find(l.selectorHeaders).each(function(a){h=g(this);c=l.headers[a];l.headerContent[a]=g(this).html();k=l.headerTemplate.replace(/\\{content\\}/g,g(this).html()).replace(/\\{icon\\}/g,w);l.onRenderTemplate&&(e=l.onRenderTemplate.apply(h,[a,k]))&&"string"===typeof e&&(k=e);g(this).html(''<div class="''+f.css.headerIn+''">''+k+"</div>");l.onRenderHeader&&l.onRenderHeader.apply(h,[a]);this.column= b[this.parentNode.rowIndex+"-"+this.cellIndex];this.order=C(f.getData(h,c,"sortInitialOrder")||l.sortInitialOrder)?[1,0,2]:[0,1,2];this.count=-1;this.lockedOrder=!1;n=f.getData(h,c,"lockedOrder")||!1;"undefined"!==typeof n&&!1!==n&&(this.order=this.lockedOrder=C(n)?[1,1,1]:[0,0,0]);h.addClass(f.css.header+" "+l.cssHeader);l.headerList[a]=this;h.parent().addClass(f.css.headerRow+" "+l.cssHeaderRow).attr("role","row");l.tabIndex&&h.attr("tabindex",0)}).attr({scope:"col",role:"columnheader"});G(a);l.debug&& (u("Built headers:",q),d(l.$headers))}function B(a,b,c){var h=a.config;h.$table.find(h.selectorRemove).remove();t(a);v(a);H(h.$table,b,c)}');
print_out('function G(a){var b,c,h=a.config;h.$headers.each(function(e,d){c=g(d);b="false"===f.getData(d,h.headers[e],"sorter");d.sortDisabled=b;c[b?"addClass":"removeClass"]("sorter-false").attr("aria-disabled",""+b);a.id&&(b?c.removeAttr("aria-controls"):c.attr("aria-controls",a.id))})}function F(a){var b,c,h,e=a.config,d=e.sortList,k=f.css.sortNone+" "+e.cssNone,n=[f.css.sortAsc+ " "+e.cssAsc,f.css.sortDesc+" "+e.cssDesc],q=["ascending","descending"],l=g(a).find("tfoot tr").children().removeClass(n.join(" "));e.$headers.removeClass(n.join(" ")).addClass(k).attr("aria-sort","none");h=d.length;for(b=0;b<h;b++)if(2!==d[b][1]&&(a=e.$headers.not(".sorter-false").filter(''[data-column="''+d[b][0]+''"]''+(1===h?":last":"")),a.length))for(c=0;c<a.length;c++)a[c].sortDisabled||(a.eq(c).removeClass(k).addClass(n[d[b][1]]).attr("aria-sort",q[d[b][1]]),l.length&&l.filter(''[data-column="''+ d[b][0]+''"]'').eq(c).addClass(n[d[b][1]]));e.$headers.not(".sorter-false").each(function(){var a=g(this),b=this.order[(this.count+1)%(e.sortReset?3:2)],b=a.text()+": "+f.language[a.hasClass(f.css.sortAsc)?"sortAsc":a.hasClass(f.css.sortDesc)?"sortDesc":"sortNone"]+f.language[0===b?"nextAsc":1===b?"nextDesc":"nextNone"];a.attr("aria-label",b)})}function L(a){if(a.config.widthFixed&&0===g(a).find("colgroup").length){var b=g("<colgroup>"),c=g(a).width();g(a.tBodies[0]).find("tr:first").children("td:visible").each(function(){b.append(g("<col>").css("width", parseInt(g(this).width()/c*1E3,10)/10+"%"))});');
print_out('g(a).prepend(b)}}function M(a,b){var c,h,e,f=a.config,d=b||f.sortList;f.sortList=[];g.each(d,function(a,b){c=[parseInt(b[0],10),parseInt(b[1],10)];if(e=f.$headers[c[0]])f.sortList.push(c),h=g.inArray(c[1],e.order),e.count=0<=h?h:c[1]%(f.sortReset?3:2)})}function N(a,b){return a&&a[b]?a[b].type||"":""}function O(a,b,c){var h,e,d,k=a.config,n=!c[k.sortMultiSortKey],q=g(a);q.trigger("sortStart",a);b.count=c[k.sortResetKey]?2:(b.count+1)%(k.sortReset?3:2); k.sortRestart&&(e=b,k.$headers.each(function(){this===e||!n&&g(this).is("."+f.css.sortDesc+",."+f.css.sortAsc)||(this.count=-1)}));e=b.column;if(n){k.sortList=[];if(null!==k.sortForce)for(h=k.sortForce,c=0;c<h.length;c++)h[c][0]!==e&&k.sortList.push(h[c]);h=b.order[b.count];if(2>h&&(k.sortList.push([e,h]),1<b.colSpan))for(c=1;c<b.colSpan;c++)k.sortList.push([e+c,h])}else if(k.sortAppend&&1<k.sortList.length&&f.isValueInArray(k.sortAppend[0][0],k.sortList)&&k.sortList.pop(),f.isValueInArray(e,k.sortList))for(c= 0;c<k.sortList.length;c++)d=k.sortList[c],h=k.$headers[d[0]],d[0]===e&&(d[1]=h.order[b.count],2===d[1]&&(k.sortList.splice(c,1),h.count=-1));else if(h=b.order[b.count],2>h&&(k.sortList.push([e,h]),1<b.colSpan))for(c=1;c<b.colSpan;c++)k.sortList.push([e+c,h]);if(null!==k.sortAppend)for(h=k.sortAppend,c=0;c<h.length;c++)h[c][0]!==e&&k.sortList.push(h[c]);q.trigger("sortBegin",a);');
print_out('setTimeout(function(){F(a);I(a);A(a)},1)}function I(a){var b,c,h,e,d,k,g,q,l,p,s,t,x=0,r=a.config,v=r.textSorter||"",A=r.sortList, B=A.length,C=a.tBodies.length;if(!r.serverSideSorting&&!m(r.cache)){r.debug&&(l=new Date);for(c=0;c<C;c++)d=r.cache[c].colMax,q=(k=r.cache[c].normalized)&&k[0]?k[0].length-1:0,k.sort(function(c,k){for(b=0;b<B;b++){e=A[b][0];g=A[b][1];x=0===g;if(r.sortStable&&c[e]===k[e]&&1===B)break;(h=/n/i.test(N(r.parsers,e)))&&r.strings[e]?(h="boolean"===typeof r.string[r.strings[e]]?(x?1:-1)*(r.string[r.strings[e]]?-1:1):r.strings[e]?r.string[r.strings[e]]||0:0,p=r.numberSorter?r.numberSorter(s[e],t[e],x,d[e], a):f["sortNumeric"+(x?"Asc":"Desc")](c[e],k[e],h,d[e],e,a)):(s=x?c:k,t=x?k:c,p="function"===typeof v?v(s[e],t[e],x,e,a):"object"===typeof v&&v.hasOwnProperty(e)?v[e](s[e],t[e],x,e,a):f["sortNatural"+(x?"Asc":"Desc")](c[e],k[e],e,a,r));if(p)return p}return c[q]-k[q]});r.debug&&u("Sorting on "+A.toString()+" and dir "+g+" time",l)}}function J(a,b){var c=a[0].config;c.pager&&!c.pager.ajax&&a.trigger("updateComplete");"function"===typeof b&&b(a[0])}function H(a,b,c){!1===b||a[0].isProcessing?J(a,c):a.trigger("sorton", [a[0].config.sortList,function(){J(a,c)}])}function K(a){var b=a.config,c=b.$table;c.unbind("sortReset update updateRows updateCell updateAll addRows sorton appendCache applyWidgetId applyWidgets refreshWidgets destroy mouseup mouseleave ".split(" ").join(".tablesorter ")).bind("sortReset.tablesorter",function(c){c.stopPropagation();');
print_out('b.sortList=[];F(a);I(a);A(a)}).bind("updateAll.tablesorter",function(c,e,d){c.stopPropagation();f.refreshWidgets(a,!0,!0);f.restoreHeaders(a);E(a);f.bindEvents(a,b.$headers); K(a);B(a,e,d)}).bind("update.tablesorter updateRows.tablesorter",function(b,c,d){b.stopPropagation();G(a);B(a,c,d)}).bind("updateCell.tablesorter",function(h,e,d,f){h.stopPropagation();c.find(b.selectorRemove).remove();var n,q,l;n=c.find("tbody");h=n.index(g(e).parents("tbody").filter(":first"));var m=g(e).parents("tr").filter(":first");e=g(e)[0];n.length&&0<=h&&(q=n.eq(h).find("tr").index(m),l=e.cellIndex,n=b.cache[h].normalized[q].length-1,b.cache[h].row[a.config.cache[h].normalized[q][n]]=m,b.cache[h].normalized[q][l]= b.parsers[l].format(p(a,e,l),a,e,l),H(c,d,f))}).bind("addRows.tablesorter",function(h,e,d,f){h.stopPropagation();if(m(b.cache))G(a),B(a,d,f);else{var g,q=e.filter("tr").length,l=[],u=e[0].cells.length,v=c.find("tbody").index(e.parents("tbody").filter(":first"));b.parsers||t(a);for(h=0;h<q;h++){for(g=0;g<u;g++)l[g]=b.parsers[g].format(p(a,e[h].cells[g],g),a,e[h].cells[g],g);l.push(b.cache[v].row.length);b.cache[v].row.push([e[h]]);b.cache[v].normalized.push(l);l=[]}H(c,d,f)}}).bind("sorton.tablesorter", function(b,e,d,f){var g=a.config;b.stopPropagation();c.trigger("sortStart",this);M(a,e);F(a);g.delayInit&&m(g.cache)&&v(a);c.trigger("sortBegin",this);I(a);A(a,f);"function"===typeof d&&d(a)}).bind("appendCache.tablesorter",function(b,c,d){b.stopPropagation();A(a,d);"function"===typeof c&&c(a)}).bind("applyWidgetId.tablesorter",function(c,e){c.stopPropagation();f.getWidgetById(e).format(a,b,b.widgetOptions)}).bind("applyWidgets.tablesorter",function(b,c){b.stopPropagation();f.applyWidget(a,c)}).bind("refreshWidgets.tablesorter", ');
print_out('function(b,c,d){b.stopPropagation();f.refreshWidgets(a,c,d)}).bind("destroy.tablesorter",function(b,c,d){b.stopPropagation();f.destroy(a,c,d)})}var f=this;f.version="2.15.3";f.parsers=[];f.widgets=[];f.defaults={theme:"default",widthFixed:!1,showProcessing:!1,headerTemplate:"{content}",onRenderTemplate:null,onRenderHeader:null,cancelSelection:!0,tabIndex:!0,dateFormat:"mmddyyyy",sortMultiSortKey:"shiftKey",sortResetKey:"ctrlKey",usNumberFormat:!0,delayInit:!1,serverSideSorting:!1,headers:{},ignoreCase:!0, sortForce:null,sortList:[],sortAppend:null,sortStable:!1,sortInitialOrder:"asc",sortLocaleCompare:!1,sortReset:!1,sortRestart:!1,emptyTo:"bottom",stringTo:"max",textExtraction:"simple",textSorter:null,numberSorter:null,widgets:[],widgetOptions:{zebra:["even","odd"]},initWidgets:!0,initialized:null,tableClass:"",cssAsc:"",cssDesc:"",cssNone:"",cssHeader:"",cssHeaderRow:"",cssProcessing:"",cssChildRow:"tablesorter-childRow",cssIcon:"tablesorter-icon",cssInfoBlock:"tablesorter-infoOnly",selectorHeaders:"> thead th, > thead td", selectorSort:"th, td",selectorRemove:".remove-me",debug:!1,headerList:[],empties:{},strings:{},parsers:[]};f.css={table:"tablesorter",childRow:"tablesorter-childRow",header:"tablesorter-header",headerRow:"tablesorter-headerRow",headerIn:"tablesorter-header-inner",icon:"tablesorter-icon",info:"tablesorter-infoOnly",processing:"tablesorter-processing",sortAsc:"tablesorter-headerAsc",sortDesc:"tablesorter-headerDesc",sortNone:"tablesorter-headerUnSorted"};f.language={sortAsc:"Ascending sort applied, ", sortDesc:"Descending sort applied, ",sortNone:"No sort applied, ",nextAsc:"activate to apply an ascending sort",nextDesc:"activate to apply a descending sort",nextNone:"activate to remove the sort"};f.log=d;f.benchmark=u;f.construct=function(a){return this.each(function(){var b=g.extend(!0,{},f.defaults,a);');
print_out('!this.hasInitialized&&f.buildTable&&"TABLE"!==this.tagName&&f.buildTable(this,b);f.setup(this,b)})};f.setup=function(a,b){if(!a||!a.tHead||0===a.tBodies.length||!0===a.hasInitialized)return b.debug? d("ERROR: stopping initialization! No table, thead, tbody or tablesorter has already been initialized"):"";var c="",h=g(a),e=g.metadata;a.hasInitialized=!1;a.isProcessing=!0;a.config=b;g.data(a,"tablesorter",b);b.debug&&g.data(a,"startoveralltimer",new Date);b.supportsTextContent="x"===g("<span>x</span>")[0].textContent;b.supportsDataObject=function(a){a[0]=parseInt(a[0],10);return 1<a[0]||1===a[0]&&4<=parseInt(a[1],10)}(g.fn.jquery.split("."));b.string={max:1,min:-1,"max+":1,"max-":-1,zero:0,none:0, "null":0,top:!0,bottom:!1};/tablesorter\\-/.test(h.attr("class"))||(c=""!==b.theme?" tablesorter-"+b.theme:"");b.$table=h.addClass(f.css.table+" "+b.tableClass+c).attr({role:"grid"});b.$tbodies=h.children("tbody:not(."+b.cssInfoBlock+")").attr({"aria-live":"polite","aria-relevant":"all"});b.$table.find("caption").length&&b.$table.attr("aria-labelledby","theCaption");b.widgetInit={};E(a);L(a);t(a);b.delayInit||v(a);f.bindEvents(a,b.$headers);K(a);b.supportsDataObject&&"undefined"!==typeof h.data().sortlist? b.sortList=h.data().sortlist:e&&h.metadata()&&h.metadata().sortlist&&(b.sortList=h.metadata().sortlist);');
print_out('f.applyWidget(a,!0);0<b.sortList.length?h.trigger("sorton",[b.sortList,{},!b.initWidgets]):(F(a),b.initWidgets&&f.applyWidget(a));b.showProcessing&&h.unbind("sortBegin.tablesorter sortEnd.tablesorter").bind("sortBegin.tablesorter sortEnd.tablesorter",function(b){f.isProcessing(a,"sortBegin"===b.type)});a.hasInitialized=!0;a.isProcessing=!1;b.debug&&f.benchmark("Overall initialization time",g.data(a, "startoveralltimer"));h.trigger("tablesorter-initialized",a);"function"===typeof b.initialized&&b.initialized(a)};f.isProcessing=function(a,b,c){a=g(a);var h=a[0].config;a=c||a.find("."+f.css.header);b?("undefined"!==typeof c&&0<h.sortList.length&&(a=a.filter(function(){return this.sortDisabled?!1:f.isValueInArray(parseFloat(g(this).attr("data-column")),h.sortList)})),a.addClass(f.css.processing+" "+h.cssProcessing)):a.removeClass(f.css.processing+" "+h.cssProcessing)};f.processTbody=function(a,b, c){a=g(a)[0];if(c)return a.isProcessing=!0,b.before(''<span class="tablesorter-savemyplace"/>''),c=g.fn.detach?b.detach():b.remove();c=g(a).find("span.tablesorter-savemyplace");b.insertAfter(c);c.remove();a.isProcessing=!1};f.clearTableBody=function(a){g(a)[0].config.$tbodies.empty()};f.bindEvents=function(a,b){a=g(a)[0];var c,h=a.config;b.find(h.selectorSort).add(b.filter(h.selectorSort)).unbind("mousedown.tablesorter mouseup.tablesorter sort.tablesorter keyup.tablesorter").bind("mousedown.tablesorter mouseup.tablesorter sort.tablesorter keyup.tablesorter", function(e,d){var f;f=e.type;');
print_out('if(!(1!==(e.which||e.button)&&!/sort|keyup/.test(f)||"keyup"===f&&13!==e.which||"mouseup"===f&&!0!==d&&250<(new Date).getTime()-c)){if("mousedown"===f)return c=(new Date).getTime(),"INPUT"===e.target.tagName?"":!h.cancelSelection;h.delayInit&&m(h.cache)&&v(a);f=/TH|TD/.test(this.tagName)?this:g(this).parents("th, td")[0];f=h.$headers[b.index(f)];f.sortDisabled||O(a,f,e)}});h.cancelSelection&&b.attr("unselectable","on").bind("selectstart",!1).css({"user-select":"none", MozUserSelect:"none"})};f.restoreHeaders=function(a){var b=g(a)[0].config;b.$table.find(b.selectorHeaders).each(function(a){g(this).find("."+f.css.headerIn).length&&g(this).html(b.headerContent[a])})};f.destroy=function(a,b,c){a=g(a)[0];if(a.hasInitialized){f.refreshWidgets(a,!0,!0);var h=g(a),e=a.config,d=h.find("thead:first"),k=d.find("tr."+f.css.headerRow).removeClass(f.css.headerRow+" "+e.cssHeaderRow),n=h.find("tfoot:first > tr").children("th, td");d.find("tr").not(k).remove();h.removeData("tablesorter").unbind("sortReset update updateAll updateRows updateCell addRows sorton appendCache applyWidgetId applyWidgets refreshWidgets destroy mouseup mouseleave keypress sortBegin sortEnd ".split(" ").join(".tablesorter ")); e.$headers.add(n).removeClass([f.css.header,e.cssHeader,e.cssAsc,e.cssDesc,f.css.sortAsc,f.css.sortDesc,f.css.sortNone].join(" ")).removeAttr("data-column");k.find(e.selectorSort).unbind("mousedown.tablesorter mouseup.tablesorter keypress.tablesorter");f.restoreHeaders(a);!1!==b&&h.removeClass(f.css.table+" "+e.tableClass+" tablesorter-"+e.theme);a.hasInitialized=!1;"function"===typeof c&&c(a)}};');
print_out('f.regex={chunk:/(^([+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)?$|^0x[0-9a-f]+$|\\d+)/gi,hex:/^0x[0-9a-f]+$/i}; f.sortNatural=function(a,b){if(a===b)return 0;var c,h,e,d,g,n;h=f.regex;if(h.hex.test(b)){c=parseInt(a.match(h.hex),16);e=parseInt(b.match(h.hex),16);if(c<e)return-1;if(c>e)return 1}c=a.replace(h.chunk,"\\\\0$1\\\\0").replace(/\\\\0$/,"").replace(/^\\\\0/,"").split("\\\\0");h=b.replace(h.chunk,"\\\\0$1\\\\0").replace(/\\\\0$/,"").replace(/^\\\\0/,"").split("\\\\0");n=Math.max(c.length,h.length);for(g=0;g<n;g++){e=isNaN(c[g])?c[g]||0:parseFloat(c[g])||0;d=isNaN(h[g])?h[g]||0:parseFloat(h[g])||0;if(isNaN(e)!==isNaN(d))return isNaN(e)? 1:-1;typeof e!==typeof d&&(e+="",d+="");if(e<d)return-1;if(e>d)return 1}return 0};f.sortNaturalAsc=function(a,b,c,d,e){if(a===b)return 0;c=e.string[e.empties[c]||e.emptyTo];return""===a&&0!==c?"boolean"===typeof c?c?-1:1:-c||-1:""===b&&0!==c?"boolean"===typeof c?c?1:-1:c||1:f.sortNatural(a,b)};f.sortNaturalDesc=function(a,b,c,d,e){if(a===b)return 0;c=e.string[e.empties[c]||e.emptyTo];return""===a&&0!==c?"boolean"===typeof c?c?-1:1:c||1:""===b&&0!==c?"boolean"===typeof c?c?1:-1:-c||-1:f.sortNatural(b, a)};f.sortText=function(a,b){return a>b?1:a<b?-1:0};f.getTextValue=function(a,b,c){if(c){var d=a?a.length:0,e=c+b;for(c=0;c<d;c++)e+=a.charCodeAt(c);return b*e}return 0};f.sortNumericAsc=function(a,b,c,d,e,g){if(a===b)return 0;g=g.config;e=g.string[g.empties[e]||g.emptyTo];');
print_out('if(""===a&&0!==e)return"boolean"===typeof e?e?-1:1:-e||-1;if(""===b&&0!==e)return"boolean"===typeof e?e?1:-1:e||1;isNaN(a)&&(a=f.getTextValue(a,c,d));isNaN(b)&&(b=f.getTextValue(b,c,d));return a-b};f.sortNumericDesc=function(a, b,c,d,e,g){if(a===b)return 0;g=g.config;e=g.string[g.empties[e]||g.emptyTo];if(""===a&&0!==e)return"boolean"===typeof e?e?-1:1:e||1;if(""===b&&0!==e)return"boolean"===typeof e?e?1:-1:-e||-1;isNaN(a)&&(a=f.getTextValue(a,c,d));isNaN(b)&&(b=f.getTextValue(b,c,d));return b-a};f.sortNumeric=function(a,b){return a-b};f.characterEquivalents={a:"\\u00e1\\u00e0\\u00e2\\u00e3\\u00e4\\u0105\\u00e5",A:"\\u00c1\\u00c0\\u00c2\\u00c3\\u00c4\\u0104\\u00c5",c:"\\u00e7\\u0107\\u010d",C:"\\u00c7\\u0106\\u010c",e:"\\u00e9\\u00e8\\u00ea\\u00eb\\u011b\\u0119", E:"\\u00c9\\u00c8\\u00ca\\u00cb\\u011a\\u0118",i:"\\u00ed\\u00ec\\u0130\\u00ee\\u00ef\\u0131",I:"\\u00cd\\u00cc\\u0130\\u00ce\\u00cf",o:"\\u00f3\\u00f2\\u00f4\\u00f5\\u00f6",O:"\\u00d3\\u00d2\\u00d4\\u00d5\\u00d6",ss:"\\u00df",SS:"\\u1e9e",u:"\\u00fa\\u00f9\\u00fb\\u00fc\\u016f",U:"\\u00da\\u00d9\\u00db\\u00dc\\u016e"};f.replaceAccents=function(a){var b,c="[",d=f.characterEquivalents;if(!f.characterRegex){f.characterRegexArray={};for(b in d)"string"===typeof b&&(c+=d[b],f.characterRegexArray[b]=RegExp("["+d[b]+"]","g"));f.characterRegex= RegExp(c+"]")}if(f.characterRegex.test(a))for(b in d)"string"===typeof b&&(a=a.replace(f.characterRegexArray[b],b));return a};f.isValueInArray=function(a,b){var c,d=b.length;for(c=0;c<d;c++)if(b[c][0]===a)return!0;return!1};f.addParser=function(a){var b,c=f.parsers.length,d=!0;for(b=0;b<c;b++)f.parsers[b].id.toLowerCase()===a.id.toLowerCase()&&(d=!1);d&&f.parsers.push(a)};f.getParserById=function(a){var b,c=f.parsers.length;for(b=0;b<c;b++)if(f.parsers[b].id.toLowerCase()===a.toString().toLowerCase())return f.parsers[b]; ');
print_out('return!1};f.addWidget=function(a){f.widgets.push(a)};f.getWidgetById=function(a){var b,c,d=f.widgets.length;for(b=0;b<d;b++)if((c=f.widgets[b])&&c.hasOwnProperty("id")&&c.id.toLowerCase()===a.toLowerCase())return c};f.applyWidget=function(a,b){a=g(a)[0];var c=a.config,d=c.widgetOptions,e=[],m,k,n;c.debug&&(m=new Date);c.widgets.length&&(c.widgets=g.grep(c.widgets,function(a,b){return g.inArray(a,c.widgets)===b}),g.each(c.widgets||[],function(a,b){(n=f.getWidgetById(b))&&n.id&&(n.priority||(n.priority= 10),e[a]=n)}),e.sort(function(a,b){return a.priority<b.priority?-1:a.priority===b.priority?0:1}),g.each(e,function(e,f){if(f){if(b||!c.widgetInit[f.id])f.hasOwnProperty("options")&&(d=a.config.widgetOptions=g.extend(!0,{},f.options,d)),f.hasOwnProperty("init")&&f.init(a,f,c,d),c.widgetInit[f.id]=!0;!b&&f.hasOwnProperty("format")&&f.format(a,c,d,!1)}}));c.debug&&(k=c.widgets.length,u("Completed "+(!0===b?"initializing ":"applying ")+k+" widget"+(1!==k?"s":""),m))};f.refreshWidgets=function(a,b,c){a= g(a)[0];var h,e=a.config,m=e.widgets,k=f.widgets,n=k.length;for(h=0;h<n;h++)k[h]&&k[h].id&&(b||0>g.inArray(k[h].id,m))&&(e.debug&&d(''Refeshing widgets: Removing "''+k[h].id+''"''),k[h].hasOwnProperty("remove")&&e.widgetInit[k[h].id]&&(k[h].remove(a,e,e.widgetOptions),e.widgetInit[k[h].id]=!1));!0!==c&&f.applyWidget(a,b)};f.getData=function(a,b,c){var d="";a=g(a);var e,f;if(!a.length)return"";e=g.metadata?a.metadata():!1;');
print_out('f=" "+(a.attr("class")||"");"undefined"!==typeof a.data(c)||"undefined"!==typeof a.data(c.toLowerCase())? d+=a.data(c)||a.data(c.toLowerCase()):e&&"undefined"!==typeof e[c]?d+=e[c]:b&&"undefined"!==typeof b[c]?d+=b[c]:" "!==f&&f.match(" "+c+"-")&&(d=f.match(RegExp("\\\\s"+c+"-([\\\\w-]+)"))[1]||"");return g.trim(d)};f.formatFloat=function(a,b){if("string"!==typeof a||""===a)return a;var c;a=(b&&b.config?!1!==b.config.usNumberFormat:"undefined"!==typeof b?b:1)?a.replace(/,/g,""):a.replace(/[\\s|\\.]/g,"").replace(/,/g,".");/^\\s*\\([.\\d]+\\)/.test(a)&&(a=a.replace(/^\\s*\\(([.\\d]+)\\)/,"-$1"));c=parseFloat(a);return isNaN(c)? g.trim(a):c};f.isDigit=function(a){return isNaN(a)?/^[\\-+(]?\\d+[)]?$/.test(a.toString().replace(/[,.''"\\s]/g,"")):!0}}});var p=g.tablesorter;g.fn.extend({tablesorter:p.construct});p.addParser({id:"text",is:function(){return!0},format:function(d,u){var m=u.config;d&&(d=g.trim(m.ignoreCase?d.toLocaleLowerCase():d),d=m.sortLocaleCompare?p.replaceAccents(d):d);return d},type:"text"});p.addParser({id:"digit",is:function(d){return p.isDigit(d)},format:function(d,u){var m=p.formatFloat((d||"").replace(/[^\\w,. \\-()]/g, ""),u);return d&&"number"===typeof m?m:d?g.trim(d&&u.config.ignoreCase?d.toLocaleLowerCase():d):d},type:"numeric"});p.addParser({id:"currency",is:function(d){return/^\\(?\\d+[\\u00a3$\\u20ac\\u00a4\\u00a5\\u00a2?.]|[\\u00a3$\\u20ac\\u00a4\\u00a5\\u00a2?.]\\d+\\)?$/.test((d||"").replace(/[+\\-,. ]/g,""))},format:function(d,u){var m=p.formatFloat((d||"").replace(/[^\\w,. \\-()]/g,""),u);return d&&"number"===typeof m?m:d?g.trim(d&&u.config.ignoreCase?d.toLocaleLowerCase():d):d},type:"numeric"});p.addParser({id:"ipAddress", is:function(d){return/^\\d{1,3}[\\.]\\d{1,3}[\\.]\\d{1,3}[\\.]\\d{1,3}$/.test(d)},format:function(d,g){var m,s=d?d.split("."):"",t="",v=s.length;');
print_out('for(m=0;m<v;m++)t+=("00"+s[m]).slice(-3);return d?p.formatFloat(t,g):d},type:"numeric"});p.addParser({id:"url",is:function(d){return/^(https?|ftp|file):\\/\\//.test(d)},format:function(d){return d?g.trim(d.replace(/(https?|ftp|file):\\/\\//,"")):d},type:"text"});p.addParser({id:"isoDate",is:function(d){return/^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}/.test(d)},format:function(d, g){return d?p.formatFloat(""!==d?(new Date(d.replace(/-/g,"/"))).getTime()||"":"",g):d},type:"numeric"});p.addParser({id:"percent",is:function(d){return/(\\d\\s*?%|%\\s*?\\d)/.test(d)&&15>d.length},format:function(d,g){return d?p.formatFloat(d.replace(/%/g,""),g):d},type:"numeric"});p.addParser({id:"usLongDate",is:function(d){return/^[A-Z]{3,10}\\.?\\s+\\d{1,2},?\\s+(\\d{4})(\\s+\\d{1,2}:\\d{2}(:\\d{2})?(\\s+[AP]M)?)?$/i.test(d)||/^\\d{1,2}\\s+[A-Z]{3,10}\\s+\\d{4}/i.test(d)},format:function(d,g){return d?p.formatFloat((new Date(d.replace(/(\\S)([AP]M)$/i, "$1 $2"))).getTime()||"",g):d},type:"numeric"});p.addParser({id:"shortDate",is:function(d){return/(^\\d{1,2}[\\/\\s]\\d{1,2}[\\/\\s]\\d{4})|(^\\d{4}[\\/\\s]\\d{1,2}[\\/\\s]\\d{1,2})/.test((d||"").replace(/\\s+/g," ").replace(/[\\-.,]/g,"/"))},format:function(d,g,m,s){if(d){m=g.config;');
print_out('var t=m.$headers.filter("[data-column="+s+"]:last");s=t.length&&t[0].dateFormat||p.getData(t,m.headers[s],"dateFormat")||m.dateFormat;d=d.replace(/\\s+/g," ").replace(/[\\-.,]/g,"/");"mmddyyyy"===s?d=d.replace(/(\\d{1,2})[\\/\\s](\\d{1,2})[\\/\\s](\\d{4})/, "$3/$1/$2"):"ddmmyyyy"===s?d=d.replace(/(\\d{1,2})[\\/\\s](\\d{1,2})[\\/\\s](\\d{4})/,"$3/$2/$1"):"yyyymmdd"===s&&(d=d.replace(/(\\d{4})[\\/\\s](\\d{1,2})[\\/\\s](\\d{1,2})/,"$1/$2/$3"))}return d?p.formatFloat((new Date(d)).getTime()||"",g):d},type:"numeric"});p.addParser({id:"time",is:function(d){return/^(([0-2]?\\d:[0-5]\\d)|([0-1]?\\d:[0-5]\\d\\s?([AP]M)))$/i.test(d)},format:function(d,g){return d?p.formatFloat((new Date("2000/01/01 "+d.replace(/(\\S)([AP]M)$/i,"$1 $2"))).getTime()||"",g):d},type:"numeric"});p.addParser({id:"metadata", is:function(){return!1},format:function(d,p,m){d=p.config;d=d.parserMetadataName?d.parserMetadataName:"sortValue";return g(m).metadata()[d]},type:"numeric"});p.addWidget({id:"zebra",priority:90,format:function(d,u,m){var s,t,v,A,D,C,E=RegExp(u.cssChildRow,"i"),B=u.$tbodies;u.debug&&(D=new Date);for(d=0;d<B.length;d++)s=B.eq(d),C=s.children("tr").length,1<C&&(v=0,s=s.children("tr:visible").not(u.selectorRemove),s.each(function(){t=g(this);E.test(this.className)||v++;A=0===v%2;t.removeClass(m.zebra[A? 1:0]).addClass(m.zebra[A?0:1])}));u.debug&&p.benchmark("Applying Zebra widget",D)},remove:function(d,p,m){var s;p=p.$tbodies;var t=(m.zebra||["even","odd"]).join(" ");for(m=0;m<p.length;m++)s=g.tablesorter.processTbody(d,p.eq(m),!0),s.children().removeClass(t),g.tablesorter.processTbody(d,s,!1)}})}(jQuery);');
print_out('</script>');
print_out('
   
<script>
$(document).ready(function(){
    var alertOn = true;   
    var filterString="";
    var sectionTitle = {"E": "Error Signatures", "W": "Warning Signatures", "S": "Successful Signatures", "I": "Informational Signatures"};
    var searchFlag=false;
    $("#homeButton").click(function(){
        $(".data").hide();
        $(".maindata").hide();
        $(".mainmenu").show();  
        $("#search").val("");
    });
    // Open pop-up window
    $("[data-popup-open]").on("click", function()  {
        var targeted_popup_class = jQuery(this).attr("data-popup-open");
        $("[data-popup]").hide();
        $("[data-popup=''" + targeted_popup_class + "'']").fadeIn(350);
    });

    // Close pop-up window
    $("[data-popup-close]").on("click", function()  {
        var targeted_popup_class = jQuery(this).attr("data-popup-close");
        $("[data-popup=''" + targeted_popup_class + "'']").fadeOut(350, function(){
        });
    });
   
    // Open section (by section name or by error type)
    $("[open-section]").on("click", function()  {
        var sectionID = jQuery(this).attr("open-section");
        var sectionName = jQuery(this).find("div.textbox").text();
        if ((sectionName == null) || (sectionName == "")){
            sectionName = sectionTitle[sectionID];
        }
        filterString = sectionID;
  // if the section is empty, do nothing
  if ($("." + sectionID).size() <= 0) {
     return;
  }
        $(".mainmenu").hide();
        $(".data").hide();
        $(".section").show();
        $(".signature").hide();
        $("." + sectionID).show();
        $("#search").val("");
        $("#showhidesection").attr("mode", "show");
        $("span.brokenlink").hide();
        $("#export2TextLink").attr("onClick", "onclick=export2PaddedText(''" + sectionID + "'');return false;");
               
        $(".containertitle").html(sectionName);       
        //CG There has to be a way to remove the IF below
        if ((sectionID == ''error'') || (sectionID == ''success'') || (sectionID == ''information'') || (sectionID == ''warning'')) {
            $(".sectionview").attr("open-sig-class", sectionID + "sig");
        } else {
            $(".sectionview").attr("open-sig-class", sectionID);
        }       
        $("a[siglink]").removeAttr("href");  //remove links between signature records in section view
        $("a[siglink]").removeClass("hypersource"); 
        $("a[siglink]").addClass("nolink");
        $("." + sectionID).first().click();     
    });
    // Open signature
    $("[open-sig]").on("click", function()  {
        var sigID = jQuery(this).attr("open-sig");   
        $(".signature").hide();
        $(".sectionbutton").css("background-color", "#e7ecf0");
        $(".export2Txt").hide();
        $("#SignatureTitle").html("Signature: " + sigID);
        $("." + sigID).show();
        $(".sectionbutton[open-sig=''" + sigID + "'']").css("background-color","white"); 
        var e = jQuery.Event("keypress");
        e.keyCode = 13; // Enter
        $("#search").focus();       
        $("#search").trigger(e);       
    });
   
    // Print, Analysis and Full Section view - CG Need to clean this a bit. Too many classes.
    $("[open-sig-class]").on("click", function(){
        var sigClassID = jQuery(this).attr("open-sig-class");   
        // hide everything first
        $(".mainmenu").hide();
        $(".data").hide();
        $("#search").val("");
       
        if (sigClassID == "print"){
            $(".containertitle").html("Print View");
            $("#expandall").attr("mode", "print");    
            filterString="";
            // show all divs that have the print class
            $(".print").show();
            $("a[siglink]").removeAttr("href");  //remove links between signature records in print view
            $("a[siglink]").removeClass("hypersource"); 
            $("a[siglink]").addClass("nolink");
            $("span.brokenlink").hide();
           
        } else if (sigClassID == "analysis") {
            $(".containertitle").html("Analysis View");
            $("#expandall").attr("mode", "analysis");
            filterString="";
            // show all divs that have the analysis class
            $(".analysis").show();
           
            // add links to the records that are interconnected (links are saved in a separate attribute named siglink)
            $("a[siglink]").each(function(){
               // if target anchor exists, create the link. Otherwise, display an exclamation mark
               if ($("a#" + $(this).attr("siglink") + ".anchor").length > 0){
                   $(this).attr("href", "#" + $(this).attr("siglink"));
                   $(this).addClass("hypersource");
                   $(this).removeClass("nolink");
               } else {
                   $(this).closest(''td'').find(''span.brokenlink'').show();
               }          
            });
       
        } else { // Entire Section view
            if ($("#showhidesection").attr("mode") == "show") {  
                $(".fullsection").show();
                $("." + sigClassID).show();
                filterString = sigClassID;
                $("#showhidesection").attr("mode", "hide");
                $("#expandall").attr("mode", "print");            
            } else {
                $(".section").show();               
                $(".signature").hide();
                $("#showhidesection").attr("mode", "show");
                $("[open-section=''"+sigClassID+"'']").click();
            }           
        }   
    });
   
   
   
    // Open table data (for a sig)   
    $("a[toggle-data]").on("click", function(){
        var tabledataID = $(this).attr("toggle-data");
        $("#"+tabledataID).toggle();
        $(this).find(".arrowright").toggle();
        if ($(this).find(".arrowdown").css("display") == "none"){
            $(this).find(".arrowdown").show();
        } else {
            $(this).find(".arrowdown").hide();
        };
        var e = jQuery.Event("keypress");
        e.keyCode = 13; // Enter
        $("#search").trigger(e);       
    });
   
    $("a[toggle-info]").on("click", function(){
        var infoID = $(this).attr("toggle-info");
        $("#"+infoID).toggle();
   
    });
    $("#exportAll").on("click", function(){
        if ($(this).is(":checked")) {
            $(".exportcheck").prop("checked", true);
        } else {   
            $(".exportcheck").prop("checked", false);
        }
    });
   
   
    $("#expandall").on("click", function(){   
        if (alertOn){
            var returnVal = confirm ("This action could lead to performance issues and might even freeze your browser window. Do you want to continue?");
            if (returnVal == false) return;
            alertOn = false;
        }   
        if (returnVal == false) return;
        $(".tabledata").show();
        if ($(this).attr("mode") == "print"){     
            $(".results").show();
        }   
        $(".arrowright").hide();
        $(".arrowdown").show();       
        var e = jQuery.Event("keypress");
        e.keyCode = 13; // Enter
        $("#search").trigger(e);       
    });
    $(".collapseall").on("click", function(){
        $(".tabledata").hide();
        if ($("#expandall").attr("mode") == "print"){     
            $(".results").show();
        } else {
            $(".results").hide();
        }  
        $(".arrowright").show();
        $(".arrowdown").hide();
    });
   
    // Dynamic display based on the search string
    $("#search").keypress (function(e) {
       if (e.keyCode == 13){
         var searchTerm = $("#search").val().toLowerCase();
        
         console.log(filterString);
        
         if ((searchTerm == null) || (searchTerm == "")) {
            if (!searchFlag){
               return;
            } else {
               searchFlag=false;       
               var rowList = document.getElementsByClassName(''tdata ''+filterString);
               for (i = 0; i < rowList.length; i++){
                   if (rowList[i].style.display == "none"){
                       rowList[i].style.display = "table-row";
                   }
               }       
             return;
            }
         }
         var rowList = document.getElementsByClassName(''tdata ''+filterString);
         for (i = 0; i < rowList.length; i++){
            if (rowList[i].innerHTML.toLowerCase().indexOf(searchTerm) >= 0){
                rowList[i].style.display="table-row";
            } else
                rowList[i].style.display="none";
            }           
        
         }
         searchFlag = true;
   });     
   
   $(".sort_ico").on(''click'', function(){
      var tableName = $(this).attr("table-name");
      $("#restable_" + tableName).tablesorter();
      $(this).hide();
   });
    
}); 
function export2CSV(tbl) {
  var records;
  // if no particular table was provided as parameter, export all selected tables on the page
  if ((tbl == "ALL") || (tbl == null) || (tbl == "")){
    if ($(".exportcheck:checkbox:checked").length == 0) {
      return;
    } else {
      $records = $(".exportcheck:checkbox:checked");
    } 
  } else {
    $records = $(".exportcheck:checkbox[rowid=''"+tbl+"'']");
  }
       
  var csv = ''"'';
         
  $records.each(function(){
           
    var $rows = $("tr." + $(this).attr("rowid"));
    var level = $($("#" + $(this).attr("rowid"))).attr("level");
   
    tmpColDelim = String.fromCharCode(11), // vertical tab character
    tmpRowDelim = String.fromCharCode(0),  // null character
    colDelim = ''","'',
    rowDelim = ''"\\r\\n"'';
   
//CG comment    csv += rowDelim + $($("#" + $(this).attr("rowid")).find("div.sigdescription")).find("td").text() + rowDelim;
    csv += $rows.map(function (i, row) {
                            var $row = $(row),
                                       $cols = $row.find(''td,th'');
                         return $cols.map(function (j, col) {
                                       var $col = $(col),
                                       text = $col.text();
                                       return text.replace(/"/g, ''""'').trim(); // escape double quotes, trim leading and trailing blacks to avoid Excel misreading them as '' ''
            }).get().join(tmpColDelim);
        }).get().join(tmpRowDelim)
            .split(tmpRowDelim).join(rowDelim)
            .split(tmpColDelim).join(colDelim) + rowDelim + rowDelim;
   }); 
  
   csv += ''"'';
   // Data URI
   csvData = ''data:text/csv;charset=utf-8,'' + encodeURIComponent(csv);

   var downloadLink = document.createElement(''a'');
   downloadLink.href = csvData;
   downloadLink.download = ''Analyzer_export_data.csv'';
   document.body.appendChild(downloadLink);
   downloadLink.click();
   document.body.removeChild(downloadLink);
}
   
function export2PaddedText(section) {
 
   // export a full section - the section id is passed as parameter. If null, then return.
   if ((section == null) || (section ==''''))
       return;
      
   var $records = $(''.signature.''+section);
  
   //if no signatures in the section, nothing to do. Return.
   if ($records.length < 0) return;
  
   // define array for col max length
   var maxlen = [];
  
   // parse all rows once and gather the max length for each column in each table (first columns, second columns etc). Populate maxlen array.  
   var $rows = $(''tr.''+section);  
   $rows.each(function(){
      // skip if this is a sig title row
      if ($(this).hasClass(''sigtitle'')) return;
      $currrow = $(this);
      var counter = 0;
      $currrow.find("td,th").each(function(){
          if (($(this).text().length > maxlen[counter]) || (typeof maxlen[counter] == "undefined")) {
              maxlen[counter] = $(this).text().length;
          }
          counter++;
      });     
   });
   
   colDelim = '' '',
   rowDelim = ''\\r\\n'';
   text = '''';
   $rows.each(function(){  
    
   if ($(this).hasClass("sigtitle")) {
        var title = $(this).find(''td'').text()
     text += rowDelim + rowDelim + rowDelim + title + rowDelim + "_".repeat(title.length) + rowDelim + rowDelim;
     return;
   }
      $cols = $(this).find(''td,th'');
      text += $cols.map(function (j, col) {
         var $col = $(col);
         var text = $col.text() + " ".repeat(maxlen[j] - $col.text().length + 1);
         return text;                                       
   }).get().join(colDelim);
  
   text += rowDelim;
    });
   
    // Data URI
    textData = ''data:text/csv;charset=utf-8,'' + encodeURIComponent(text);
   
    var downloadLink = document.createElement(''a'');
    downloadLink.href = textData;
    downloadLink.download = ''Analyzer_export_data.txt'';
    document.body.appendChild(downloadLink);
    downloadLink.click();
    document.body.removeChild(downloadLink);
   
}   
</script>
');

     print_out('</HEAD><BODY>');
 
EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_page_header: '||sqlerrm);
  raise;
END print_page_header;
      
 
----------------------------------------------------------------
-- Prints analyzer header (title and top menu)                --
----------------------------------------------------------------
PROCEDURE print_rep_header(p_analyzer_title varchar2) is
BEGIN
-- page header
    print_out('<!-- page header (always displayed) -->
<div class="pageheader">
    <div class="header_s1">
    ');
    -- Print logo image
    print_out('        <div class="header_img">
        ');       
    print_out('<img src="', 'N');
    print_out('68JfxhhE1EQ0b+AumDJgpYFryK9Issi70SZREmieqMVoxOim6Nfx3jHlMdIY61iV8ZeitOIE8R1x2Pjo+Ob4qcX+izcuXA8wT6hOOH6IuNFeYsuLNZYnL74+BLFJZwlRxLRiTGJLYnvOaGcBs700oCltUunuGzuLu4TngdvB2+S78ov508kuSaVJz1Kdk3enjyZ4p5SkfJUwBZUC56n+qfWpb5OC03bn/YpPSa9PQOXkZhxVEgRpgn7MrUz8zKHs8yzirOky5yX7Vw2JQoSNWVD2Yuyu8U02c/UgMREsl4ymuOWU5PzJjc690iecp4wb2C52fJNyyfyffO/XoFawV3RW6BbsLZgdKXnyvpV0Kqlq3pX668uWj2+xm/NgbWEtWlrfyi0LiwvfLkuZl1PkVbRmqKx9X7rW4sVikXFNza4bKjbiNoo2Di4ae6mqk0fS3glF0utSytK32/mbr74lc1XlV992pK0ZbDMoWzPVsxW4dbr29y3HShXLs8vH9sesr1zB2NHyY6XO5fsvFBhV1G3i7BLsktaGVzZXWVQtbXqfXVK9UiNV017rWbtptrXu3m7r+zx2NNWp1VXWvdur2DvzXq/+s4Go4aKfZh9OfseNkY39n/N+rq5SaOptOnDfuF+6YGIA33Njs3NLZotZa1wq6R18mDCwcvfeH/T3cZsq2+nt5ceAockhx5/m/jt9cNBh3uPsI60fWf4XW0HtaOkE+pc3jnVldIl7Y7rHj4aeLS3x6Wn43vL7/cf0z1Wc1zleNkJwomiE59O5p+cPpV16unp5NNjvUt675yJPXOtL7xv8GzQ2fPnfM+d6ffsP3ne9fyxC84Xjl5kXey65HCpc8B+oOMH+x86Bh0GO4cch7ovO13uGZ43fOKK+5XTV72vnrsWcO3SyPyR4etR12/eSLghvcm7+ehW+q3nt3Nuz9xZcxd9t+Se0r2K+5r3G340/bFd6iA9Puo9OvBgwYM7Y9yxJz9l//R+vOgh+WHFhM5E8yPbR8cmfScvP174ePxJ1pOZp8U/K/9c+8zk2Xe/ePwyMBU7Nf5c9PzTr5tfqL/Y/9LuZe902PT9VxmvZl6XvFF/c+At623/u5h3EzO577HvKz+Yfuj5GPTx7qeMT59+A/eE8/txAYbrAAAAIGNIUk0AAHomAACAhAAA+gAAAIDoAAB1MAAA6mAAADqYAAAXcJy6UTwAAAAGYktHRAD/AP8A/6C9p5MAAAAJcEhZcwAACxMAAAsTAQCanBgAAAAHdElNRQfgBw4LKi43hzQHAAAAFmlUWHRDb21tZW50AAAAAABBcHBsZU1hcmsKy0CeVQAAIABJREFUeNrtfHdYVNfW/rvPOTBDmWFmKIp0saPRxILGXlJMNCHRGBNNUWzRXDTGxJKiUWPUmKioEWwpdlRiIfaoCCioWBAVpQ0gdYBhmMa0s74/KNEYr/H+cu/vK1nPM88ps2efvdde9V37DPBvJl15Rcilc8lyAMi/eQt/09/02FReWsYazysrNKMP7o2bM3/GDHrzxRfOF+fkfvk3h/7vEPurO6yurEq6dOVyUK2utllNcZHzJ9NnQMIL8G3TBmm3brK/Wf5/g7i/qiONRvNkfn4+3cm900e0OQJsdruz0tsLACCAkHvr5l86cKqu+cv6urDkXzemdOz4w78rK3+8vopKHq890UMVdXv3bn+uD532L+HhnDlz7rsW/qrFcTgc6RaLBTzHAQzgGAcbAU91fQqp6ZeJ/wutIx3+BUylABG55a6J/uT2z/usfK4agl0EBxEixzVpDAEgEECAgzE43GVoP22aNPj9aXMZY0QlxYy18KNzn8z7Sr9hk0UQGAAeHBgYifU9sIaPyEMkESapM4ImTWEdp7x3mHmq0h7qDpo3AxH1TRgxaogj6wa1mBR5q/v0mfsYY/Y/bB/QAkQUjhvZLxyY+C65FeSDJwaOEUSRwMBAHIGBINpsYlr37p6nmvlUXfJWuXx0/dYXGbM+ml8UF2fR+PnWjElNW/VIPh4/wpiHkojI8/L0mbPKTp6wuNZUg4kiCABjIgAGIgbGiQAxEBhq/IP5nl8tPnW85G6nSo3GM/X8xcNLl', 'N');
    print_out('y5N+/fEV+XlKXl5eXT58iU6deoU/ZJwmHbt2i1uXB9D+7dto6h33ukLAN98tew+Adv6/Q//mnDdzpp8vnu3Cp23DxlcXahW4MkgCKTnf/+pv1//cSKjREra5s3pWOt2d4koqbG/7BnTqZpxZBScyMg7kYEXyCDwDR+BDLxARieBDLwTmSUS0ng1pztDX6C4Ll1ldCyBPcSi8Jfmzdus9vShKmdnqhwzlqo+/cSDsm8/0L5iwQJmOPGrLO/d8VQS2poMri5kcOJJL/Bk5AUyCgKZeNY0LpOTExkEJ7oJUNXBg0Txez0qxo+nIqkLJXbsWPSn+XgtPSlRoSw3evmQwVlKtU4CGXmBTHzDnH93XiUIdDwktBQAVq5YUTRzxgd0J/s25RfkBfxbLBZjzMJx3B2JxKWNm5zyCcS1a99WHhoaqgKAd0eOCPh24fyg8ZMjdWazqSB+/8/yWbM+in3jrbHvvTXuXXos63jpUt+SBV/EtE+/DGPzZtD5+tWKLlKtgzHwjEEEA1dvpMAAiKzR6IhwmEyCl83q11ud43cmtLWfZcOmWMmkCZM5EuFEIgwSCazde9j1lVVF4HmOifVaCyaCGANPHIkms3vzkjIvlyOH6cXYdbXsuWF/KFj25KSng2/fGu9WXQkODKXbt5Hql0M1rHXbB9p7z5/vXjplSq3rD1tI6ixlZS0DyeKAmpNIOREOcJzQYEE5EANEUYSDY6jr1s0jd+lXgcO+WOjJE+DicIB3OByP4mHdlatOgr52R8bQl/t0N9WhTOlqq1V5lDl7e4uN9p4YAcTAABATwcBQanfgmV8OFSMkFL379y/Mvn0by5Z//eXmjZuK/nJrVVFRwQCgrKy8V1FRwbLfxwE/rlt7tX+njjTmhefp12NHyVvmTq4ATR43ji5fvBjy57UrkwGA/Vwq5QDiBY4TKT2diKjz44zXdOzEtTte3lTjLKHK6TOIiNxzp88gPRiluLoSEWU9IrbxKXvrLcpxllJacOgDSkHl9fywp52jbEBUA6TrFEY1TKAz3t5ERF8DAF2+8ttvUlK0twAx11kiFr07noho0mNZ8JMngrTjx1Olk0BJ7dqp/2nb7DvsqI+vKr1PP9I5S+hqUBBZ06/ufZznFaaeuy8+n/vJvH9PFlBSUvJ75vdJTkq8Hb877u7UkSOoHcdRWyeBPps+nUKaNyMFx1GPTp1o3NgxQY/FQHVRcnrfvpQNiPoDB4mIZABAObmPl2xETb1bIjjTDT8/qklJHps37X0yAXTe3Z3I5jj80OeXljIAsP0cT1lKFV1o1pzuX7ScxvkfOt8yiMoA0bRsOTmuXKaSTmFUIjjR9VkfEVVo/lE/7mwAQGqnp/LKBIGKP55FlJrat36ueY8nWJH1gpX8CMECAEtKsu6WwFMBx8hy/NhjWRuqqX5km7/MFUql0nr8qlovq6worj2Xcg4mYx0cjAOB4ATAZrOj/G4xRo0eha1bfoRfiwB06tTFDmyHRqNReHl56fLz86lly5YPF+C4Xf6Oi5fhaNeWrX75JdUnt+8YAIC1Cn2s8Xot/brsSuz3frLiYnLjuK2Vljpy1HtMQODUAIRtHcP8Ag1GCIyH3W4DJ/D42tdXZ7txs/Bmn77kra9heO554Jff5JC1bgUx6/aS7Kn/GNauqBTanr1Y5r79nkNmf1x95c03NvnlF0Y6rV+HK1cu9SAiJ8aYjXQ1SzN79wnhZR5QV2uX+/XsmQQALLjl46SI9b7/T5KYelHua3egxN0NvJe3v+VSeg5IdACMiVZzBtkctU35FmsIKTgmaA2GC0yhWvsfEyyVSgUi4u/eLSl1OOwEjhjjeEAkNAsOgd3JGRZLHZjAYdiI1/DGO+/i4rnzbSdOe78YAI6fOJEW3qNHYqtWrf6pCyi6mQkXToS8hT9GvzFGztq2+dfyZRfXnjZvTxtfUsbY7WwwQWAcAOYQAXKE7X/11c+tmdc/8zQZwRMDiSLAGCK8fFAS1gFteWfkOURq9ekn7F7BIiJ59gcfDBR/+BHE8+CeGXJz8MKFOjCGLps33b7W+Um0Vuej2mQdm9Jj4HQA1SgpMbnYrGBSKUK7djdi0+Z/Jch9rLy7KOsW/AEEW6yofOopEBDKfsukW3NNGXV9twRAD8AaGfkWgP+cYDX2x3FMz3jOjed5MI4DLzgjuENHzPhqKRw2M1546aWVnKvsi4DAAGttjW7s+aTkX69cu8a+XLjIjxP4NgAmPUoxeY4DgQPo/wmGc4ggEE8AA4hYvcIz', 'N');   
    print_out('BhCrjIiP/9ySeX3GhU6d3MM5njECHBwHncMBC8dRpsKDeUVFMT4wqF/T2H4+wC6/8DzfzGztKbeaYFGp0MzVJbBi9eo8zapvqezHHxXtxoxF+YIF4C9cQK/Y79S4eEYOTvAC4yFChCg6OPwHiGMNYsRxMAGAm6weWQGBeB6MRBARGGNgoggLA7Q+nvDmuX7/UaRVq603HJqqysRb2XfoesZ1Sjufejct7WJRuaZqUoM2qwC4XLt2Vbdnz24K9vAgF4B2bdtO7dq0bVQQzJ49G/ce74uNNm4sTHaT0a3AQMqPju4DAKTR/HmPcaMeqKWKisrLPBOzGMh6MZXyJ04hA0CpUimR2VjY2N6Wn1173c+fDLwT6ZQqEjdtJsq6/VArafx2FVUAopVxZAHIDFBdw/GWyoust+8UXh/yLJW6y+k8IDryCjRENOF6pyeoykNOqe++sxoAKPH048Ev98RYSX8ixrLFbiQNQFfcZUQORwURtSSijkT0RMNayYhI2XAcTkSu/1+Qd6VS2Wiy3vGWq770VHkt69EzPDA8vHtAbaXGdeuPW+fsXLe2qq3gZPrp25Xy2pJiMIcNIgCzwYBhL76Ad95+CwCwbNkyLFmyZPayZcuQkZFxn4H3evmlXwNfewUuhYXE6WqTiKgX8/YGlfw51JqFdQARdS6a9g8nP45nkrAOgFy2VGxAcIlxAO+cW4+c32VOIa3lfj/9cDavhR9MJjNKV62E6UBCLABQSQmrD2br5czy84EtubM+hOgmZ8ZXR8CwaBGMXyyEaeEi6D/5BB4z/vG1c9s2gR23/7TBOnoU2joJLDNiuASAp0tYhxq7yQyfurooupAay/oPbOr/zwVNBCIGERwY9+hgy9quzYliNxl8rRbkL1/mDEDBGMtkjGU0wEd6xpi24XiIMWZqnOd/nKqqqh64Fz3rQ13C9p20d/sOerVHD3oKoDAXV1q/ZDEN6NiRAIinj52gK+mX12feuK4kIveUlJQqH29v0mg0SX+Y0aSm0W1AvOkmJ0o5ZyKiyY9RBnE3HE0wq728qNpJQuUffEBE5JE97X0yAnTe1Y3I7tj/gIb/sF13zrsZ6RlHSX4BRESJAGBauLCpTXK3bnd1gpSqhg0nUucSEanI7ggihyOIiPzu7e/S+MjVFUollXp7k27vXhulXhRvcwIVuLpS5sBBRERnH8tiHT8WXDVuPGmcpXSmVdv8R7UvmPlBs/T+/ahaECg7JJTo+LEVjw1S56v/fTHWjYuXENZQl6q5liHPO5ukLLJa/d2lkuSvJkzAsRXfULPOT2D4lCnw8/WDGoDdYoXNQdT/xaH5Q16OcB/w7BC/07+eF3Jz08pj18fIVZ5eVKPTYcSIEQEPTOZuMUP0WrkycmKtsHUbCns/7WJp1jym9KUXY0QnKRjjwBjVa3CTvosgMEhsIu52fQri5Sskc5Igq1c4/CTOkxljupz3/wERaPzNfZaCtscxNmaUh7UgL/9m13DPJysrZGl+fv3q5s+PlX7++WRrQUEgrl4tqJ40CUZXF6hb+HzzdHDoLKoqZ8yz2R/m5l03b8q9oFajzZlE3BoXKTyVmgbx1VeKXQ4f8VOcPotbEknf4r59CBIJGHEQGcBBbCpTiQRwvACTww5TxCtASKACEME77Ginrwkue+VlImqcPerLQURgHKGcEyB9aZj2qalTbxSOfqND80tXmPrliA9zWod+6N6qLewkPjTD5JwFFHr7IHz1mtlM5rb8LxesmmotFColwrp3gzo7J2pj5ARF3JIlQ5WB/j29uveAVupKYrWWuXGM5VzLwOXTp9F1yEAYjbWoqKhcM3jIkAsdevZMWjh79tBFn8+3tWrVCrNnfgQiEYuWLoWPtzcG9B8oP3v2fsVl/n4EQE/nUzqXtA29xsfvB3JzYTx5GhA5cEwEQUQDaNy0EBwAMxjIyRnuffuxDE159IDExFzG2AYAMAgCSCKB1sUN4LnS+545ZhRRZTljXs1CTjz/XGen0vKriuxs3NodN+nkO+9ITZcuiJejPkALvRH8G6PQK3ZTHDZsBvNsRn9cnNaAMRZNF1LrLo55K1ZZdBfpsz5Ez18Obi2Z+0l/55KSXtzhBNjS0wEHqx88UX1iUV/5BAODgWcwPtUNXfoPiBWzclwNEiksbq5wNughHj0JwAGAQSRCPZpOMJAIt/Hj0GzAYBUA0OlTk4qPH4tlcfFgJeUwFZWA53g0SeXvS3cMCP5uXRWTuS2nfDVYSPBfI1g1l69A8dSTUKiUKNVoXriZmfl9zqV074rr15lDYChNTYEjLR0jvpjP5L4tUKfVQgIHtX7iCRb+7DO1KUdPtEzIuFYV6+urOXRgn/Mve/fIiwuKEPHmaCiUCtgtVvTr25eZzXV9+g8arF646IsH44Pvt4D16p1BRP7Xiu4KJbpayAUGT', 'N');
    print_out('mTgQPVMaciRWQN7eQB2jkedxBl+PZ/mBiz/Ss0YI7pzB6xNG+h5PqTGzZWqXVwYgAd8OvNqRud69MDTR49dSxr5ur+1pFiwlZdBdDg4J3c36PS6BaLECV0HD7Izxorp5k2wDh0eUpz2hn3bVrAePTckPP/cCbFaJ146fQY9LXVii6VffVl3/Khn9oXzUKgLxZBPPwkuWLxULchkHNWjbCAicJwAI8/QvF9vjo/bpHYMHcXrnaUtK1zcRKloB8d4EBPBEeAgERx4EByottnx3OujGNbHwL5vL9jAQRuoqvJEypUM0Wqug6vNVm/dGqzj70aOAnKgxzvv2PHuuw8VqgdM/p+hczu2Bfo4SecwqfQ9Awhqq4W4qmp2fM5cKHgOoihCI3XHyBXLUJp9BwnfrUfHXj0h8/F0mxm7yXQofp+qtrhUnZWV5d6tX2/2+bQo1FRVos/QoWjWKhTfRq85C6A//iZQrRZMrmw6/k+iP2WxiIilJCcv0ZaUcCXJKR9n7I6HaK+D3skZwZMnMFmrUNiZAE4UAZHACQJatm4DI481S/YfzG0V3g11tcaZ3V8f0zbryuWxW+Z+ijqrGabKKgQGh5C2WsvKS0rPRP+09ci30WuWL5w/f3X3bt0/Hzp8mO7/smA1CtP/NKF6MEitqgbzVP12bbPurykpfiozt5Cr0FT4uRr0yP3ySzS3AXXkQJ3DDqdePSF9YSjobgkyDh5CWUEhlh2Kr1X16tWCZ8xYUVai2Tx3rtOVU2c8fLt0RugTnXFw5WrYjAZ0jYhAxJT30O+5Z1hezp3ZhUUl7y2c96lT5o3rLSpqdao7N2/VtOnQvgG3ZA/1+3/Tf1OLlZaWhvDwcDBPFchB4XdWLDtf8OMOdiK4JTQSKTp8/jlKeUB0OCAwHk4cwe4Q4eosAeN4SN3c4NInnMa9Nfqb1qGtP9ry9NPQaDSrjh0/Pv3nzd/T1bi9TOpwoCQpCX0GPwOHqxusdjvOnU3+aEnc7oKUpERavWw5wjqGobamEpW1Oko5k1jdpkN7do/VhLu7+1Iims0YA2MMoij+vYL/DUipVEKlUrXMyMjIv0+wwsPDceXKlajCzBuq1OVfvyzs3sXaWK2wurrD02ZDxa5d8BjzBkw8B7e2bWG/ehUCY9DZbHB1dUnz8fM/0rl3z5uuvLDHUVMdtXj026H7VnwTFfhkF0gkzsxhs4PjODCHAyazGePnfwqb0YSuA/qOTjl7tsvVM6foxJ44ps4MQ/fwHrh1K4vp9bWxv5/A66+/fhSAxWazEc/zf6/ofxPy8PCQeHh4VGdkZPzmCq9cvyS3WcT88jKN0lJSwJonn0fI+QtgImBzEGwcocpVgso3xsDWMgjmikqYklPg5HCgba8++vCPZsgBQFtdmZt94yaXvPmHoOojJ5jVUgdbq1D0fncsTkevhUFdAItCjp052SjTm6CtrMCPK5ajS5++uHDqDA7s3gleIqXTd7IM/kHBwQC0hXn5FNiyfrvW6NGjsWvXrr9X8X8IcRLeVWcxW5UWSx3jRB7ODgJHdgggOPMceDsHjgR4eCkgU8iLm4eF3X1pQ+zUt+P3svCPZsiLbt6ITTt7ln799XTL4qK7wZoLacyd7JAxgvZGJnyDAtFlwrsIGPEKvjl+AoVVVUg+fRwp++NxbOs2fDdvHvoMGYy2Xbpg7MRIg39QsLwoP08LoEmoANwnVLm59Xuv7Ha7n16vDxJFsTkArFy5EgBgMBj8jEZjEBHJAWD+/PkAgOzsbBARy8nJCSkrKwsBgEuXLt2PsNtsD4CyFotFnpKSEnT9+nU/ANDr9X51dXVBJpMpyGQyBZnNZj8AMJvNfmaz2c9iscj0en0IANy8eRP79u0DETGdTqcEAKPRGKLX64OsVmuQXq/3u7fW2li9MJvNLa5duxZCRKxxjI0vTzS2JSKXxjEaDIZgvV4fZDabQwBgxYoVjfdDDAZDcCMvfvrpp3uTMvnZs2eDdDqdHwCcPn0aJpNJMBgMIUajMaiurq6pWmAymYLr6uqC9Hp9kMFgCDKZTCFGo/GhyZ8giiJADgYmwsIL0CqVaCaRQGayApwIgeegV3hgwMiRGZynd9NOTbJaotS/ngk9PefzSUajCR2nTYReJDjAAxyBF3hYRTu693oavYYNR53FirvZd3D11CmIINhNengA0Fdp0SW8R2L009tOtg7ruBgAXhk48J9qQ2hoKEwmU3hMTEyq0WiE2WzWR0dHb4mKippBRO7R0dF3LBaLa2lpaeqSJUtOz5s3b16HDh241q1bi2q1OmbdunWTZDIZLBbLZIlEskGhUKCmpgYzZ87sFR0dfQ4Ai4mJYe3atcOAAQMoISHh7MGDBzsrFAocPnw4cO3atZcZY148zzfFebt37267c+fO80ajUXQ4HCusVutSo9H4npubWwwAHD', 'N');      
    print_out('p0aGNZWZns2LFjSTExMWvsdnvj4tYC8FAqlZg/fz48PT1BRM0WLlxYrNFoMH369A3dunWbvG3btgFvvvnmmwAmKZVKEJHkk08+SUhLS5sfHh6eHBsbm2+z2cDzPKZMmTJ51qxZGxITE6fExsauF0URJSUlqYmJidv69++/rlWrViwnJ4eio6PPpqend+7SpQuIqDNjLGPVqlUBDocjz2q1gogwZcqUzjExMRmrVq3K5zgOgiDAZrOB1e+OaAngj8tHN29m0dmziXQw4QDt3bOHDsRuoPOvRtC14JZ0NSBEvNC3H1lvZurulfIL59OqTnyzUtzYvRftCQyln/xCaMWAwXT4uxj6ccZM+kgmp6m8QEkrVhERUW52DqWcOEmRT3SmkXIl7Vz2NW39chF1Buij4cMJAMpLSiY+++STRd1bhqQAgEP7zwueRqPxCz8/Pxo5ciSNHTuWFAoFjR8//iwRtVcqlbpnnnmGBgwYQG5ubtSnT59kAAgODk709/enCRMm0MCBA8nHx4c4jpsEAGvWrPEbOnQoAaC9e/cmNz7nl19+0TVv3py+/PJLGj16NL3xxhvV06dPp4kTJ1JoaKg4cOBAcebMmZSdnT23ffv2uXK5PPerr76a4+LiQlOnTi1qsIJJbdu2JQCz4+PjCwHQ4MGDafLkyRQZGXlfyWfdunXTAwICqtu0aUNvvfUWeXl50cSJE898++23H3p7e9+XFrdo0YJOnjz5BQA4OTnRc889R5GRkY27REadOXMmHwANGjSIBg4cSAqFggBMBoD27dvXymQyWrp0KXXq1InGjRtHhYWFMhcXl2CpVEpvv/02vfbaa007TiZOnEhjx44liURCI0eOpAkTJtD48eMfjpBmZd2kS+mX6NdTJykh4Rfaf/AAbfvh+7vX9u1RU2mZttGEWjWa8NzsbMvJ4ycpfts2cd2AwbQrtC0dDGhFcUGhtKpNG4qbP59+2hR79+SGTUV1t3NINBgpKTGRdm39iQ5s3ECjBIHGCk4UM2UqHdu1i+I3xFLZ7dvivrh99MO69dRT6UGdpS7lROT9KB9uMpkWKBQK0mg0eQAwaNCgPAB5RDTFy8uLEhIS8gBgypQpRQBy7Xb7nObNm5O/v3+ThrVu3ZrGjBlDJ06cCH7yySdbcRxHzz//PKlUqqbqqqurK/n6+s5pWDx5586dRQByIlJFRUXRqVOnmha7Xbt2arlcrgaA4cOH5wG4CwBjxoxRu7m5iTt27Hh77969eQBoxIgRXxGRLCcnR37vvMLCwhYAoP379xcSkXPfvn3TXnrppaQVK1Z84OHhQfcouIenpycdPXp0QeM4x4wZMxsAduzYQZMmTTIlJSU5AFDPnj1nN2RvNHXqVMrKyiJnZ2fHnTt3JgNA7969VSqVihYtWkQAPIKDg0mpVHoQkcfkyZPpyJEj1BB6zFEoFFReXv7IIjfn7u5xw93dHV5KLwQFBiKsfVjimHfe9e884rVg5ttcyRirpaybsZpTv6YK1zOcXWEHY2ASuwgJOPCcCIF4WJmANqGhGW9PmOw/eGLkazUyN1w6cgQ39sVDSoDDboMzxyDabejarRuejXgFHQcOwZEDB1n60QQIFgsEBweJs7MrgLBHDdzhcIDjOOTk5KjS0tJmpKenK4ODgz0AZFosFvOdO3cU69atO7N//35/T09Pj0WLFpm1Wi0iIyObIIzIyEgkJSUhIiLCuGzZsu+kUik+++yzpSaTyZeIegKAIAiYNWuWtMHy1F67do0DUGs0GmV2ux1Wq/U3ZnIcGl+Q2bJli1KhUPgR0Yzt27fbjEaj+s033/xJFEUOAO7cuTNn6NChtVFRUfdtEfjhhx8kvXv3RkRERMDzzz9viYmJOXvw4MG+dXV1isY2Wq0WjDEdY7/BkKIookWLFs9fvnx59urVq7Fhw4YPHA5HHgA88cQTz//888+ztVot8vLyjn733Xdaq9Va0KZNm9hdu3Zh1apVsuHDhzfGX8xkMmHOnDkLVqxYseDAgQPQarXvA0BlZaWUiGA2mx9ZsRGcJdK+vMXswfM8eXh4kMJTWdU4YG1F+Xv5K9fMuTFhSiCv1cIqdUFtxw5wHvocPJ7sjJqSUgSIDlTU6mnIvIWGLm+/3RkArqRdOJd/JhFZ27bCUqWFRW9Ay/79wPwDYCguQvOuXXA1MxOFN27gcHQ0NBoNpGM4tHiyE7p162ZljJ0xl5bCxdf3nw7ezc0NgwYN8vDw8FgZGBiI4uJidwBDXVxcuHnz5ikFQejv5uYGX1/fIIPB8CERQRCE+wSB4zi88MILtmXLlj0TGRmJ3r17z23evPmcWbNmDQWQyhgDxz24bU0Uf9theS/W1giDeHl5BRGRbs+ePZ97eXnJgoKCitPT05v66tevH3r16gXGGB0+/NvW5m7dun2RkpIyLyEhQXz', 'N');
    print_out('llVcwYMCAWSqVqrtMJjvQCBDX1tbWbx2759kWiwWxsbEDtm3bNkChUCAvL0+Rn5/PNViwAfHx8QNGjx6NadOmndq8eXObRnDc398fPM/Xw0EN/Wk0GnzzzTcztFot5HL5RhcXl/WN83ssaswyrFarU1ZWlkqtVusO7t1HpxZ/Sde7Pkma0NZU1rItFYa0o5SuPShxw0bavfl7Orpunbiid5+c/P0HiYhcb928deLIkaO0Y32MuHTwEFrRIoC+UnrTljfG0qEft6mzrmVS5d1iOnnsGO3Zs5diFi2iV+RyGsoL1Atoekc7+rNPH6kRZrN5gUKhIKPRmP+78lMfiURSe/z48WwA7wGguXPnuhUWFk718fEhLy+vu0SkLCsrUwUEBFBERISDiNoDIJlMpm/RogX5+PiQj4/PagDw8/MjPz+/laIo+i9evLh3ly5dyMfHJ6SmpiZoypQpTW6iwY2pZTJZkwX6/PPPdZ6enhQYGEhVVVVJABAXF6cGQBEREV8ZjUbZxYsX5fdmp3K5fJmrqys1zGWMt7e3GUB+QkLCBwqFgpYvX64ym82K27dv10okEjEtLe3DRlcYGRl533vuJ0+eVDfEWPfdv3XctkQaAAAFt0lEQVTrVrJCoaDDhw+vr6io8B81atTTvr6+9Nlnn+kAqEJCQgiAcPjw4doBAwbQxo0bAwGgvLx8gYeHB6nVavWfQt4bd38WFBRst9lsr+Xl5cGh18MpLwceVisY6t9f4RmDzMkJvLPkjKlFi9NePt41s6ZNi56e8Mu55JiNxqrCArgFB8FBDiYIAgSeg+gsBRPYr8NeH7E/r7h0TU5xMURGIBKhaOELm6sb/Nu2w3tvjVW8FBUFAIhatPiRqiGKotRut0Oj0Sh+95XNarWSRqMRXn311dP5+fm6uLg4w5IlS9pWVFRMfPnllzdGRERUV1dXo3379ti/f3/w6tWrr3Acp6utrR0GoMfPP/8csGbNmhkLFixYyhiL3bFjx4z3339/RmlpKaRS6dWPP/64ShRFz0ar1Uh1dXUwGo0AgOXLl7OPP/44CIA2KioqxtPT871GSwcApaWlcyZOnDjH2dkZGo3maW9v7/MAwPN8/ODBgz/OzMykd955ByEhIRg6dOiVF1988dibb76JlStXVhUUFGDLli2YMGGCPjw8/JuGmBOVlZXS30EnjRBG0/2zZ8+y9u3b95HL5bGRkZFTIiIipqjVagwaNOjaokWLugAINplM6Nu3r/+GDRuCjUZj1Z49e+YAmEpETjabDUTk8chaYXV1NVQqFcrKys5XV1f31Gq1qKyshF1TCe+kRISkX4LMYoPNIQKCM277eKP3z/uXMm/VXACoqap+/9bBhDVXFi+C3C5CG+CPVtPeQ3VqGvLj42CHM4Z8Ou9gl1EjdCWa6rdqtFro9VroDSaYavVQMobeT/fWykNDVI9V+SfChg0baNKkSXLGmP7e79asWaMdOnSo2KpVK8+cnJyqxMRE1TPPPLM8MDBw9s6dO/tmZWWdVSqV8PPzk7/22mv6uLi4KqPRiHHjxnkCwNq1awNlMlmBi4tLy1GjRuVv3rw55sKFC5OdnJxq165d69GIKW3atGmHl5dX7CuvvHKmwRpV1dTUYNKkSZ4N18EmkynfbDYHiaJYOG3aNOTk5FQdPXpU1egyJRIJRo4cOV0ul0cHBgaisLAQp0+flmVmZtbm5eXB1dW17+LFi68yxgw5OTmylJSU2vPnz6NPnz4YPny43MPDQw8AmzZtosDAwKXPPvvs3EY+FBYWVh05ckTl6em5dOTIkXPvDSGMRiO+//77mNTU1MlhYWG1UVFRHgCwfv36YLlcni+Xy0OGDRtWsGXLlvVKpXLyq6++ykRR7LF58+a0CRMmPMDzPySDwdBSrVZXXr2aQWeTkulQQgLFb99Op778kjL79qWy0DZU0r4D3e7ag0qWLE8EESssLJx2/fp1OvjjD7S5c1c6EdiajgSEUIyvP13YsUvcvnFD3tHoNWrD1WtJAFBZoTmWk51LGVev1iYnJeadT005AwAb4/bKD38XO2z5lPfos9dH9f2zgrVnzx5277GRdu/e3XRdUFBwX3CUnZ39QB9Hjhxpan/o0KEHXPDv0f5PP6130zt37rzv/vHjx5t+u2/fvj905fn5+Q918RUVFU3n8fHxf9juxIkT991PTExkALB3796m+8nJ9UjJ3bt32e/Gd19fx44du+9669atDzwzLi6u6fz06dPsj3j8T3c3VFVVjTYajTt1Oh1MRiNq9XrodDrYjWa4lZSgpakWTKvd59emXYZxQqSyRl0wo7j4LrQ1NRDulsD8w0+QVetgZ0C+3Y5phw/PlXYJW9rEtMwbnE/HMLGyUjMdYCnu7u7u2dnZg6u11a9VllW03fbxHJSqc/FWVBSmRUf//R9a/1t2N3Ac9z', 'N');
 print_out('PHcYE8z3McX78t1cnJCXYXQm1AAORPdCD/Tp0rGGN1xa+NCDWZDatEkWC32eGw22AAQBwHOwAdzzFpl7D7gjufjmFiRUUFvLy8VzcIsicRFVZUaDZb6+qovLwcAoCq6uq/hep/Cf0XtNFmA3zXn6gAAAAASUVORK5CYII=" title="Click here to see other helpful Oracle Proactive Tools" alt="Proactive Services Banner">');        
    print_out('        </div>', 'Y');
       
-- page title
    print_out('        <div class="header_title">EBS '||p_analyzer_title|| ' Analyzer Report <br>
        <span class="header_subtitle">Compiled using version '||g_rep_info('File Version')||'/ Latest version:</span>
        <a href="https://support.oracle.com/oip/faces/secure/km/DownloadAttachment.jspx?attachid=1411723.1:CP_ANALYZER">       
  <img class="header_version" src="https://blogs.oracle.com/ebs/resource/Proactive/cpa_latest_version.gif" title="Click here to download the latest version of Analyzer" alt="Latest Version Icon"></a>');
 print_cloud_image;
    print_out('        </div>
    </div>');
       
-- top right menu
    print_out('<div class="topmenu">
          <div class="menubutton" id="homeButton" title="Open the analyzer''s main page">
          <img src="" class="smallimg">       
          Home</div>');
    print_out('<div class="menubutton" id="execDetails" title="Show the analyzer''s execution details" data-popup-open="popup-1">         
          <img src="" class="smallimg">
          Execution Details</div>');
    print_out('<div class="menubutton" id="execParameters" title="Shows the analyzer''s execution parameters" data-popup-open="popup-2">
          <img src="" class="smallimg">
          Parameters</div>');
    print_out('<div class="menubutton" id="feedback" title="Opens the Oracle Community feedback thread"><a href="https://community.oracle.com/thread/3093389" class="blacklink" target="new">         
          <img src="" class="smallimg">Feedback</a></div>');
    print_out('<div class="menubutton" id="analysisView" open-sig-class="analysis" title="Displays all data in a single page, without the Errors/Warnings/Passed Checks/Information messages - Click Plus (+) icon to expand all Table Data">
          <img src="" class="smallimg">
          Analysis View</div>');
    print_out('<div class="menubutton" id="printView" open-sig-class="print" title="Displays all data in a single page, including the Errors/Warnings/Passed Checks/Information messages - Click Plus (+) icon to expand all Table Data">
          <img src="" class="smallimg">
          Print view</div>
        </div> 
    </div>');
EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_rep_header: '||sqlerrm);
  raise;
END print_rep_header;

----------------------------------------------------------------
-- Prints execution details pop-up window                     --
----------------------------------------------------------------
PROCEDURE print_execdetails IS
  l_key  VARCHAR2(255);
BEGIN
  g_sections.delete;
    print_out('       <!-- print Execution Details pop-up window -->
       <div class="popup" data-popup="popup-1">
            <div class="popup-inner">
                     <table cellpadding="3" cellspacing="0" border="0" width="100%" style="font-size: 14px;">
                        <tbody>
                           <tr>
                              <td colspan="2" class="popup-title"><b>Execution Details</b></td>                             
                           </tr>');


  -- Loop and print values
  l_key := g_rep_info.first;
  WHILE l_key IS NOT NULL LOOP
    IF ((l_key = 'FullHost') AND (g_cloud_flag)) THEN
        print_out('                       <tr>
                              <td class="popup-paramname"><b>'||l_key||'</b></td>
                              <td class="popup-paramval">
            <span title="">'||g_rep_info(l_key));
        print_cloud_image;        
        print_out('                                 </span>
         </td>
                           </tr>');
 ELSE
        print_out('                       <tr>
                              <td class="popup-paramname"><b>'||l_key||'</b></td>
                              <td class="popup-paramval"><span title="">'||g_rep_info(l_key)||'</span></td>
                           </tr>');
 END IF;
 l_key := g_rep_info.next(l_key);
  END LOOP;
 
  print_out('                       <tr>
                        <td class="popup-paramname"><b>Start time:</b></td>
                        <td class="popup-paramval">
                          <span id="start_time"></span>
            </td>
                     </tr>');
  print_out('                       <tr>
                        <td class="popup-paramname"><b>End time:</b></td>
                        <td class="popup-paramval">
                          <span id="end_time"></span>
            </td>
                     </tr>');
  print_out('                       <tr>
                        <td class="popup-paramname"><b>Execution time:</b></td>
                        <td class="popup-paramval">
                          <span id="exec_time"></span>
            </td>
                     </tr>');
  print_out('                        </tbody>
                     </table>
                <div class="close-button" data-popup-close="popup-1"><a class="black-link">OK</a></div>
            </div>
    </div>
  ');
EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_execdetails: '||sqlerrm);
  raise;
END print_execdetails;
 
----------------------------------------------------------------
-- Prints parameters pop-up window                            --
----------------------------------------------------------------
PROCEDURE print_parameters IS
BEGIN
 
  print_out('    <!-- print Parameters pop-up window -->
      <div class="popup" data-popup="popup-2">
            <div class="popup-inner">
                   <table cellpadding="5" cellspacing="0" border="0" width="100%" style="font-size: 14px;">
                        <tbody>
                           <tr>
                              <td colspan="2" class="popup-title"><b>Parameters</b></td>                             
                           </tr>');
  FOR i IN 1..g_parameters.COUNT LOOP
    print_out('                           <tr>
                              <td class="popup-paramname"><b>'||to_char(i)||'. '||g_parameters(i).pname||'</b></td>
                              <td class="popup-paramval"><span>'||g_parameters(i).pvalue||'</span></td>
                           </tr>');
  END LOOP;
    print_out('                        </tbody>
                     </table>           
                <div class="close-button" data-popup-close="popup-2"><a class="black-link">OK</a></div>
            </div>
           
    </div>'); 
EXCEPTION WHEN OTHERS THEN
    print_log('Error in print_parameters: '||sqlerrm);
    raise;
END print_parameters;

PROCEDURE print_mainpage IS
   l_loop_count NUMBER;
   l_section_id  VARCHAR2(320);
   l_counter_str VARCHAR2(2048);  
BEGIN
  
   l_loop_count := g_sections.count;
    print_out('
<!-- main menu with tiles -->   
    <div class="mainmenu">
     <table align="center"  id="menutable">
        <tbody>
            <tr>
            <td>
              <div class="menubox">
                <table cellpadding="5" cellspacing="2" class="mboxinner">
                <thead>
                <tr><th><span class="menuboxitemt">Execution Summary</span></th></tr></thead>
                <tbody>
                <tr><td><div open-section="E" class="menuboxitem"><span class=''error_ico icon''></span><div class="mboxelem">Errors</div></div></td>
                <td align="right"><span class="errcount">'||g_results('E')||'</span></td></tr>
                <tr><td><div open-section="W" class="menuboxitem"><span class=''warn_ico icon''></span><div class="mboxelem">Warnings</div></div></td>
                <td align="right"><span class="warncount">'||g_results('W')||'</span></td></tr>
                <tr><td><div open-section="S" class="menuboxitem"><span class=''success_ico icon''></span><div class="mboxelem">Passed Checks</div></div></td>
                <td align="right"><span class="successcount">'||g_results('S')||'</span></td></tr>
                <tr><td><div open-section="I" class="menuboxitem"><span class=''information_ico icon''></span><div class="mboxelem">Informational</div></div></td>
                <td align="right"><span class="infocount">'||g_results('I')||'</span></td></tr>
                </tbody></table>
              </div>   
            </td>
            <td>');
           
    print_out('
                <table>
                <tr>');
    FOR i in 1 .. l_loop_count LOOP    
        l_section_id := replace_chars(g_sec_detail(i).name);
        l_counter_str := '';
        IF (g_sec_detail(i).results('E') > 0)THEN
            l_counter_str := '<div class=''counternumber''>' || to_char(g_sec_detail(i).results('E')) || '</div><span class=''error_ico icon''></span>&nbsp;';
        END IF;
        IF (g_sec_detail(i).results('W') > 0)THEN
            l_counter_str := l_counter_str || '<div class=''counternumber''>' || to_char(g_sec_detail(i).results('W')) || '</div><span class=''warn_ico icon''></span>&nbsp;';
        END IF;
        IF (g_sec_detail(i).results('S') > 0)THEN
            l_counter_str := l_counter_str || '<div class=''counternumber''>' || to_char(g_sec_detail(i).results('S')) || '</div><span class=''success_ico icon''></span>&nbsp;';
        END IF;
        IF (g_sec_detail(i).results('I') > 0)THEN
            l_counter_str := l_counter_str || '<div class=''counternumber''>' || to_char(g_sec_detail(i).results('I')) || '</div><span class=''information_ico icon''></span>&nbsp;';
        END IF;
  IF (g_sec_detail(i).results('E') + g_sec_detail(i).results('W') + g_sec_detail(i).results('S') + g_sec_detail(i).results('I') = 0) THEN
      l_counter_str := '<span class=''menubox_subtitle''>Executed, nothing to report</span>';
        END IF;
        print_out('
                <td>
                <a href="#" class="blacklink"><div class="floating-box" open-section="'||l_section_id||'"><div class="textbox">'||g_sec_detail(i).title||'</div><div id="'||l_section_id||'Count" class="counterbox">'||l_counter_str||'</div></div></a>
                </td>');
        IF (MOD(i,3)=0 ) THEN
            print_out('                </tr><tr>');
        END IF;
    END LOOP;   
    print_out('       
                </tr>
            </table>
            </td></tr>           
        </tbody>
     </table>
    </div>   
<!-- end main menu -->     ');

EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_mainpage: '||sqlerrm);
  raise;
END print_mainpage;

----------------------------------------------------------------
-- Print footer and end of html page def                      --
----------------------------------------------------------------
PROCEDURE print_footer IS
BEGIN
print_out('      <!-- footer area -->
    <div class="footerarea">
        <div class="footer">
            <div style="visibility: visible; max-height: 33px; min-height: 33px;">
               <span><a href="https://support.oracle.com/epmos/faces/DocumentDisplay?id=1549983.1" target="_blank" class="blacklink">About Oracle Proactive Support</a></span>
               <span class="separator"></span>
               <span><a href="https://support.oracle.com/epmos/faces/SrCreate" target="_blank" class="blacklink">Log a Service Request</a></span>
               <span class="separator"></span>
               <span><a href="https://support.oracle.com/epmos/faces/DocumentDisplay?id=1545562.1" target="_blank" class="blacklink">Related Analyzers</a></span>
               <span class="separator"></span>
               <span><a href="https://support.oracle.com/epmos/faces/DocumentDisplay?id=1939637.1" target="_blank" class="blacklink">Analyzer Bundle Menu Tool</a></span>
               <span class="separator"></span>
               <span><a href="http://www.oracle.com/us/legal/privacy/overview/index.html" target="_blank" class="blacklink">Your Privacy Rights</a></span>
               <span class="separator"></span>
               <span><a href="https://support.oracle.com/epmos/faces/DocumentDisplay?id=2116869.1" target="_blank" class="blacklink">Frequently Asked Questions</a></span>
            </div>       
        </div>
    </div><!-- end footer area -->
  </div><!-- end main div -->   
');
EXCEPTION WHEN OTHERS THEN
  print_log('Error in print_footer: '||sqlerrm);
  raise;
END print_footer;
----------------------------------------------------------------
-- Print execution times in the Execution Details page        --
----------------------------------------------------------------
PROCEDURE print_execution_time (l_time TIMESTAMP) IS
BEGIN
  print_out('     <script>
      $("#start_time").text("'||to_char(g_analyzer_start_time,'hh24:mi:ss.ff3')||'");
  </script>');
  print_out('     <script>
      $("#end_time").text("'||to_char(l_time,'hh24:mi:ss.ff3')||'");
  </script>');
  print_out('     <script>
      $("#exec_time").text("'||format_elapsed(g_analyzer_elapsed)||'");
  </script>');
 
END print_execution_time;

----------------------------------------------------------------
-- Evaluates if a rowcol meets desired criteria               --
----------------------------------------------------------------
FUNCTION evaluate_rowcol(p_oper varchar2, p_val varchar2, p_colv varchar2) return boolean is
  x   NUMBER;
  y   NUMBER;
  n   boolean := true;
BEGIN
  -- Attempt to convert to number the column value, otherwise proceed as string
  BEGIN
    x := to_number(p_colv);
    y := to_number(p_val);
  EXCEPTION WHEN OTHERS THEN
    n := false;
  END;
  -- Compare
  IF p_oper = '=' THEN
    IF n THEN
      return x = y;
    ELSE
      return p_val = p_colv;
    END IF;
  ELSIF p_oper = '>' THEN
    IF n THEN
      return x > y;
    ELSE
      return p_colv > p_val;
    END IF;
  ELSIF p_oper = '<' THEN
    IF n THEN
      return x < y;
    ELSE
      return p_colv < p_val;
    END IF;
  ELSIF p_oper = '<=' THEN
    IF n THEN
      return x <= y;
    ELSE
      return p_colv <= p_val;
    END IF;
  ELSIF p_oper = '>=' THEN
    IF n THEN
      return x >= y;
    ELSE
      return p_colv >= p_val;
    END IF;
  ELSIF p_oper = '!=' OR p_oper = '<>' THEN
    IF n THEN
      return x != y;
    ELSE
      return p_colv != p_val;
    END IF;
  END IF;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in evaluate_rowcol');
  raise;
END evaluate_rowcol;
---------------------------------------------
-- Expand [note] or {patch} tokens         --
---------------------------------------------
FUNCTION expand_links(p_str VARCHAR2) return VARCHAR2 IS
  l_str VARCHAR2(32767);
Begin
  -- Assign to working variable
  l_str := p_str;
  -- First deal with patches
  l_str := regexp_replace(l_str,'({)([0-9]*)(})',
    '<a target="_blank" href="'||g_mos_patch_url||'\\2">\\2</a>',1,0);
  -- Same for notes
  l_str := regexp_replace(l_str,'(\\[)([0-9]*\\.[0-9])(\\#[a-zA-Z0-9_]+)*(\\])',
    '<a target="_blank" href="'||g_mos_doc_url||'\\2\\3">Doc ID \\2</a>',1,0);
  return l_str;
END expand_links;
--------------------------------------------
-- Prepare the SQL with the substitution values
--------------------------------------------
FUNCTION prepare_text(
  p_raw_text IN VARCHAR2
  ) RETURN VARCHAR2 IS
  l_formatted_text  VARCHAR2(32767);
  l_key             VARCHAR2(255);
BEGIN
  -- Assign signature to working variable
  l_formatted_text := p_raw_text;
  --  Build the appropriate SQL replacing all applicable values
  --  with the appropriate parameters
  l_key := g_sql_tokens.first;
  WHILE l_key is not null LOOP
    l_formatted_text := replace(l_formatted_text, l_key, g_sql_tokens(l_key));
    l_key := g_sql_tokens.next(l_key);
  END LOOP;
  RETURN l_formatted_text;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in prepare_text');
  raise;
END prepare_text;
----------------------------------------------------------------
-- Set partial section result                                 --
----------------------------------------------------------------
PROCEDURE set_item_result(result varchar2) is
BEGIN
  IF g_sections(g_sections.last).result in ('U','I') THEN
          g_sections(g_sections.last).result := result;
      ELSIF g_sections(g_sections.last).result = 'S' THEN
        IF result in ('E','W') THEN
          g_sections(g_sections.last).result := result;
        END IF;  
      ELSIF g_sections(g_sections.last).result = 'W' THEN
        IF result = 'E' THEN
          g_sections(g_sections.last).result := result;
        END IF;
      END IF;
  -- Set counts
  IF result = 'S' THEN
    g_sections(g_sections.last).success_count :=
       g_sections(g_sections.last).success_count + 1;
  ELSIF result = 'W' THEN
    g_sections(g_sections.last).warn_count :=
       g_sections(g_sections.last).warn_count + 1;
  ELSIF result = 'E' THEN
    g_sections(g_sections.last).error_count :=
       g_sections(g_sections.last).error_count + 1;
  END IF;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in set_item_result: '||sqlerrm);
--CG   raise;
END set_item_result;
----------------------------------------------------------------------
-- Create associative tables that will keep the links
-- between the signatures that use hyperlinks
----------------------------------------------------------------------
PROCEDURE create_hyperlink_table IS
    TYPE l_split_str_type IS TABLE OF VARCHAR(126); 
    l_split_str          l_split_str_type := l_split_str_type();
 l_hyperlink          VARCHAR2(512);
    l_count              NUMBER;
    l_key                VARCHAR2(215);
BEGIN
    l_key := g_signatures.first;
   
    WHILE l_key IS NOT NULL LOOP
        l_count := 1;
        IF (g_signatures(l_key).extra_info.EXISTS('HYPERLINK')) AND (g_signatures(l_key).extra_info('HYPERLINK') IS NOT NULL) THEN
            l_hyperlink := g_signatures(l_key).extra_info('HYPERLINK');
            debug ('CG Hyper:' || l_hyperlink);
          -- remove the table entry as we won't need it anymore
            g_signatures(l_key).extra_info.DELETE('HYPERLINK');
   
             -- split the string and extract the hyperlink details 
            WHILE (l_count < 4) AND (l_hyperlink IS NOT NULL) LOOP
              l_split_str.extend();
              l_split_str(l_count) := regexp_substr(l_hyperlink, '^([^:]+)');    
              l_hyperlink := regexp_replace(l_hyperlink, '^([^:]+):(.+)', '\\2');
            debug ('CG Hyper7:' || l_hyperlink);
         
                l_count := l_count + 1;
            END LOOP;   
           
          IF (l_count < 3) THEN
              print_log('Broken hyperlink!');
                return;
          END IF;
                -- populate source to dest (links) table - sig and column names in upper case
                g_source_to_dest(l_key).cols(UPPER(l_split_str(1))) := 'a' || to_char(g_hypercount);
                -- populate dest to source table (anchors)
                g_dest_to_source(UPPER(l_split_str(2))).cols(UPPER(l_split_str(3))) := 'a' || to_char(g_hypercount);
                g_hypercount := g_hypercount + 1;
        END IF; 
    l_key := g_signatures.next(l_key);
    END LOOP;
EXCEPTION WHEN OTHERS THEN
    print_log('Error in create_hyperlink_table: '||sqlerrm); 
END create_hyperlink_table;

----------------------------------------------------------------------
-- Runs a single SQL using DBMS_SQL returns filled tables
-- Precursor to future run_signature which will call this and
-- the print api. For now calls are manual.
----------------------------------------------------------------------
PROCEDURE run_sig_sql(
   p_raw_sql      IN  VARCHAR2,     -- SQL in the signature may require substitution
   p_col_rows     OUT COL_LIST_TBL, -- signature SQL column names
   p_col_headings OUT VARCHAR_TBL, -- signature SQL row values
   p_limit_rows   IN  VARCHAR2 DEFAULT 'Y') IS
  l_sql            VARCHAR2(32767);
  c                INTEGER;
  l_rows_fetched   NUMBER;
  l_step           VARCHAR2(20);
  l_col_rows       COL_LIST_TBL := col_list_tbl();
  l_col_headings   VARCHAR_TBL := varchar_tbl();
  l_col_cnt        INTEGER;
  l_desc_rec_tbl   DBMS_SQL.DESC_TAB2;
BEGIN
  -- Prepare the Signature SQL
  l_step := '10';
  l_sql := prepare_text(p_raw_sql);
  -- Add SQL with substitution to attributes table
  l_step := '20';
  c := dbms_sql.open_cursor;
  l_step := '30';
  DBMS_SQL.PARSE(c, l_sql, DBMS_SQL.NATIVE);
  -- Get column count and descriptions
  l_step := '40';
  DBMS_SQL.DESCRIBE_COLUMNS2(c, l_col_cnt, l_desc_rec_tbl);
  -- Register arrays to bulk collect results and set headings
  l_step := '50';
  FOR i IN 1..l_col_cnt LOOP
    l_step := '50.1.'||to_char(i);
    l_col_headings.extend();
 -- removed initCap per Standardization team in 3.0.34
    l_col_headings(i) := replace(l_desc_rec_tbl(i).col_name,'|','<br>');
    l_col_rows.extend();
    dbms_sql.define_array(c, i, l_col_rows(i), g_max_output_rows, 1);
  END LOOP;
  -- Execute and Fetch
  l_step := '60';
  get_current_time(g_query_start_time);
  l_rows_fetched := DBMS_SQL.EXECUTE(c);
  l_rows_fetched := DBMS_SQL.FETCH_ROWS(c);
  debug(' Rows fetched: '||to_char(l_rows_fetched));
  l_step := '70';
  IF l_rows_fetched > 0 THEN
    FOR i in 1..l_col_cnt LOOP
      l_step := '70.1.'||to_char(i);
      DBMS_SQL.COLUMN_VALUE(c, i, l_col_rows(i));
    END LOOP;
  END IF;
  IF nvl(p_limit_rows,'Y') = 'N' THEN
    WHILE l_rows_fetched = g_max_output_rows LOOP
      l_rows_fetched := DBMS_SQL.FETCH_ROWS(c);
      debug(' Rows fetched: '||to_char(l_rows_fetched));
      FOR i in 1..l_col_cnt LOOP
        l_step := '70.2.'||to_char(i);
        DBMS_SQL.COLUMN_VALUE(c, i, l_col_rows(i));
      END LOOP;
    END LOOP;
  END IF;
  g_query_elapsed := stop_timer(g_query_start_time);
--  g_query_total := g_query_total + g_query_elapsed;
  -- Close cursor
  l_step := '80';
  IF dbms_sql.is_open(c) THEN
    dbms_sql.close_cursor(c);
  END IF;
  -- Set out parameters
  p_col_headings := l_col_headings;
  p_col_rows := l_col_rows;
EXCEPTION
  WHEN OTHERS THEN
    print_error('PROGRAM ERROR<br />
      Error in run_sig_sql at step '||
      l_step||': '||sqlerrm||'<br/>
      See the log file for additional details<br/>');
    print_log('Error at step '||l_step||' in run_sig_sql running: '||l_sql);
    print_log('Error: '||sqlerrm);
    l_col_cnt := -1;
    IF dbms_sql.is_open(c) THEN
      dbms_sql.close_cursor(c);
    END IF;
    g_errbuf := 'toto '||l_step;
END run_sig_sql;
PROCEDURE generate_hidden_xml(
  p_sig_id          VARCHAR2,
  p_sig             SIGNATURE_REC, -- Name of signature item
  p_col_rows        COL_LIST_TBL,  -- signature SQL row values
  p_col_headings    VARCHAR_TBL)    -- signature SQL column names      
IS
l_hidden_xml_doc       XMLDOM.DOMDocument;
l_hidden_xml_node      XMLDOM.DOMNode;
l_diagnostic_element   XMLDOM.DOMElement;
l_diagnostic_node      XMLDOM.DOMNode;
l_issues_node          XMLDOM.DOMNode;
l_signature_node       XMLDOM.DOMNode;
l_signature_element    XMLDOM.DOMElement;
l_node                 XMLDOM.DOMNode;
l_row_node             XMLDOM.DOMNode;
l_failure_node         XMLDOM.DOMNode;
l_run_details_node     XMLDOM.DOMNode;
l_run_detail_data_node XMLDOM.DOMNode;
l_detail_element       XMLDOM.DOMElement;
l_detail_node          XMLDOM.DOMNode;
l_detail_name_attribute XMLDOM.DOMAttr;
l_parameters_node      XMLDOM.DOMNode;
l_parameter_node       XMLDOM.DOMNode;
l_col_node             XMLDOM.DOMNode;
l_parameter_element    XMLDOM.DOMElement;
l_col_element          XMLDOM.DOMElement;
l_param_name_attribute XMLDOM.DOMAttr;
l_failure_element      XMLDOM.DOMElement;
l_sig_id_attribute     XMLDOM.DOMAttr;
l_col_name_attribute   XMLDOM.DOMAttr;
l_row_attribute        XMLDOM.DOMAttr;
l_sigxinfo_element     XMLDOM.DOMElement;
l_sigxinfo_node        XMLDOM.DOMNode;
l_xinfo_element        XMLDOM.DOMElement;
l_xinfo_node           XMLDOM.DOMNode;
l_xinfo_name_attr      XMLDOM.DOMAttr;
l_key                  VARCHAR2(255);
l_match                VARCHAR2(1);
l_rows                 NUMBER;
l_value                VARCHAR2(2000);

BEGIN
IF g_dx_summary_error IS NOT NULL THEN
   return;
END IF;  
l_hidden_xml_doc := g_hidden_xml;
IF (XMLDOM.isNULL(l_hidden_xml_doc)) THEN
   l_hidden_xml_doc := XMLDOM.newDOMDocument;
   l_hidden_xml_node := XMLDOM.makeNode(l_hidden_xml_doc);
   l_diagnostic_node := XMLDOM.appendChild(l_hidden_xml_node,XMLDOM.makeNode(XMLDOM.createElement(l_hidden_xml_doc,'diagnostic')));
   l_run_details_node := XMLDOM.appendChild(l_diagnostic_node,XMLDOM.makeNode(XMLDOM.createElement(l_hidden_xml_doc,'run_details')));  
   l_key := g_rep_info.first;
   WHILE l_key IS NOT NULL LOOP
  
     l_detail_element := XMLDOM.createElement(l_hidden_xml_doc,'detail');
     l_detail_node := XMLDOM.appendChild(l_run_details_node,XMLDOM.makeNode(l_detail_element));
     l_detail_name_attribute:=XMLDOM.setAttributeNode(l_detail_element,XMLDOM.createAttribute(l_hidden_xml_doc,'name'));
     XMLDOM.setAttribute(l_detail_element, 'name', l_key);
     IF g_rep_info(l_key) IS NOT NULL THEN
        l_node := XMLDOM.appendChild(l_detail_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,g_rep_info(l_key))));
     END IF;  
     l_key := g_rep_info.next(l_key);
   END LOOP;
   -- add cloud check
   l_detail_element := XMLDOM.createElement(l_hidden_xml_doc,'detail');
   l_detail_node := XMLDOM.appendChild(l_run_details_node,XMLDOM.makeNode(l_detail_element));
   l_detail_name_attribute:=XMLDOM.setAttributeNode(l_detail_element,XMLDOM.createAttribute(l_hidden_xml_doc,'name'));
   XMLDOM.setAttribute(l_detail_element, 'name', 'Cloud');
   IF g_cloud_flag THEN
      l_node := XMLDOM.appendChild(l_detail_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,'Y')));
   ELSE  
      l_node := XMLDOM.appendChild(l_detail_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,'N')));
   END IF;  
  
   l_parameters_node := XMLDOM.appendChild(l_diagnostic_node,XMLDOM.makeNode(XMLDOM.createElement(l_hidden_xml_doc,'parameters')));
   FOR i IN 1..g_parameters.COUNT LOOP
     l_parameter_element := XMLDOM.createElement(l_hidden_xml_doc,'parameter');
     l_parameter_node := XMLDOM.appendChild(l_parameters_node,XMLDOM.makeNode(l_parameter_element));
     l_param_name_attribute:=XMLDOM.setAttributeNode(l_parameter_element,XMLDOM.createAttribute(l_hidden_xml_doc,'name'));
     XMLDOM.setAttribute(l_parameter_element, 'name', to_char(i) || '. ' ||g_parameters(i).pname);
                        
     IF g_parameters(i).pvalue IS NOT NULL THEN
        l_node := XMLDOM.appendChild(l_parameter_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,g_parameters(i).pvalue)));
     END IF;
   END LOOP;
  
   l_issues_node := XMLDOM.appendChild(l_diagnostic_node,XMLDOM.makeNode(XMLDOM.createElement(l_hidden_xml_doc,'issues')));  
END IF;

 IF p_sig_id IS NOT NULL THEN
   l_issues_node := XMLDOM.getLastChild(XMLDOM.getFirstChild(XMLDOM.makeNode(l_hidden_xml_doc)));
   l_signature_element := XMLDOM.createElement(l_hidden_xml_doc,'signature');
   l_sig_id_attribute := XMLDOM.setAttributeNode(l_signature_element,XMLDOM.createAttribute(l_hidden_xml_doc,'id'));
   l_signature_node := XMLDOM.appendChild(l_issues_node,XMLDOM.makeNode(l_signature_element));
   XMLDOM.setAttribute(l_signature_element, 'id',p_sig_id);
   IF p_sig.extra_info.count > 0 THEN
      l_sigxinfo_element := XMLDOM.createElement(l_hidden_xml_doc,'sigxinfo');     
      l_sigxinfo_node := XMLDOM.appendChild(l_signature_node,XMLDOM.makeNode(l_sigxinfo_element));     
      l_key := p_sig.extra_info.first;
      WHILE l_key IS NOT NULL LOOP
         l_xinfo_element := XMLDOM.createElement(l_hidden_xml_doc,'info');     
         l_xinfo_node := XMLDOM.appendChild(l_sigxinfo_node,XMLDOM.makeNode(l_xinfo_element));     
         l_xinfo_name_attr := XMLDOM.setAttributeNode(l_xinfo_element,XMLDOM.createAttribute(l_hidden_xml_doc,'name'));
         XMLDOM.setAttribute(l_xinfo_element, 'name',l_key);
         IF p_sig.extra_info(l_key) IS NOT NULL THEN
            l_node := XMLDOM.appendChild(l_xinfo_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,p_sig.extra_info(l_key))));        
         END IF;
         l_key := p_sig.extra_info.next(l_key);
      END LOOP;
   END IF;
  
   -- if the DX flag is Y or D, print all the details
   IF (p_sig.include_in_xml in ('Y', 'D')) THEN
      IF p_sig.limit_rows='Y' THEN
         l_rows := least(g_max_output_rows,p_col_rows(1).COUNT,50);
      ELSE
         l_rows := least(p_col_rows(1).COUNT,50);
      END IF;
    
      FOR i IN 1..l_rows LOOP
         l_failure_element := XMLDOM.createElement(l_hidden_xml_doc,'failure');
         l_row_attribute := XMLDOM.setAttributeNode(l_failure_element,XMLDOM.createAttribute(l_hidden_xml_doc,'row'));    
         l_failure_node := XMLDOM.appendChild(l_signature_node,XMLDOM.makeNode(l_failure_element));
         XMLDOM.setAttribute(l_failure_element, 'row', i);  
   
         FOR j IN 1..p_col_headings.count LOOP
   
            l_col_element := XMLDOM.createElement(l_hidden_xml_doc,'column');
            l_col_name_attribute := XMLDOM.setAttributeNode(l_col_element,XMLDOM.createAttribute(l_hidden_xml_doc,'name'));
            l_col_node := XMLDOM.appendChild(l_failure_node,XMLDOM.makeNode(l_col_element));
            XMLDOM.setAttribute(l_col_element, 'name',p_col_headings(j));

            l_value := p_col_rows(j)(i);
            IF p_sig_id = 'REC_PATCH_CHECK' THEN
               IF p_col_headings(j) = 'Patch' THEN
                  l_value := replace(replace(p_col_rows(j)(i),'{'),'}');
               ELSIF p_col_headings(j) = 'Note' THEN
                  l_value := replace(replace(p_col_rows(j)(i),'['),']');
               END IF;
            END IF;
  
      -- Rtrim the column value if blanks are not to be preserved
            IF NOT g_preserve_trailing_blanks THEN
               l_value := RTRIM(l_value, ' ');
            END IF;
            IF l_value IS NOT NULL THEN
               l_node := XMLDOM.appendChild(l_col_node,XMLDOM.makeNode(XMLDOM.createTextNode(l_hidden_xml_doc,l_value)));
            END IF;
          END LOOP;
       END LOOP;
    
     END IF;  --p_sig.include_in_xml='Y'
   
  END IF; 
  g_hidden_xml := l_hidden_xml_doc;
 
EXCEPTION
   WHEN OTHERS THEN  
      g_dx_summary_error := '<DXSUMMGENERR><![CDATA['||SQLERRM||']]></DXSUMMGENERR>';
      print_log('DX Summary generation error: '||SQLERRM);
END generate_hidden_xml;

PROCEDURE print_hidden_xml
IS
l_hidden_xml_clob      clob;
l_offset               NUMBER := 1;
l_length               NUMBER;
l_node_list            XMLDOM.DOMNodeList;
l_node_length          NUMBER;
BEGIN
IF g_dx_summary_error IS NOT NULL THEN
   print_out('<!-- ######BEGIN DX SUMMARY######','Y');
   print_out(g_dx_summary_error);
   print_out('######END DX SUMMARY######-->','Y');
   g_dx_summary_error:=null;
   return;
END IF;  
  
IF XMLDOM.isNULL(g_hidden_xml) THEN
   generate_hidden_xml(p_sig_id => null,
                       p_sig => null,
                       p_col_headings => null,
                       p_col_rows => null);
                      
END IF;                     
dbms_lob.createtemporary(l_hidden_xml_clob, true);
--print CLOB
XMLDOM.WRITETOCLOB(g_hidden_xml, l_hidden_xml_clob);
print_out('<!-- ######BEGIN DX SUMMARY######','Y');
LOOP
   EXIT WHEN (l_offset > dbms_lob.getlength(l_hidden_xml_clob) OR dbms_lob.getlength(l_hidden_xml_clob)=0);
  
      print_out(dbms_lob.substr(l_hidden_xml_clob,2000, l_offset),'N');
      l_offset := l_offset + 2000;
     
   END LOOP;
  
print_out('######END DX SUMMARY######-->','Y');  --should be a newline here
dbms_lob.freeTemporary(l_hidden_xml_clob);     
XMLDOM.FREEDOCUMENT(g_hidden_xml);
EXCEPTION
   WHEN OTHERS THEN  
      print_log('Error in print_hidden_xml: '||SQLERRM);
END print_hidden_xml;
----------------------------------------------------------------
-- Once a signature has been run, evaluates and prints it     --
----------------------------------------------------------------
FUNCTION process_signature_results(
  p_sig_id          VARCHAR2,      -- signature id
  p_sig             SIGNATURE_REC, -- Name of signature item
  p_col_rows        COL_LIST_TBL,  -- signature SQL row values
  p_col_headings    VARCHAR_TBL,    -- signature SQL column names
  p_parent_id       VARCHAR2    DEFAULT NULL,
  p_sig_suffix      VARCHAR2    DEFAULT NULL,
  p_class_string    VARCHAR2    DEFAULT NULL
  ) RETURN VARCHAR2 IS             -- returns 'E','W','S','I'
  l_sig_fail      BOOLEAN := false;
  l_row_fail      BOOLEAN := false;
  l_fail_flag     BOOLEAN := false;
  l_html          VARCHAR2(32767) := null;
  l_column        VARCHAR2(255) := null;
  l_operand       VARCHAR2(3);
  l_value         VARCHAR2(4000);
  l_step          VARCHAR2(255);
  l_i             VARCHAR2(255);
  l_curr_col      VARCHAR2(255) := NULL;
  l_curr_val      VARCHAR2(4000) := NULL;
  l_print_sql_out BOOLEAN := true;
  l_inv_param     EXCEPTION;
  l_rows_fetched  NUMBER := p_col_rows(1).count;
  l_printing_cols NUMBER := 0;
  l_error_type    VARCHAR2(1);
  l_current_section  VARCHAR2(320);
  l_current_sig      VARCHAR2(320);
  l_sig_suffix       VARCHAR2(100);
  l_class_string     VARCHAR2(1024);
BEGIN
  -- Validate parameters which have fixed values against errors when
  -- defining or loading signatures
  l_current_section := replace_chars(g_sec_detail(g_sec_detail.COUNT).name);
    g_sig_count := g_sig_count + 1;
 l_current_sig := 'S'||to_char(g_sig_count);  --build signature class name
 
  -- if p_sig_suffix is not null, then this ia a child signature and we should append the id with the parent row count, so it will be unique
  IF (p_sig_suffix IS NOT NULL) THEN
      l_current_sig := l_current_sig || to_char(p_sig_suffix);
  END IF;     
 
  IF (p_sig.fail_condition NOT IN ('RSGT1','RS','NRS')) AND
     ((instr(p_sig.fail_condition,'[') = 0) OR
      (instr(p_sig.fail_condition,'[',1,2) = 0) OR
      (instr(p_sig.fail_condition,']') = 0) OR
      (instr(p_sig.fail_condition,']',1,2) = 0))  THEN
    print_log('Invalid value or format for failure condition: '||
      p_sig.fail_condition);
    raise l_inv_param;
  ELSIF p_sig.print_condition NOT IN ('SUCCESS','FAILURE','ALWAYS','NEVER') THEN
    print_log('Invalid value for print_condition: '||p_sig.print_condition);
    raise l_inv_param;
  ELSIF p_sig.fail_type NOT IN ('E','W','I') THEN
    print_log('Invalid value for fail_type: '||p_sig.fail_type);
    raise l_inv_param;
  ELSIF p_sig.print_sql_output NOT IN ('Y','N','RS') THEN
    print_log('Invalid value for print_sql_output: '||p_sig.print_sql_output);
    raise l_inv_param;
  ELSIF p_sig.limit_rows NOT IN ('Y','N') THEN
    print_log('Invalid value for limit_rows: '||p_sig.limit_rows);
    raise l_inv_param;
  ELSIF p_sig.print_condition in ('ALWAYS','SUCCESS') AND
        p_sig.success_msg is null AND p_sig.print_sql_output = 'N' THEN
    print_log('Invalid parameter combination.');
    print_log('print_condition/success_msg/print_sql_output: '||
      p_sig.print_condition||'/'||nvl(p_sig.success_msg,'null')||
      '/'||p_sig.print_sql_output);
    print_log('When printing on success either success msg or SQL output '||
        'printing should be enabled.');
    raise l_inv_param;
  END IF;
  l_print_sql_out := (nvl(p_sig.print_sql_output,'Y') = 'Y' OR
      (p_sig.print_sql_output = 'RSGT1' AND l_rows_fetched > 1) OR
                     (p_sig.print_sql_output = 'RS' AND l_rows_fetched > 0) OR
                      p_sig.child_sigs.count > 0 AND l_rows_fetched > 0);
  -- Determine signature failure status
  IF p_sig.fail_condition NOT IN ('RSGT1','RS','NRS') THEN
    -- Get the column to evaluate, if any
    l_step := '20';
    l_column := upper(substr(ltrim(p_sig.fail_condition),2,instr(p_sig.fail_condition,']') - 2));
    l_operand := rtrim(ltrim(substr(p_sig.fail_condition, instr(p_sig.fail_condition,']')+1,
      (instr(p_sig.fail_condition,'[',1,2)-instr(p_sig.fail_condition,']') - 1))));
    l_value := substr(p_sig.fail_condition, instr(p_sig.fail_condition,'[',2)+1,
      (instr(p_sig.fail_condition,']',1,2)-instr(p_sig.fail_condition,'[',1,2)-1));
    l_step := '30';
    FOR i IN 1..least(l_rows_fetched, g_max_output_rows) LOOP
      l_step := '40';
      FOR j IN 1..p_col_headings.count LOOP
        l_step := '40.1.'||to_char(j);
        l_row_fail := false;
        l_curr_col := upper(p_col_headings(j));
        l_curr_val := p_col_rows(j)(i);
        IF nvl(l_column,'&&&') = l_curr_col THEN
          l_step := '40.2.'||to_char(j);
          l_row_fail := evaluate_rowcol(l_operand, l_value, l_curr_val);
          IF l_row_fail THEN
            l_fail_flag := true;
          END IF;
        END IF;
      END LOOP;
    END LOOP;
  END IF;
  -- Evaluate this signature
  l_step := '50';
  l_sig_fail := l_fail_flag OR
    (p_sig.fail_condition = 'RSGT1' AND l_rows_fetched > 1) OR
                (p_sig.fail_condition = 'RS' AND l_rows_fetched > 0) OR
                (p_sig.fail_condition = 'NRS' and l_rows_fetched = 0);
  l_step := '55';
  IF (l_sig_fail OR p_sig.fail_type = 'I') THEN
     generate_hidden_xml(p_sig_id => p_sig_id,
                         p_sig => p_sig,
                         p_col_headings => p_col_headings,
                         p_col_rows => p_col_rows);
  END IF;
  -- If success and no print just return
  l_step := '60';
  IF ((NOT l_sig_fail) AND p_sig.print_condition IN ('FAILURE','NEVER')) THEN
    IF p_sig.fail_type = 'I' THEN
      return 'I';
    ELSE
      return 'S';
    END IF;
  ELSIF (l_sig_fail AND (p_sig.print_condition IN ('SUCCESS','NEVER'))) THEN
    return p_sig.fail_type;
-- if the sig is set as "Print in DX only" then return   
  ELSIF (p_sig.include_in_xml = 'D') THEN
    return p_sig.fail_type; 
  END IF;

  -- if p_parent_id is null, this is not a child sig (it's a first level signature)
  IF (p_parent_id IS NULL) THEN   
     g_level := 1;
     g_family_result := '';
  -- populate the signature result to the global hash
     l_step := 'Populate result in the structure';
     g_sec_detail(g_sec_detail.LAST).sigs.extend();    
     g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_id := l_current_sig;
     g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_name := p_sig_id;
  g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result := p_sig.fail_type;
  IF (NOT l_sig_fail AND (p_sig.fail_type != 'I')) THEN
           g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result := 'S';
     END IF;
   ELSE
     g_level := g_level + 1;  
   END IF;
   -- Print container and title
  l_html := '
<!-- '||l_current_sig||' -->
               <div class="data sigcontainer signature '||l_current_section||' '||l_current_sig||' '|| p_class_string || ' ' || g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result ||' section print analysis" level="'||to_char(g_level)||'"  id="'||l_current_sig||'" style="display: none;">
                    <div class="divItemTitle">
                        <input type="checkbox" rowid="'||l_current_sig||'" class="exportcheck data print">';
   l_html := l_html || '
                        <a class="detail" toggle-data="restable_'||l_current_sig||'">
                           <div class="arrowright data section fullsection print analysis">&#9654;</div><div class="arrowdown data" style="display: none">&#9660;</div>
                           <div class="sigdescription" style="display:inline;"><table style="display:inline;"><tr class="'||l_current_section||' '||l_current_sig||' '||g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result ||' sigtitle"><td class="divItemTitlet">'||prepare_text(p_sig.title)||'</td></tr></table></div>
                        </a>';
 -- CG Review this condition    
 IF p_sig.extra_info.count > 0 OR p_sig.sig_sql is not null THEN    
        l_html := l_html || '
                        <a class="detailsmall" toggle-info="tbitm_'||l_current_sig||'"><span class="siginfo_ico" title="Show signature information" alt="Show Info"></span></a>';
 END IF;
    l_html := l_html || '
                        <a class="detailsmall" href="javascript:;" onclick=''export2PaddedText("'||l_current_sig||'");return false;''><span class="export_txt_ico" title="Export to .txt" alt="Export to .txt"></span></a>
                        <a class="detailsmall" href="javascript:;" onclick=''export2CSV("'||l_current_sig||'")''><span class="export_ico" title="Export to .csv" alt="Export to .csv"></span></a>';
    -- add sort icon for non-parents sigs and only when more than 1 record is retrieved (it doesn't make any sense to sort a single record)
    IF ((p_sig.child_sigs.count = 0) AND (l_rows_fetched > 1) AND (l_print_sql_out)) THEN
        l_html := l_html || '
                        <a class="detailsmall"><span class="sort_ico" table-name='||l_current_sig||' title="Sort table" alt="Sort table"></span></a>';    
    END IF;
    l_html := l_html || '
                    </div>';
                   
  -- Print collapsable/expandable extra info table if there are contents
  l_step := '80';
  IF p_sig.extra_info.count > 0 OR p_sig.sig_sql is not null THEN
    g_item_id := g_item_id + 1;
    l_step := '90';
  
    l_html := l_html || '
                    <table class="table1 data" id="tbitm_' || l_current_sig || '" style="display:none">
                    <thead>
                       <tr><th bgcolor="#f2f4f7" class="sigdetails">Item Name</th><th bgcolor="#f2f4f7" class="sigdetails">Item Value</th></tr>
                    </thead>
                    <tbody>';
    -- Loop and print values
    l_step := '110';
    l_i := p_sig.extra_info.FIRST;
    WHILE (l_i IS NOT NULL) LOOP
      l_step := '110.1.'||l_i;
      -- don't print the SHOW_SQL parameter
   IF (l_i != 'SHOW_SQL') THEN
          l_html := l_html || '                           <tr><td>' || l_i || '</td><td>'||
             p_sig.extra_info(l_i) || '</td></tr>';
   END IF;  
      l_step := '110.2.'||l_i;
      l_i := p_sig.extra_info.next(l_i);
    END LOOP;
    -- print SQL only if SHOW_SQL != 'N' and the SQL string is not null
    IF ((p_sig.sig_sql is not null) AND ((NOT p_sig.extra_info.EXISTS('SHOW_SQL')) OR (p_sig.extra_info.EXISTS('SHOW_SQL')) AND (nvl(p_sig.extra_info('SHOW_SQL'), 'Y') != 'N'))) THEN
      l_step := '120';
      l_html := l_html || '
                        <tr><td>SQL</td><td><pre>'|| prepare_text(escape_html_chars(p_sig.sig_sql)) ||
         '</pre></td></tr>';
    END IF;
   
    -- number of records retrieved and elapsed time
    l_html := l_html ||'<tr><td>Number of rows:</td><td>';
      IF p_sig.limit_rows = 'N' OR l_rows_fetched < g_max_output_rows THEN
        l_html := l_html || l_rows_fetched || ' rows selected';
      ELSE
        l_html := l_html ||'Displaying first '||to_char(g_max_output_rows) || ' out of ' || l_rows_fetched || ' rows retrieved.';
      END IF;
      l_html := l_html ||'</td></tr><tr><td>';
      l_html := l_html ||'Elapsed time:</td><td>' || format_elapsed(g_query_elapsed) || '</td></tr>';
      l_html := l_html || '
                    </tbody>
                    </table>';
  END IF;
  l_step := '140';
  -- Print the header SQL info table
  print_out(expand_links(l_html));
  l_html := null;
  IF l_print_sql_out THEN
    IF p_sig.child_sigs.count = 0 THEN        -- Signature has no children
      -- Print the actual results table
      -- Table header
      l_step := '150';
                
      l_html := '
                    <!-- table that includes the SQL results (data) -->
                    <div class="divtable">';
      l_html := l_html || '
                    <table class="table1 data tabledata" id="restable_'||l_current_sig||'" style="display:none">
                    <thead>';
      -- Column headings
      l_html := l_html || '
                        <tr class="'||l_current_section||' '||l_current_sig||' '||g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result ||'">';
      print_out(l_html);
      l_html := '';
      l_step := '160';
      FOR i IN 1..p_col_headings.count LOOP
     IF upper(nvl(p_col_headings(i),'XXX')) not like '##$$FK_$$##' THEN
           -- Encode blanks as HTML space if this analyzer is set so by g_preserve_trailing_blanks
           -- this ensures trailing blanks added for padding are honored by browsers
           -- affects only printing, DX summary handled separately
            IF g_preserve_trailing_blanks THEN
              l_html := l_html ||'
                                <th bgcolor="#f2f4f7" class="sigdetails">'||RPAD(RTRIM(p_col_headings(i),' '),
           -- pad length is the number of spaces existing times the length of &nbsp; => 6
            (length(p_col_headings(i)) - length(RTRIM(p_col_headings(i),' '))) * 6
            + length(RTRIM(p_col_headings(i),' ')),'&nbsp;') ||'</th>';
            ELSE
              l_html := l_html || '
                                <th bgcolor="#f2f4f7" class="sigdetails">'||nvl(p_col_headings(i),'&nbsp;')||'</th>';
            END IF;    
             -- if the html buffer is already larger than the limit, spool the content and reset
             IF (LENGTH(l_html) > 32000) THEN
                 print_out(expand_links(l_html));
                 l_html := '';
             END IF;         
       END IF;  
      END LOOP;
      l_html := l_html || '
                        </tr>
                    </thead>
                    <tbody>';
      -- Print headers
      print_out(expand_links(l_html));
      -- Row values
      l_step := '170';
      FOR i IN 1..l_rows_fetched LOOP
        l_html := '                        <tr class="tdata '||l_current_section||' '||l_current_sig||' '||g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result ||'">'; 
        l_step := '170.1.'||to_char(i);
        FOR j IN 1..p_col_headings.count LOOP
          -- Evaluate if necessary
          l_step := '170.2.'||to_char(j);
          l_row_fail := false;
          l_step := '170.3.'||to_char(j);
          l_curr_col := upper(p_col_headings(j));
          l_step := '170.4.'||to_char(j);
          l_curr_val := p_col_rows(j)(i);
          l_step := '170.5.'||to_char(j);
          IF nvl(l_column,'&&&') = l_curr_col THEN
            l_step := '170.6.'||
              substr('['||l_operand||']['||l_value||']['||l_curr_val||']',1,96);
            l_row_fail := evaluate_rowcol(l_operand, l_value, l_curr_val);
          END IF;
         
          -- Encode blanks as HTML space if this analyzer is set so by g_preserve_trailing_blanks
          -- this ensures trailing blanks added for padding are honored by browsers
          -- affects only printing, DX summary handled separately
          IF g_preserve_trailing_blanks THEN
            l_curr_Val := RPAD(RTRIM(l_curr_Val,' '),
             -- pad length is the number of spaces existing times the length of &nbsp; => 6
            (length(l_curr_Val) - length(RTRIM(l_curr_Val,' '))) * 6 + length(RTRIM(l_curr_Val,' ')),
            '&nbsp;');
          ELSE
            l_curr_Val := RTRIM(l_curr_Val, ' ');
          END IF;
      
          -- Print
          l_step := '170.7.'||to_char(j);
    IF upper(nvl(p_col_headings(j),'XXX')) not like '##$$FK_$$##' THEN
             DECLARE
                l_cell_text VARCHAR2(1024) := '';   
             BEGIN            
            
                  IF (g_dest_to_source.EXISTS(p_sig_id)) AND (g_dest_to_source(p_sig_id).cols.EXISTS(l_curr_col)) AND (g_dest_to_source(p_sig_id).cols(l_curr_col) IS NOT NULL) THEN
                        l_cell_text := '<a class="anchor" id="'|| g_dest_to_source(p_sig_id).cols(l_curr_col)||'_'||to_char(l_curr_val)|| '">' || l_curr_val || '</a>';
                  ELSIF (g_source_to_dest.EXISTS(p_sig_id)) AND (g_source_to_dest(p_sig_id).cols.EXISTS(l_curr_col)) AND (g_source_to_dest(p_sig_id).cols(l_curr_col) IS NOT NULL) THEN
                        l_cell_text := '<a href="" siglink="'|| g_source_to_dest(p_sig_id).cols(l_curr_col)||'_'||to_char(l_curr_val)|| '">' || l_curr_val || '</a>';
                        l_cell_text := l_cell_text || '<span class="brokenlink" style="display:none;" title="This record does no have a parent"></span>';
                  ELSE
                        l_cell_text := l_curr_val;      
                  END IF; 
                  IF l_row_fail THEN
                    l_html := l_html || '
                                   <td class="hlt sigdetails">'|| l_cell_text || '</td>';
                  ELSE
                    l_html := l_html || '
                                   <td class="sigdetails">'|| l_cell_text || '</td>';
                  END IF;                
             EXCEPTION WHEN OTHERS THEN
                  print_log('Error when populating table data for signature: ' || p_sig_id);
             END;  
          END IF;         
        -- if the html buffer is already larger than the limit, spool the content and reset       
        IF (LENGTH(l_html) > 32000) THEN
            print_out(expand_links(l_html));
            l_html := '';
        END IF;  
        END LOOP;
        l_html := l_html || '
                        </tr>';
        print_out(expand_links(l_html));
      END LOOP;
      -- End of results and footer
      l_step := '180';
      l_html :=  '
                    </tbody>
                    </table>
                    </div>  <!-- end table data -->';
      l_step := '190';     
      print_out(l_html);
--
    ELSE -- there are children signatures
      -- Print master rows and call appropriate processes for the children
      -- Table header
      l_html := '
                    <!-- table that includes the SQL results (data) -->
                    <div class="divtable">';
      l_html := l_html || '
                    <table class="table1 data tabledata" id="restable_'||l_current_sig||'" style="display:none">';
                   
      -- Keep the id of the parent signature to use as anchor in the table of contents
--      g_parent_sig_id := l_current_sig;
                      
      -- Row values
      l_step := '200';
      FOR i IN 1..l_rows_fetched LOOP
        l_step := '200.1'||to_char(i);
        -- Column headings printed for each row
        l_html := l_html || '
                        <tr class="'||l_current_section||' '||l_current_sig||' '||g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result ||'">';
        FOR j IN 1..p_col_headings.count LOOP
          l_step := '200.2'||to_char(j);
          IF upper(nvl(p_col_headings(j),'XXX')) not like '##$$FK_$$##' THEN
            l_html := l_html || '
                            <th bgcolor="#f2f4f7" class="sigdetails '||l_current_sig||'">'||nvl(p_col_headings(j),'&nbsp;')||'</th>';
          END IF;
        -- if the html buffer is already larger than the limit, spool the content and reset
        IF (LENGTH(l_html) > 32000) THEN
            print_out(expand_links(l_html));
            l_html := '';
        END IF;  
        END LOOP;
        l_step := '200.3';
        l_html := l_html || '
                        </tr>';
        -- Print headers
        print_out(expand_links(l_html));
        -- Print a row
        l_html := '
                        <tr class="tdata '||l_current_section||' '||l_current_sig||' '||g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result||'">';
        l_printing_cols := 0;
        FOR j IN 1..p_col_headings.count LOOP
          l_step := '200.4'||to_char(j);
          l_curr_col := upper(p_col_headings(j));
          l_curr_val := p_col_rows(j)(i);
          -- If the col is a FK set the global replacement vals
          IF l_curr_col like '##$$FK_$$##' THEN
            l_step := '200.5';
            g_sql_tokens(l_curr_col) := l_curr_val;
          ELSE -- printable column
            l_printing_cols := l_printing_cols + 1;
            -- Evaluate if necessary
            l_row_fail := false;
            IF nvl(l_column,'&&&') = l_curr_col THEN
              l_step := '200.6'||
                substr('['||l_operand||']['||l_value||']['||l_curr_val||']',1,96);
              l_row_fail := evaluate_rowcol(l_operand, l_value, l_curr_val);
            END IF;
            -- Encode blanks as HTML space if this analyzer is set so by g_preserve_trailing_blanks
            -- this ensures trailing blanks added for padding are honored by browsers
            -- affects only printing, DX summary handled separately
            IF g_preserve_trailing_blanks THEN
              l_curr_Val := RPAD(RTRIM(l_curr_Val,' '),
               -- pad length is the number of spaces existing times the length of &nbsp; => 6
              (length(l_curr_Val) - length(RTRIM(l_curr_Val,' '))) * 6 + length(RTRIM(l_curr_Val,' ')),
              '&nbsp;');
            ELSE
              l_curr_Val := RTRIM(l_curr_Val, ' ');
            END IF;           
           
            -- Print
          DECLARE
             l_cell_text VARCHAR2(1024) := '';   
          BEGIN            
               IF (g_dest_to_source.EXISTS(p_sig_id)) AND (g_dest_to_source(p_sig_id).cols.EXISTS(l_curr_col)) AND (g_dest_to_source(p_sig_id).cols(l_curr_col) IS NOT NULL) THEN
                     l_cell_text := '<a class="anchor" id="'|| g_dest_to_source(p_sig_id).cols(l_curr_col)||'_'||to_char(l_curr_val)|| '">' || l_curr_val || '</a>';
               ELSIF (g_source_to_dest.EXISTS(p_sig_id)) AND (g_source_to_dest(p_sig_id).cols.EXISTS(l_curr_col)) AND (g_source_to_dest(p_sig_id).cols(l_curr_col) IS NOT NULL) THEN
                     l_cell_text := '<a href="" siglink="'|| g_source_to_dest(p_sig_id).cols(l_curr_col)||'_'||to_char(l_curr_val)|| '">' || l_curr_val || '</a>';
                     l_cell_text := l_cell_text || '<span class="brokenlink" style="display:none;" title="This record does no have a parent"></span>';
               ELSE
                     l_cell_text := l_curr_val;      
               END IF; 
               IF l_row_fail THEN
                 l_html := l_html || '
                                <td class="hlt sigdetails">'|| l_cell_text || '</td>';
               ELSE
                 l_html := l_html || '
                                <td class="sigdetails">'|| l_cell_text || '</td>';
               END IF;                
          EXCEPTION WHEN OTHERS THEN
               print_log('Error when populating table data for signature: ' || p_sig_id);
          END;                
          END IF;
          -- if the html buffer is already larger than the limit, spool the content and reset
          IF (LENGTH(l_html) > 32000) THEN
              print_out(expand_links(l_html));
              l_html := '';
          END IF;  
        END LOOP;
        l_html := l_html || '
                        </tr>';
        print_out(expand_links(l_html));
        l_html := null;
        FOR k IN p_sig.child_sigs.first..p_sig.child_sigs.last LOOP
          print_out('
                        <tr><td colspan="'||to_char(l_printing_cols)||'"><blockquote>');
          DECLARE
            l_col_rows  COL_LIST_TBL := col_list_tbl();
            l_col_hea   VARCHAR_TBL := varchar_tbl();
            l_child_sig SIGNATURE_REC;
            l_result    VARCHAR2(1);
          BEGIN
           l_child_sig := g_signatures(p_sig.child_sigs(k));
           print_log('Processing child signature: '||p_sig.child_sigs(k));
           run_sig_sql(l_child_sig.sig_sql, l_col_rows, l_col_hea, l_child_sig.limit_rows);
     l_class_string := p_class_string || ' ' || l_current_sig;
           l_result := process_signature_results(p_sig.child_sigs(k), l_child_sig, l_col_rows, l_col_hea, l_current_sig, p_sig_suffix || '_' || to_char(i), l_class_string);
           set_item_result(l_result);
           -- show parent signature failure based on result from child signature(s)
         IF l_result in ('W','E') THEN
             l_fail_flag := true;
           IF l_result = 'E' THEN
             l_error_type := 'E';
           ELSIF (l_result = 'W') AND ((l_error_type is NULL) OR (l_error_type != 'E')) THEN
             l_error_type := 'W';
           END IF;
           g_family_result := l_error_type;
         END IF;
          EXCEPTION WHEN OTHERS THEN
            print_log('Error processing child signature: '||p_sig.child_sigs(i));
            print_log('Error: '||sqlerrm);
--CG          raise;
            print_out('
                        </blockquote></td></tr>');
            goto end_loop;
          END;
          print_out('
                        </blockquote></td></tr>');
        <<end_loop>>
        NULL;
        END LOOP;
      END LOOP;
     
     
      --l_sig_fail := (l_sig_fail OR l_fail_flag);
      -- End of results and footer
      l_step := '210';
      l_html := l_html ||  '
                    </tbody>
                    </table>
                    </div>  <!-- end table data -->';
      print_out(l_html);
    END IF; -- master or child
  END IF; -- print output is true
  -------------------------------------
  -- Print actions for each signature
  -------------------------------------
  IF l_sig_fail THEN
    l_step := '230';
    IF p_sig.fail_type = 'E' THEN
      l_html := '                   
                    <div class="divuar results data print section fullsection">
                        <span class="divuar1">Error: </span>'||prepare_text(p_sig.problem_descr);
    ELSIF p_sig.fail_type = 'W' THEN
      l_html := '                   
                    <div class="divwarn results data print section fullsection">
                        <span class="divwarn1">Warning: </span>'||prepare_text(p_sig.problem_descr);
    ELSE
      l_html := '                   
                    <div class="divok results data print section fullsection">
                        <span class="divok1">Information: </span>'||prepare_text(p_sig.problem_descr);
    END IF;
       -----------------------------------------------------
    -- Print solution part of the action - only if passed
    -----------------------------------------------------
    l_step := '240';
    IF p_sig.solution is not null THEN
      l_html := l_html || '
                     <br><br><span class="solution">Findings and Recommendations:</span><br>
        ' || prepare_text(p_sig.solution);
    END IF;
    -- Close div here cause success div is conditional
    l_html := l_html || '
                    </div> <!-- end results div -->';
  ELSE
    l_step := '250';
    IF p_sig.success_msg is not null THEN
      IF p_sig.fail_type = 'I' THEN
        l_html := '
          <div class="divok results data print section fullsection"><div class="divok1">Information:</div>'||
          prepare_text(nvl(p_sig.success_msg, 'No instances of this problem found')) ||
          '</div> <!-- end results div -->';
      ELSE
        l_html := '
          <div class="divok results data print section fullsection"><div class="divok1"><span class="check_ico"></span> All checks passed.</div>'||
          prepare_text(nvl(p_sig.success_msg,
          'No instances of this problem found')) ||
          '</div> <!-- end results div -->';
      END IF;
    ELSE
      l_html := null;
    END IF;
  END IF;
  -- DIV for parent
 
     IF p_sig.child_sigs.count > 0 and (p_parent_id IS NULL) THEN
        IF g_family_result = 'E' THEN
           l_html := l_html || '
             <div class="divuar results data print section fullsection"><span class="divuar1">Error:</span> There was an error reported in one of the child checks. Please expand the section for more information.</div>';   
        ELSIF g_family_result = 'W' THEN
           l_html := l_html || '
             <div class="divwarn results data print section fullsection"><span class="divwarn1">Warning:</span> There was an issue reported in one of the child checks. Please expand the section for more information.</div>';   
        END IF;    
      END IF;
    -- if p_parent_id is null, this is not a child sig (it's a first level signature)
    IF (p_parent_id IS NULL)  THEN   
        IF (g_family_result = 'E' or g_family_result = 'W') THEN
            g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result := g_family_result;
        END IF;
        -- increment the global counter and the section counter for the fail_type
        DECLARE
           l_result VARCHAR2(1);
        BEGIN
           l_result := g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result;
           g_results(l_result) := g_results(l_result) + 1;    
           g_sec_detail(g_sec_detail.LAST).results(l_result) := g_sec_detail(g_sec_detail.LAST).results(l_result) + 1;   
        END;          
    END IF;
  
   -- print the result div of the sig container
 
    l_html := l_html || ' 
                  <div style="display:none" class="sigrescode '||l_current_section||' '||l_current_sig||' '|| p_class_string || ' ' || g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_result||'" level="'||to_char(g_level)||'"></div>
 ';
  
    l_html := l_html || '
                </div> <!-- end of sig container -->
<!-- '||l_current_sig||'-->';
  -- Increment the print count for the section      
  l_step := '260';
  g_sections(g_sections.last).print_count :=
       g_sections(g_sections.last).print_count + 1;
  -- Print
  l_step := '270';
  print_out(expand_links(l_html));
  
  g_level := g_level - 1;
  IF l_sig_fail THEN
    l_step := '280';
    return p_sig.fail_type;
  ELSE
    l_step := '290';
    IF p_sig.fail_type = 'I' THEN
      return 'I';
    ELSE
      return 'S';
    END IF;
  END IF;
 
 
EXCEPTION
  WHEN L_INV_PARAM THEN
    print_log('Invalid parameter error in process_signature_results at step '
      ||l_step);
    raise;
  WHEN OTHERS THEN
    print_log('Error in process_signature_results at step '||l_step);
    g_errbuf := l_step;
    raise;
END process_signature_results;

----------------------------------------------------------------
-- Start the main section                                     --
-- (where the sections and signatures reside)                 --
----------------------------------------------------------------
PROCEDURE start_main_section is
 
BEGIN
  print_out('
<!-- start body ---> 
    <div class="body background">
    <div style="min-height:75px;">
    </div> 
<!-- main data screen (showing section and signatures) -->
    <div class="maindata print analysis section fullsection">
    <div style="min-height:10px;">
    </div>
    <div class="sigcontainer background">    
    <div class="containertitle"></div>
      <table class="background" style="width:100%;border-spacing:0;border-collapse:collapse;">
        <tr>
            <td class="leftcell data section background">   <!-- Start menu on the left hand side -->
            <div class="sectionmenu background" id="sectionmenu">  
            </div>
            </td>
            <!-- Cell that includes the signature details -->
            <td class="rightcell analysis print section fullsection">
                 <div class="sigcontainer" style="padding:20px;margin:0;">
                   <div class="searchbox data analysis print section fullsection">
                       <div style="float:left"><b>Search within tables:</b></div><br>
                       <div style="float:left"><input type="text" class="search" placeholder="Enter search string and press <enter>" id="search" size="96" maxlength="96"></div><br>
                   </div><br><br>
                   <div class="expcoll data analysis print section fullsection">
                       <input type="checkbox" class="data print" id="exportAll">
                       <a class="detailsmall print data exportAllImg" href="javascript:;" onclick=''export2CSV("ALL")''><span class="export_ico" title="Export to Excel (.csv)" alt="Export to .csv"></span></a>
                       &nbsp;&nbsp;
                       <a class="detailsmall export2Txt data fullsection" id="export2TextLink" href="javascript:;" onclick=''export2PaddedText("")''><span class="export_txt_ico" title="Export to .txt" alt="Export to .txt"></span></a>
                       &nbsp;&nbsp;
                       <a href="#" class="detailsmall fullsection data print analysis" id="expandall" mode="analysis"><img src=" " alt="expand_all" title="Expand All"></a>&nbsp;
                       <a href="#" class="detailsmall collapseall data print analysis fullsection"><img src=" " alt="collapse_all" title="Collapse All"></a>
                       <div style="float:left;" id ="showhidesection" mode="show">
                          <a href="#" class="detailsmall data section sectionview" mode="show" id="showAll" open-sig-class=""><img src=" " alt="show_all" title="Show entire section"></a>
                          <a href="#" class= "detailsmall data fullsection sectionview" mode="hide" id="hideAll" open-sig-class=""><img src=" " alt="hide_all" title="Hide All"></a>
                       </div>
                   </div>
            <br><br>');
 
EXCEPTION WHEN OTHERS THEN
  print_log('Error in start_main_section: '||sqlerrm);
  raise;
END start_main_section;

PROCEDURE end_main_section IS
   l_html       VARCHAR2(32767) := '';
BEGIN
print_out('
      </div> <!-- end of inner container -->
            </td>         
        </tr>       
      </table>
    </div>  <!-- end of outer container -->
    <div style="min-height: 35;"></div>
 </div>');

--CG Populate the sectionmenu details here, because we need the signature results
    print_out('<script>');           
    FOR i IN 1 .. g_sec_detail.COUNT LOOP
        FOR j IN 1 .. g_sec_detail(i).sigs.COUNT LOOP
            -- in case of customizations, the global signatures table might not be populated correctly, so we might encounter a "no data found" exception.
            BEGIN 
                l_html := ' <div class="sectionbutton data '||replace_chars(g_sec_detail(i).name)||' '||nvl(g_sec_detail(i).sigs(j).sig_id, 'null')||' '||nvl(g_sec_detail(i).sigs(j).sig_result, 'I')||'" open-sig="'||g_sec_detail(i).sigs(j).sig_id||'"> <span class="'||g_result(nvl(g_sec_detail(i).sigs(j).sig_result, 'I'))||'_small"></span><span style="padding:5px;">'||prepare_text(g_signatures(g_sec_detail(i).sigs(j).sig_name).title)||'</span> </div>';
      EXCEPTION
                WHEN NO_DATA_FOUND THEN
                l_html := ' <div class="sectionbutton data '||replace_chars(g_sec_detail(i).name)||' '||nvl(g_sec_detail(i).sigs(j).sig_id, 'null')||' '||nvl(g_sec_detail(i).sigs(j).sig_result, 'I')||'" open-sig="'||g_sec_detail(i).sigs(j).sig_id||'"> <span class="'||g_result(nvl(g_sec_detail(i).sigs(j).sig_result, 'I'))||'_small"></span><span style="padding:5px;">' || g_sec_detail(i).sigs(j).sig_name || '</span> </div>';
    WHEN OTHERS THEN
    raise;
            END;     
         print_out('
                  $("#sectionmenu").append('''||l_html||''');');
        END LOOP;          
    END LOOP;                    
    print_out('</script>');         
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in end_main_section: '||sqlerrm);
  raise;
END end_main_section;

----------------------------------------------------------------
-- Creates a report section                                   --
-- For now it just prints html, in future it could be         --
-- smarter by having the definition of the section logic,     --
-- signatures etc....                                         --
----------------------------------------------------------------
PROCEDURE start_section(p_sect_title VARCHAR2, p_sect_name VARCHAR2 DEFAULT '') IS
  lsect section_rec;
  l_sig_array signatures_tbl := signatures_tbl();
 
BEGIN
  g_sections(g_sections.count + 1) := lsect;
 
  -- add element in the sections table
  g_sec_detail.extend();
  IF (p_sect_name != '') THEN
      g_sec_detail(g_sec_detail.LAST).name := p_sect_name;
  ELSE   
      g_sec_detail(g_sec_detail.LAST).name := p_sect_title;
  END IF;
  g_sec_detail(g_sec_detail.LAST).title := p_sect_title;
 
  g_sec_detail(g_sec_detail.LAST).sigs := l_sig_array;
  -- initialize the results hash for section
  g_sec_detail(g_sec_detail.LAST).results('E') := 0;
  g_sec_detail(g_sec_detail.LAST).results('W') := 0;
  g_sec_detail(g_sec_detail.LAST).results('S') := 0;
  g_sec_detail(g_sec_detail.LAST).results('I') := 0;
 
EXCEPTION WHEN OTHERS THEN
  print_log('Error in start_section: '||sqlerrm);
  raise;
END start_section;
PROCEDURE start_sig(p_sig_name varchar2) is

BEGIN
   g_sec_detail(g_sec_detail.LAST).sigs.extend();
   g_sec_detail(g_sec_detail.LAST).sigs(g_sec_detail(g_sec_detail.LAST).sigs.LAST).sig_name := p_sig_name;
 
EXCEPTION WHEN OTHERS THEN
  print_log('Error in start_sig: '||sqlerrm);
  raise;
END start_sig;
----------------------------------------------------------------
-- Finalizes a report section                                 --
-- Finalizes the html                                         --
----------------------------------------------------------------
-- CG to be removed from the AB
PROCEDURE end_section (
  p_success_msg IN VARCHAR2 DEFAULT 'All checks passed.') IS
 
  l_loop_count NUMBER;
 
BEGIN
  print_log ('End Section');

END end_section;

----------------------------------------------------------------
-- Creates a report sub section                               --
-- workaround for now in future normal sections should        --
-- support nesting                                            --
----------------------------------------------------------------
PROCEDURE print_rep_subsection(p_sect_title varchar2) is
BEGIN
  print_out('<div class="divSubSection"><div class="divSubSectionTitle">' ||
    p_sect_title || '</div><br>');
END print_rep_subsection;
PROCEDURE print_rep_subsection_end is
BEGIN
  print_out('</div><br>');
END print_rep_subsection_end;

-----------------------------------------------
-- Diagnostic specific functions and procedures
-----------------------------------------------
----------------------------------------------------------------
-- Creates a Temperature Gauge Graph                          --
-- Used to show how healthy the current data is               --
----------------------------------------------------------------
PROCEDURE show_data_gauge IS
begin
print_out('<div class="data sigcontainer signature CP_ENV ' ||  g_sec_detail(g_sec_detail.COUNT).name || ' I section print analysis" level="1" id="CP_ENV" style="display: none;">');
 print_out('<table border="1" name="NoteBox" cellpadding="10" bordercolor="#C1A90D" bgcolor="#FEFCEE" cellspacing="0">');
 print_out('<tbody><tr><td>');     
 if (g_reqid_cnt > g_max_vol) THEN  -- This is the critical setting which customers can adjust here
 print_out('<b>Concurrent Processing (1)Runtime Data Gauge</b><BR>');
 print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=300x150&cht=gm&chd=t:10&chl=Excessive" width="300" height="150" alt="" />');
 print_out('</td>');
  else   if (g_reqid_cnt > g_min_vol) THEN   -- This is the bad setting which customers can adjust here.
  print_out('<b>Concurrent Processing (2)Runtime Data Gauge</b><BR>');
  print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=300x150&cht=gm&chd=t:50&chl=Poor" width="300" height="150" alt="" />');
  print_out('</td>');
 
  else
  print_out('<b>Concurrent Processing (3)Runtime Data Gauge</b><BR>');
  print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=300x150&cht=gm&chd=t:90&chl=Healthy" width="300" height="150" alt="" />');
  print_out('</td>');
    
  end if;
end if;

 print_out('<td>');
 print_out(' This Runtime Data Gauge is adjustable for your site by entering your own settings for the g_reqid_cnt variable in cp_analyzer.sql:<BR>');
 print_out(' 1. Change the following for the immediate review setting (critical): ''(g_reqid_cnt > 5000)''.<br>');
 print_out(' 2. Change the following for the review required setting (bad): ''(g_reqid_cnt > 3500)''.');
 print_out('</td></tr></tbody> ');
 print_out('</table>');

 print_out('</div>');
--BILL ADD  -> replace signature id and name as needed
     g_sec_detail(g_sec_detail.COUNT).sigs.extend();    
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_id := 'CP_ENV';
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_name := 'COncurrent Processing Charts';
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_result := 'I';
--END BILL ADD
END show_data_gauge;
----------------------------------------------------------------
-- Creates a Bar Chart for WF Runtime Data &                  --
-- a Gauge Graphic to indicate the amount of OLD data found   --
----------------------------------------------------------------
PROCEDURE show_gauge_chart IS
 clsd_index number;
 open_index number;
 year_index number;
 emesg       VARCHAR2(250);

begin
print_log('  Processing Procedure: show_gauge_chart');
select min(to_char(actual_start_date, 'YYYY')) into beginmin
from fnd_concurrent_requests;
select max(to_char(sysdate, 'YYYY')) into beginmax
from wf_items;
clsd_index := beginmin;
Select max(nvl(Count(request_id),0)) into maxitems
From fnd_concurrent_requests
where PHASE_CODE = 'C'
Group By To_Char(actual_start_date, 'YYYY')
order by To_Char(actual_start_date, 'YYYY');
--BILL ADD -> For a different signature id, change CP_REQS with the sig id (replace spaces by _ and : by  -)
print_out('<div class="data sigcontainer signature CP_REQS ' ||  g_sec_detail(g_sec_detail.COUNT).name || ' I section print analysis" level="1" id="CP_REQS" style="display: none;">');
print_out('    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1316/styles/kendo.common.min.css" />');
print_out('    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1316/styles/kendo.default.min.css" />');
print_out('    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1316/styles/kendo.dataviz.min.css" />');
print_out('    <link rel="stylesheet" href="http://cdn.kendostatic.com/2014.3.1316/styles/kendo.dataviz.default.min.css" />');
print_out('');
print_out('    <script src="http://cdn.kendostatic.com/2014.3.1316/js/jquery.min.js"></script>');
print_out('    <script src="http://cdn.kendostatic.com/2014.3.1316/js/kendo.all.min.js"></script>');
print_out('    <script type="text/javascript" src="http://cdnjs.cloudflare.com/ajax/libs/jquery.tablesorter/2.9.1/jquery.tablesorter.min.js"></script>');

print_out('<div id="container">');
print_out('<table border="0" cellpadding="0" cellspacing="0" width="100%">');
print_out('<tr>');
print_out('<td width="50%" align="center">');
print_out('<h3>FND_CONCURRENT_REQUESTS Runtime Data by Year</h3>');
print_out('</td>');
print_out('<td width="50%">');
print_out('<h3>Concurrent Processing Runtime Data Volume Gauge</h3>');
print_out('</td>');
print_out('</tr>');
print_out('<tr>');
print_out('<td width="50%">');
print_out('<div id="chart" style="width: 600px; height: 250px; float: left; vertical-align: top; margin: 5px 5px 5px 15px; ">');
print_out('<script>');
print_out('function createChart() {$("#chart").kendoChart({');
print_out('legend: {position: "top",visible: true},');
print_out('seriesDefaults: {type: "column",stack: true},');
print_out('series: [{name: "Closed",');
print_out('data: [');
WHILE clsd_index <= beginmax
LOOP
   BEGIN
      /* Loop thru the CLOSED items by year */
 select nvl(count(request_id),0) into cls_cnt
 from fnd_concurrent_requests
 where to_char(actual_start_date,'YYYY')=clsd_index
 --and r.phase_code = 'C'
 and actual_completion_date is not null;
      print_out(cls_cnt,'N');
     
      if (clsd_index = beginmax) then
        print_out('],','N');
      else
        print_out(',','N');
      end if;
     
      clsd_index:=clsd_index+ 1;
     
   EXCEPTION
      WHEN OTHERS
      THEN
         clsd_index:=clsd_index+ 1;
   END;
END LOOP;
print_out('color: "#4D89F9"}, {name: "Open",data: [');
open_index := beginmin;
WHILE open_index <= beginmax
LOOP
   BEGIN
      /* Loop thru the OPEN items by year */
 select nvl(count(request_id),0) into cls_cnt
 from fnd_concurrent_requests
 where to_char(actual_start_date,'YYYY')=open_index
 and actual_completion_date is null;
       print_out(cls_cnt,'N');
     
      if (open_index=beginmax) then
       exit;
      else
        print_out(',','N');
      end if;
     
      open_index:=open_index+ 1;
     
   EXCEPTION
      WHEN OTHERS
      THEN
         open_index:=open_index+ 1;
   END;
END LOOP;

print_out('],color: "#C6D9FD"}],valueAxis: {max: '||maxitems||',');
print_out('labels: {format: "{0}"},');
print_out('line: {visible: false},');
print_out('minorGridLines: {visible: true}},');
print_out('categoryAxis: {categories: [');
year_index := beginmin;
WHILE year_index <= beginmax
LOOP
   BEGIN
      /* Build the labels by year */
        print_out(year_index,'N');
     
      if (year_index=beginmax) then
       exit;
      else
        print_out(',','N');
      end if;
     
      year_index:=year_index+ 1;
     
   EXCEPTION
      WHEN OTHERS
      THEN
         year_index:=year_index+ 1;
   END;
END LOOP;
print_out('],majorGridLines: {visible: false}},');
print_out('tooltip: {visible: true,template: "#= series.name #: #= value #"}});}');
print_out('$(document).ready(createChart);$(document).bind("kendo:skinChange", createChart);');
print_out('</script>');

print_out('<script>');
print_out('//------------------------------------------------------------------');
print_out('//   This function will expand and contract selected text for individual sections.');
print_out('//------------------------------------------------------------------');
print_out('function showDetails(divID) {');
print_out(' if (document.getElementById("detailImg"+divID).value == ''+'') {');
print_out('      document.getElementById("detailImg"+divID).value = ''-'';');
print_out('  document.getElementById("detailTxt"+divID).style.display = ''block'';');
print_out('    } else {');
print_out('  document.getElementById("detailImg"+divID).value = ''+'';');
print_out('  document.getElementById("detailTxt"+divID).style.display = ''none'';');
print_out(' }');
print_out('}');
print_out('//------------------------------------------------------------------');
print_out('//   This function will expand text for all expandable sections in the document by clicking the "Show All" button.');
print_out('//------------------------------------------------------------------');
print_out('function showAllDetails() {');
print_out('  for ( var i=0; i <= max_divID; i++ ) {');
print_out(' if (document.getElementById("detailImg"+i) != null){');
print_out('   if (document.getElementById("detailImg"+i).value == ''+'') {');
print_out('  document.getElementById("detailImg"+i).value = ''-'';');
print_out('  document.getElementById("detailTxt"+i).style.display = ''block'';');
print_out('      }');
print_out(' }');
print_out('  }');
print_out('}');
print_out('//------------------------------------------------------------------');
print_out('//   This function will collapse text for all collapsable sections in the document by clicking the "Hide All" button.');
print_out('//------------------------------------------------------------------');
print_out('function hideAllDetails() {');
print_out(' for ( var i=0; i <= max_divID; i++ ) {');
print_out(' if (document.getElementById("detailImg"+i) != null){');
print_out('   if(document.getElementById("detailImg"+i).value == ''-'') {');
print_out('  document.getElementById("detailImg"+i).value = ''+'';');
print_out('  document.getElementById("detailTxt"+i).style.display = ''none'';');
print_out('      }');
print_out(' }');
print_out('  }');
print_out('}');
print_out('</script>');
print_out('</div>');
print_out('</td>');
print_out('<td width="50%">');
print_out('<div id="gauge-graph" display:table-cell; vertical-align:top>');

 if (g_reqid_cnt > g_max_vol) THEN  -- This is the critical setting which customers can adjust here
 print_out('<br><BR>');
 print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=400x250&cht=gm&chd=t:10&chl=Excessive" width="400" height="250">');
 print_out('</td>');


  else   if (g_reqid_cnt > g_min_vol) THEN   -- This is the bad setting which customers can adjust here.
  print_out('<br><BR>');
  print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=400x250&cht=gm&chd=t:50&chl=Poor" width="400" height="250">');
  print_out('</td>');
 
  else
  print_out('<br><BR>');
  print_out('<img src="http://chart.apis.google.com/chart?chxl=0:|critical|bad|good&chxt=y&chs=400x250&cht=gm&chd=t:90&chl=Healthy" width="400" height="250">');
  print_out('</td>');
    
  end if;
end if;
    print_out('</div></td></tr></table>');
    print_out('</div></div>');
   --print_out('</div></div><font style="font-size:x-small;">');
--    print_out('<a href="#top"><font color="#0066CC">Back to top</font></a></font><br><br>');
--BILL ADD  -> If incorrect replace signature id and name as needed
     g_sec_detail(g_sec_detail.COUNT).sigs.extend();    
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_id := 'CP_REQS';
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_name := 'Concurrent Requests Charts';
     g_sec_detail(g_sec_detail.COUNT).sigs(g_sec_detail(g_sec_detail.COUNT).sigs.COUNT).sig_result := 'I';
--END BILL ADD
  exception
 when others then
 emesg := SQLERRM;
        print_out(emesg);
   
END show_gauge_chart;

-------------------------
-- Recommended Patches
-------------------------
FUNCTION check_rec_patches_1 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_1');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,2) = '11' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '5472959';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 5.6.3';
   l_col_rows(5)(1) := '[422508.1]';
   l_col_rows(1)(2) := '5097966';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'XDO/ORACLE XML PUBLISHER CORE ROLLUP PATCH 5.6.2';
   l_col_rows(5)(2) := '[367394.1]';
   l_col_rows(1)(3) := '4905678';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 5.6.1';
   l_col_rows(5)(3) := '[357308.1]';
   l_col_rows(1)(4) := '4561451';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 5.6.0';
   l_col_rows(5)(4) := '[337999.1]';
   l_col_rows(1)(5) := '4236958';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'XDO/ORACLE XML PUBLISHER CORE ROLLUP PATCH 5.0.1';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '4206181';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 5.5.0';
   l_col_rows(5)(6) := '[316447.1]';
   l_col_rows(1)(7) := '3822219';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 5.0.0';
   l_col_rows(5)(7) := '[295036.1]';
   l_col_rows(1)(8) := '3554613';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'XDO/ORACLE XML PUBLISHER OA ROLLUP PATCH 4.5.0';
   l_col_rows(5)(8) := '[269605.1]';
   l_col_rows(1)(9) := '3263588';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := 'Patch 11i.XDO.H';
   l_col_rows(5)(9) := '[258332.1]';
END IF;
   l_sig.title := 'XDO Suggested Patches for 11i';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := 'Suggested XDO Patches';
   l_sig.solution := 'Suggested XDO Patches';
   l_sig.success_msg := 'Suggested XDO Patches';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('XDO_PATCHES') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'XDO_PATCHES',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_1');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_1 at step '||l_step);
  raise;
END check_rec_patches_1;
FUNCTION check_rec_patches_2 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_2');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,4) = '12.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '20043910';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'November Bundle Patches for TXK Delta 5';
   l_col_rows(5)(1) := '[1617461.1]';
END IF;
   l_sig.title := 'Suggested Patches on top of TXK Delta 5';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := 'November Bundle Patches for TXK Delta 5';
   l_sig.solution := 'November Bundle Patches for TXK Delta 5';
   l_sig.success_msg := 'November Bundle Patches for TXK Delta 5';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_CP_PATCHES_R122') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_CP_PATCHES_R122',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_2');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_2 at step '||l_step);
  raise;
END check_rec_patches_2;
FUNCTION check_rec_patches_3 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_3');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,6) = '12.2.4' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17919161';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.4 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17020683';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.3 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '16207672';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.2 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '21236633';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 4 [RPC4]';
   l_col_rows(5)(1) := '[2053709.1]';
   l_col_rows(1)(2) := '9239090';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.3 (RUP3)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '8919491';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12.ATG_PF.B.DELTA.3';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7651091';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.2';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303033';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.2 (RUP2)';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.1' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7307198';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.1';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303030';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '12.1.1 Maintenance Pack';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6430106';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12 Oracle E-Business Suite 12.1';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.0' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7237006';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.A.DELTA.6';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '6728000';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 12.0.6 (RUP6)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6435000';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '12.0.4 Release Update Pack (RUP4)';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '6272680';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.A.DELTA.4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '6077669';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'R12.ATG_PF.A.DELTA.3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '5917344';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.ATG_PF.A.DELTA.2';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '5907545';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.ATG_PF.A.DELTA.1';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '4440000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 12 Maintenance Pack';
   l_col_rows(5)(8) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,9) = '11.5.10.2' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '6241631';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := '11i.ATG_PF.H.RUP7';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '5903765';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '11i.ATG_PF.H.RUP6';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '5473858';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '11i.ATG_PF.H.RUP5';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '4676589';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := '11i.ATG_PF.H.RUP4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '4334965';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '11i.ATG_PF.H RUP3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '4125550';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ATG_PF:11.5.10 Consolidated Update (CU2) for ATG Product Family';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '4017300';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ATG_PF:11.5.10 Consolidated Update (CU1) for ATG Product Family';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '3480000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 11.5.10.2 Maintenance Pack';
   l_col_rows(5)(8) := '[316365.1]';
   l_col_rows(1)(9) := '3460000';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU2)';
   l_col_rows(5)(9) := '[316366.1]';
END IF;
   l_sig.title := 'Recommended Concurrent Processing Patches for '||g_rep_info('Apps Version')||' Release';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := '<p>There are recommended Concurrent Processing and Technology Stack patches that are not applied on this '||g_rep_info('Instance')||' instance.</p>';
   l_sig.solution := '<ul>
 <li>Please review list above and schedule to apply any unappplied recommended Concurrent Processing and Techstack patches as soon as possible</li>
 <li>Refer to the note indicated for more information about each patch</li>
</ul>';
   l_sig.success_msg := '<b>All known recommended EBS Concurrent Processing and Technology Stack patches for release '||g_rep_info('Apps Version')||' have been applied.</b><br><br>
   To get the most current list of recommended EBS CP and Techstack patches that are applied/not applied to your instance, please run Patch Wizard.<br>
   See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_CP_PATCHES_CU2A') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_CP_PATCHES_CU2A',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_3');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_3 at step '||l_step);
  raise;
END check_rec_patches_3;
FUNCTION check_rec_patches_4 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_4');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,6) = '12.2.4' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17919161';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.4 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17020683';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.3 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '16207672';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.2 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '21236633';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 4 [RPC4]';
   l_col_rows(5)(1) := '[2053709.1]';
   l_col_rows(1)(2) := '8919491';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12.ATG_PF.B.DELTA.3';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7651091';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.2';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303033';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.2 (RUP2)';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.1' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7307198';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.1';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303030';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '12.1.1 Maintenance Pack';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6430106';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12 Oracle E-Business Suite 12.1';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.0' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7237006';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.A.DELTA.6';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '6728000';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 12.0.6 (RUP6)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6435000';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '12.0.4 Release Update Pack (RUP4)';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '6272680';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.A.DELTA.4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '6077669';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'R12.ATG_PF.A.DELTA.3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '5917344';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.ATG_PF.A.DELTA.2';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '5907545';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.ATG_PF.A.DELTA.1';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '4440000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 12 Maintenance Pack';
   l_col_rows(5)(8) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,9) = '11.5.10.2' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '6241631';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := '11i.ATG_PF.H.RUP7';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '5903765';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '11i.ATG_PF.H.RUP6';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '5473858';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '11i.ATG_PF.H.RUP5';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '4676589';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := '11i.ATG_PF.H.RUP4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '4334965';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '11i.ATG_PF.H RUP3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '4125550';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ATG_PF:11.5.10 Consolidated Update (CU2) for ATG Product Family';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '4017300';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ATG_PF:11.5.10 Consolidated Update (CU1) for ATG Product Family';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '3480000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 11.5.10.2 Maintenance Pack';
   l_col_rows(5)(8) := '[316365.1]';
   l_col_rows(1)(9) := '3460000';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU2)';
   l_col_rows(5)(9) := '[316366.1]';
   l_col_rows(1)(10) := '3240000';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU1)';
   l_col_rows(5)(10) := '[298352.1]';
END IF;
   l_sig.title := 'Recommended Concurrent Processing Patches for '||g_rep_info('Apps Version')||' Release';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := 'Please check if any of the recommended E-Business Suite CP and Technology Stack patches were not applied in this  '||g_rep_info('Apps Version')||' instance';
   l_sig.solution := '<b>To get a current accurate list of recommended EBS CP and Techstack patches that are applied/not applied to your instance, please run Patch Wizard.</b><br>
  See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>
  <ul>Above is a short list of recommended CP and Technology Stack patches as of the date this script was written to show you what may or may not be applied on this '||g_rep_info('Instance')||' instance.
  <li>Please review the list above and schedule to apply any unappplied patches as soon as possible</li>
        <li>Refer to the note indicated for more information about each patch</li></ul>';
   l_sig.success_msg := '<b>All known recommended EBS Concurrent Processing and Technology Stack patches for release '||g_rep_info('Apps Version')||' have been applied.</b><br><br>
   To get the most current list of recommended EBS CP and Techstack patches that are applied/not applied to your instance, please run Patch Wizard.<br>
   See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_CP_PATCHES_RUP4A') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_CP_PATCHES_RUP4A',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_4');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_4 at step '||l_step);
  raise;
END check_rec_patches_4;
FUNCTION check_rec_patches_5 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_5');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,6) = '12.2.4' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17919161';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.4 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17020683';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.3 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '16207672';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.2 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '21236633';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 4 [RPC4]';
   l_col_rows(5)(1) := '[2053709.1]';
   l_col_rows(1)(2) := '9239090';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.3 (RUP3)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '8919491';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12.ATG_PF.B.DELTA.3';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7651091';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.2';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303033';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.2 (RUP2)';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.1' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7307198';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.1';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303030';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '12.1.1 Maintenance Pack';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6430106';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12 Oracle E-Business Suite 12.1';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.0' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7237006';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.A.DELTA.6';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '6728000';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 12.0.6 (RUP6)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6272680';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12.ATG_PF.A.DELTA.4';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '6077669';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.A.DELTA.3';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '5917344';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'R12.ATG_PF.A.DELTA.2';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '5907545';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.ATG_PF.A.DELTA.1';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '4440000';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'Oracle Applications Release 12 Maintenance Pack';
   l_col_rows(5)(7) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,9) = '11.5.10.2' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '6241631';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := '11i.ATG_PF.H.RUP7';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '5903765';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '11i.ATG_PF.H.RUP6';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '5473858';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '11i.ATG_PF.H.RUP5';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '4676589';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := '11i.ATG_PF.H.RUP4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '4334965';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '11i.ATG_PF.H RUP3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '4125550';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ATG_PF:11.5.10 Consolidated Update (CU2) for ATG Product Family';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '4017300';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ATG_PF:11.5.10 Consolidated Update (CU1) for ATG Product Family';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '3480000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 11.5.10.2 Maintenance Pack';
   l_col_rows(5)(8) := '[316365.1]';
   l_col_rows(1)(9) := '3460000';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU2)';
   l_col_rows(5)(9) := '[316366.1]';
   l_col_rows(1)(10) := '3240000';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU1)';
   l_col_rows(5)(10) := '[298352.1]';
END IF;
   l_sig.title := 'Recommended Concurrent Processing Patches for '||g_rep_info('Apps Version')||' Release';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := '<p>There are recommended Concurrent Processing patches that are not applied on this &#39;||g_rep_info(&#39;Instance&#39;)||&#39; instance.</p>';
   l_sig.solution := '<ul>
 <li>Please review list above and schedule to apply any unappplied recommended Concurrent Processing patches as soon as possible</li>
 <li>Refer to the note indicated for more information about each patch</li>
</ul>';
   l_sig.success_msg := '<p>All recommended Concurrent Processing patches (if any) have been applied.</p>';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_CP_PATCHES_RUP6') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_CP_PATCHES_RUP6',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_5');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_5 at step '||l_step);
  raise;
END check_rec_patches_5;
FUNCTION check_rec_patches_6 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_6');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,6) = '12.2.6' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '21900901';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.6 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '[2114016.1]';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.5' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '19676458';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.5 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '[1983050.1]';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.4' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '25598741';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := '1OFF:12.2.4:RECALCULATE PARAMETERS NOT WORKING FOR REQUEST SETS - FLEX PORTION';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '17919161';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'ORACLE E-BUSINESS SUITE 12.2.4 RELEASE UPDATE PACK';
   l_col_rows(5)(2) := '[1617458.1]';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '17020683';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.3 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '[1586214.1]';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.2.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '16207672';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'ORACLE E-BUSINESS SUITE 12.2.2 RELEASE UPDATE PACK';
   l_col_rows(5)(1) := '[1506669.1]';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '25381217';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'UNABLE TO ADD NEW MESSAGE TYPE FORMS PERSONALIZATION ACTIONS ON TOP PF EXISTING';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '25186394';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'FND Recommended Patch Collection (12/2016)';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '22644544';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Oracle E-Business Suite Release 12.1.3+ Recommended Patch Collection 5 [RPC5]';
   l_col_rows(5)(1) := '[2152266.1]';
   l_col_rows(1)(2) := '21236633';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'Oracle E-Business Suite Release 12.1.3+ Recommended Patch Collection 4 [RPC4]';
   l_col_rows(5)(2) := '[2053709.1]';
   l_col_rows(1)(3) := '9239090';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12 Oracle E-Business Suite 12.1.3 (RUP3)';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '8919491';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.B.DELTA.3';
   l_col_rows(5)(4) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7651091';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.2';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303033';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 Oracle E-Business Suite 12.1.2 (RUP2)';
   l_col_rows(5)(2) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.1' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7307198';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.B.DELTA.1';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '7303030';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '12.1.1 Maintenance Pack';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6430106';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12 Oracle E-Business Suite 12.1';
   l_col_rows(5)(3) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.0' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7237006';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.A.DELTA.6';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '6728000';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12 12.0.6 (RUP6)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6435000';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '12.0.4 Release Update Pack (RUP4)';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '6272680';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.A.DELTA.4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '6077669';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'R12.ATG_PF.A.DELTA.3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '5917344';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.ATG_PF.A.DELTA.2';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '5907545';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.ATG_PF.A.DELTA.1';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '4440000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 12 Maintenance Pack';
   l_col_rows(5)(8) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,9) = '11.5.10.2' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '6241631';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := '11i.ATG_PF.H.RUP7';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '5903765';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '11i.ATG_PF.H.RUP6';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '5473858';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '11i.ATG_PF.H.RUP5';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '4676589';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := '11i.ATG_PF.H.RUP4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '4334965';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '11i.ATG_PF.H RUP3';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '4125550';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ATG_PF:11.5.10 Consolidated Update (CU2) for ATG Product Family';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '4017300';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ATG_PF:11.5.10 Consolidated Update (CU1) for ATG Product Family';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '3480000';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Oracle Applications Release 11.5.10.2 Maintenance Pack';
   l_col_rows(5)(8) := '[316365.1]';
   l_col_rows(1)(9) := '3460000';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '11.5.10 Oracle E-Business Suite Consolidated Update (CU2)';
   l_col_rows(5)(9) := '[316366.1]';
END IF;
   l_sig.title := 'Recommended Concurrent Processing Patches for '||g_rep_info('Apps Version')||' Release';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := '<p>There are recommended Concurrent Processing and Technology Stack patches that are not applied on this '||g_rep_info('Instance')||' instance.</p>';
   l_sig.solution := '<ul>
 <li>Please review list above and schedule to apply any unappplied recommended Concurrent Processing and Techstack patches as soon as possible</li>
 <li>Refer to the note indicated for more information about each patch</li>
</ul>';
   l_sig.success_msg := '<b>All known recommended EBS Concurrent Processing and Technology Stack patches for release '||g_rep_info('Apps Version')||' have been applied.</b><br><br>
   To get the most current list of recommended EBS CP and Techstack patches that are applied/not applied to your instance, please run Patch Wizard.<br>
   See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_CP_PATCHES') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_CP_PATCHES',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_6');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_6 at step '||l_step);
  raise;
END check_rec_patches_6;
FUNCTION check_rec_patches_7 RETURN VARCHAR2 IS

  l_col_rows   COL_LIST_TBL := col_list_tbl(); -- Row values
  l_hdr        VARCHAR_TBL  := varchar_tbl(); -- Column headings
  l_app_date   DATE;         -- Patch applied date
  l_extra_info HASH_TBL_4K;  -- Extra information
  l_step       VARCHAR2(10);
  l_sig        SIGNATURE_REC;
  l_rel        VARCHAR2(3);

  CURSOR get_app_date(p_ptch VARCHAR2, p_rel VARCHAR2) IS    
   SELECT min(Last_Update_Date) as date_applied
    FROM Ad_Bugs Adb
    WHERE Adb.Bug_Number like p_ptch
    AND ad_patch.is_patch_applied(p_rel, -1, adb.bug_number)!='NOT_APPLIED';

BEGIN

debug('Begin recommended patches signature: check_rec_patches_7');

  -- Column headings
  l_step := '10';
  l_hdr.extend(5);
  l_hdr(1) := 'Patch';
  l_hdr(2) := 'Applied';
  l_hdr(3) := 'Date';
  l_hdr(4) := 'Name';
  l_hdr(5) := 'Note';
  l_col_rows.extend(5);

IF substr(g_rep_info('Apps Version'),1,4) = '12.2' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '24578455';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'REVERT CHANGES MADE TO VALIDATE MANAGED SERVER PORTS OF ALL NODES';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '21841299';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'R12.AD.C.DELTA.8 PATCH';
   l_col_rows(5)(2) := '[1617461.1]';
   l_col_rows(1)(3) := '21830810';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'R12.TXK.C.DELTA.8';
   l_col_rows(5)(3) := '[1617461.1]';
   l_col_rows(1)(4) := '20784380';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.TXK.C.delta.7 (Superseded by 21830810)';
   l_col_rows(5)(4) := '[1617461.1]';
   l_col_rows(1)(5) := '20745242';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'R12.AD.C.delta.7 (Superseded by 21841299)';
   l_col_rows(5)(5) := '[1617461.1]';
   l_col_rows(1)(6) := '17919161';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.2.4 - ORACLE E-BUSINESS SUITE 12.2.4 RELEASE UPDATE PACK';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '17020683';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.2.3 - ORACLE E-BUSINESS SUITE 12.2.3 RELEASE UPDATE PACK';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '16207672';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'R12.2.2 - ORACLE E-BUSINESS SUITE 12.2.2 RELEASE UPDATE PACK';
   l_col_rows(5)(8) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.1.3' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '24516586';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Fix for Bug 24516586';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '22879584';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'Fix for Bug 22879584';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '22200487';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'E-BUSINESS SUITE: CONSOLIDATED ONLINE PATCHING ENABLEMENT READINESS REPORT';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '20592764';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'CONSOLIDATED AD IO PATCH FOR EBS PLUGIN 12.1.0.4.0';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '20228512';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '1OFF:12.1.3:18356549:EM_MONITOR USER REQUIRES ACCESS TO TABLES';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '19287203';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'TECHPLAT:CHANGES REQUIRED FOR RELINKING FAILURES ON WIN 2012 R2 WITH VS2013';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '18312333';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ADGENJKY.SH GENERATING CORE DUMP AT THE END OF EXECUTION';
   l_col_rows(5)(7) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.1' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '22644544';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 5 [RPC5]';
   l_col_rows(5)(1) := '[1986065.1]';
   l_col_rows(1)(2) := '21236633';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 4 [RPC4] - (Superseded by RPC5 - Patch 22644544)';
   l_col_rows(5)(2) := '[2053709.1]';
   l_col_rows(1)(3) := '20203366';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 3 [RPC3] - (Superseded by RPC5 - Patch 22644544)';
   l_col_rows(5)(3) := '[1986065.1]';
   l_col_rows(1)(4) := '19030202';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 2 [RPC2] - (Superseded by RPC5 - Patch 22644544)';
   l_col_rows(5)(4) := '[1920628.1]';
   l_col_rows(1)(5) := '17774755';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'Oracle 12.1.3+ E-Business Suite Recommended Patch Collection 1 [RPC1] - (Superseded by RPC5 - Patch 22644544)';
   l_col_rows(5)(5) := '[1638535.1]';
   l_col_rows(1)(6) := '9239090';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ORACLE E-BUSINESS SUITE 12.1.3 RELEASE UPDATE PACK';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '8919491';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.ATG_PF.B.DELTA.3';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '7651091';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'R12.ATG_PF.B.DELTA.2';
   l_col_rows(5)(8) := '';
   l_col_rows(1)(9) := '7307198';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := 'R12.ATG_PF.B.DELTA.1';
   l_col_rows(5)(9) := '';
   l_col_rows(1)(10) := '7303033';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := 'Oracle E-Business Suite 12.1.2 Release Update Pack (RUP2)';
   l_col_rows(5)(10) := '';
   l_col_rows(1)(11) := '7303030';
   l_col_rows(2)(11) := 'No';
   l_col_rows(3)(11) := NULL;
   l_col_rows(4)(11) := '12.1.1 Maintenance Pack';
   l_col_rows(5)(11) := '';
   l_col_rows(1)(12) := '6430106';
   l_col_rows(2)(12) := 'No';
   l_col_rows(3)(12) := NULL;
   l_col_rows(4)(12) := 'R12 ORACLE E-BUSINESS SUITE 12.1';
   l_col_rows(5)(12) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,6) = '12.0.6' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '22200487';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'E-BUSINESS SUITE: CONSOLIDATED ONLINE PATCHING ENABLEMENT READINESS REPORT';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '18312333';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'ADGENJKY.SH GENERATING CORE DUMP AT THE END OF EXECUTION';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '16541210';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'ENCOUNTER ORA-12899 WHEN RUNNIJNG PATCH WIZARD';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '16322006';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'TXK CPU fix';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '6767273';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'INSTALLING R12.AD.A.DELTA.4 FAILS FOR OFF-CYCLE PRODUCTS';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '5938978';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'ADMRGPCH ERRORS WITH A "CHARACTER-SET CONVERSION" ERROR ON SUN SOLARIS';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '5866902';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'ADMERGE.PL IS NOT COPYING THE MSI FILES IN THE MERGED PATCH.';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '5866720';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'CONNECTION ISSUES IN "PATCH APPLICATION ASSISTANT" ON RAC INSTANCE';
   l_col_rows(5)(8) := '';
   l_col_rows(1)(9) := '5856453';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := 'QREP120.19:R12 MP(4440000) GETS KILLED WHILE EXECUTING EGOSILDU.SQL';
   l_col_rows(5)(9) := '';
   l_col_rows(1)(10) := '5635729';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := 'ADPATCH TO COMPARE FILE VERSIONS FOR TRANSLATION SYNCH. PATCHES';
   l_col_rows(5)(10) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,4) = '12.0' THEN
   l_rel := 'R12';
   l_col_rows(1)(1) := '7237006';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'R12.ATG_PF.A.DELTA.6';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '6728000';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := '12.0.6 RELEASE UPDATE PACK (RUP6)';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '6435000';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := '12.0.4 RELEASE UPDATE PACK (RUP4)';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '6272680';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'R12.ATG_PF.A.DELTA.4';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '6141000';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := '12.0.3 Release Update Pack (RUP3)';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '6077669';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'R12.ATG_PF.A.DELTA.3';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '5917344';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'R12.ATG_PF.A.DELTA.2';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '5907545';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'R12.ATG_PF.A.DELTA.1';
   l_col_rows(5)(8) := '';
   l_col_rows(1)(9) := '5484000';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '12.0.2 Release Update Pack (RUP2)';
   l_col_rows(5)(9) := '';
   l_col_rows(1)(10) := '5082400';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := '12.0.1 Release Update Pack (RUP1)';
   l_col_rows(5)(10) := '';
   l_col_rows(1)(11) := '4440000';
   l_col_rows(2)(11) := 'No';
   l_col_rows(3)(11) := NULL;
   l_col_rows(4)(11) := 'Oracle Applications Release 12 Maintenance Pack';
   l_col_rows(5)(11) := '';
END IF;
IF substr(g_rep_info('Apps Version'),1,9) = '11.5.10.2' THEN
   l_rel := '11i';
   l_col_rows(1)(1) := '24755689';
   l_col_rows(2)(1) := 'No';
   l_col_rows(3)(1) := NULL;
   l_col_rows(4)(1) := 'E-BUSINESS SUITE: 11I CONSOLIDATED ONLINE PATCHING ENABLEMENT READINESS REPORT';
   l_col_rows(5)(1) := '';
   l_col_rows(1)(2) := '22200487';
   l_col_rows(2)(2) := 'No';
   l_col_rows(3)(2) := NULL;
   l_col_rows(4)(2) := 'E-BUSINESS SUITE: CONSOLIDATED ONLINE PATCHING ENABLEMENT READINESS REPORT';
   l_col_rows(5)(2) := '';
   l_col_rows(1)(3) := '20592764';
   l_col_rows(2)(3) := 'No';
   l_col_rows(3)(3) := NULL;
   l_col_rows(4)(3) := 'CONSOLIDATED AD IO PATCH FOR EBS PLUGIN 12.1.0.4.0';
   l_col_rows(5)(3) := '';
   l_col_rows(1)(4) := '19725648';
   l_col_rows(2)(4) := 'No';
   l_col_rows(3)(4) := NULL;
   l_col_rows(4)(4) := 'ADGENJKY.SH GENERATING CORE DUMP AT THE END OF EXECUTION';
   l_col_rows(5)(4) := '';
   l_col_rows(1)(5) := '19502890';
   l_col_rows(2)(5) := 'No';
   l_col_rows(3)(5) := NULL;
   l_col_rows(4)(5) := 'Fix for Bug 19502890';
   l_col_rows(5)(5) := '';
   l_col_rows(1)(6) := '19492734';
   l_col_rows(2)(6) := 'No';
   l_col_rows(3)(6) := NULL;
   l_col_rows(4)(6) := 'Fix for Bug 19492734';
   l_col_rows(5)(6) := '';
   l_col_rows(1)(7) := '16322742';
   l_col_rows(2)(7) := 'No';
   l_col_rows(3)(7) := NULL;
   l_col_rows(4)(7) := 'Fix for Bug 16322742';
   l_col_rows(5)(7) := '';
   l_col_rows(1)(8) := '16264433';
   l_col_rows(2)(8) := 'No';
   l_col_rows(3)(8) := NULL;
   l_col_rows(4)(8) := 'Fix for Bug 16264433';
   l_col_rows(5)(8) := '';
   l_col_rows(1)(9) := '6241631';
   l_col_rows(2)(9) := 'No';
   l_col_rows(3)(9) := NULL;
   l_col_rows(4)(9) := '11i.ATG_PF.H.RUP7';
   l_col_rows(5)(9) := '';
   l_col_rows(1)(10) := '6047864';
   l_col_rows(2)(10) := 'No';
   l_col_rows(3)(10) := NULL;
   l_col_rows(4)(10) := 'REHOST JOC FIXES (BASED ON JOC 10.1.2.2) FOR APPS 11i';
   l_col_rows(5)(10) := '';
   l_col_rows(1)(11) := '6008417';
   l_col_rows(2)(11) := 'No';
   l_col_rows(3)(11) := NULL;
   l_col_rows(4)(11) := 'AOL USER RESPONSIBILITY SECURITY FIXES 2b';
   l_col_rows(5)(11) := '';
   l_col_rows(1)(12) := '5903765';
   l_col_rows(2)(12) := 'No';
   l_col_rows(3)(12) := NULL;
   l_col_rows(4)(12) := '11i.ATG_PF.H.RUP6';
   l_col_rows(5)(12) := '';
   l_col_rows(1)(13) := '5473858';
   l_col_rows(2)(13) := 'No';
   l_col_rows(3)(13) := NULL;
   l_col_rows(4)(13) := '11i.ATG_PF.H.RUP5';
   l_col_rows(5)(13) := '';
   l_col_rows(1)(14) := '5121512';
   l_col_rows(2)(14) := 'No';
   l_col_rows(3)(14) := NULL;
   l_col_rows(4)(14) := 'AOL USER RESPONSIBILITY SECURITY FIXES VERSION 1';
   l_col_rows(5)(14) := '';
   l_col_rows(1)(15) := '4676589';
   l_col_rows(2)(15) := 'No';
   l_col_rows(3)(15) := NULL;
   l_col_rows(4)(15) := '11i.ATG_PF.H.RUP4';
   l_col_rows(5)(15) := '';
   l_col_rows(1)(16) := '4334965';
   l_col_rows(2)(16) := 'No';
   l_col_rows(3)(16) := NULL;
   l_col_rows(4)(16) := '11i.ATG_PF.H RUP3';
   l_col_rows(5)(16) := '';
   l_col_rows(1)(17) := '4125550';
   l_col_rows(2)(17) := 'No';
   l_col_rows(3)(17) := NULL;
   l_col_rows(4)(17) := 'ATG_PF:11.5.10 Consolidated Update (CU2) for ATG Product Family';
   l_col_rows(5)(17) := '';
   l_col_rows(1)(18) := '4017300';
   l_col_rows(2)(18) := 'No';
   l_col_rows(3)(18) := NULL;
   l_col_rows(4)(18) := 'ATG_PF:11.5.10 Consolidated Update (CU1) for ATG Product Family';
   l_col_rows(5)(18) := '';
   l_col_rows(1)(19) := '3480000';
   l_col_rows(2)(19) := 'No';
   l_col_rows(3)(19) := NULL;
   l_col_rows(4)(19) := 'ORACLE APPLICATIONS RELEASE 11.5.10.2 MAINTENANCE PACK';
   l_col_rows(5)(19) := '';
   l_col_rows(1)(20) := '3460000';
   l_col_rows(2)(20) := 'No';
   l_col_rows(3)(20) := NULL;
   l_col_rows(4)(20) := '11.5.10 ORACLE E-BUSINESS SUITE CONSOLIDATED UPDATE 2';
   l_col_rows(5)(20) := '';
   l_col_rows(1)(21) := '3438354';
   l_col_rows(2)(21) := 'No';
   l_col_rows(3)(21) := NULL;
   l_col_rows(4)(21) := '11i.ATG_PF.H INCLUDE OWF.H';
   l_col_rows(5)(21) := '';
   l_col_rows(1)(22) := '3262919';
   l_col_rows(2)(22) := 'No';
   l_col_rows(3)(22) := NULL;
   l_col_rows(4)(22) := 'FMWK.H';
   l_col_rows(5)(22) := '';
   l_col_rows(1)(23) := '3262159';
   l_col_rows(2)(23) := 'No';
   l_col_rows(3)(23) := NULL;
   l_col_rows(4)(23) := 'FND.H INCLUDE OWF.H';
   l_col_rows(5)(23) := '';
   l_col_rows(1)(24) := '3258819';
   l_col_rows(2)(24) := 'No';
   l_col_rows(3)(24) := NULL;
   l_col_rows(4)(24) := 'OWF.H INCLUDED IN 11.5.10';
   l_col_rows(5)(24) := '';
   l_col_rows(1)(25) := '3240000';
   l_col_rows(2)(25) := 'No';
   l_col_rows(3)(25) := NULL;
   l_col_rows(4)(25) := '11.5.10 ORACLE E-BUSINESS SUITE CONSOLIDATED UPDATE 1';
   l_col_rows(5)(25) := '';
   l_col_rows(1)(26) := '3140000';
   l_col_rows(2)(26) := 'No';
   l_col_rows(3)(26) := NULL;
   l_col_rows(4)(26) := 'ORACLE APPLICATIONS RELEASE 11.5.10 MAINTENANCE PACK';
   l_col_rows(5)(26) := '';
END IF;
   l_sig.title := 'Recommended  '||g_rep_info('Apps Version')||' E-Business Suite Technology Stack Patches';
   l_sig.fail_condition := '[Applied] = [No]';
   l_sig.problem_descr := 'Please check if any of the recommended E-Business Suite Technology Stack patches were not applied in this  '||g_rep_info('Apps Version')||' instance';
   l_sig.solution := '<b>To get a current accurate list of recommended EBS product patches that are applied/not applied to your instance, please run Patch Wizard.</b><br>
  See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>
  <ul>Above is a short list of recommended product patches as of the date this script was written to show you what may or may not be applied on this '||g_rep_info('Instance')||' instance.
  <li>Please review the list above and schedule to apply any unappplied patches as soon as possible</li>
        <li>Refer to the note indicated for more information about each patch</li></ul><br>';
   l_sig.success_msg := '<b>All known recommended EBS product patches, at the time this script was written, for release '||g_rep_info('Apps Version')||' have been applied.<br>
   To get the most current list of recommended EBS product patches that are applied/not applied to your instance, please run Patch Wizard.</b><br>
   See [976188.1] - Patch Wizard Utility, [976688.2] FAQ, or [1077813.1] Videos for more information.<br>';
   l_sig.print_condition := 'ALWAYS';
   l_sig.fail_type := 'W';
   l_sig.print_sql_output := 'Y';
   l_sig.limit_rows := 'N';
   l_sig.include_in_xml :='Y';

  -- Check if applied
  IF l_col_rows.exists(1) THEN
    FOR i in 1..l_col_rows(1).count loop
      l_step := '40';
      OPEN get_app_date(l_col_rows(1)(i),l_rel);
      FETCH get_app_date INTO l_app_date;
      CLOSE get_app_date;
      l_col_rows(1)(i) := '{'||l_col_rows(1)(i)||'}';
      IF l_app_date is not null THEN
        l_step := '50';
        l_col_rows(2)(i) := 'Yes';
        l_col_rows(3)(i) := to_char(l_app_date);
      END IF;
    END LOOP;
  END IF;

--Render
  l_step := '60';
 
  g_signatures('CP1_CHK_TXK_PATCHES') := l_sig;

  l_step := '70';
  RETURN process_signature_results(
    'CP1_CHK_TXK_PATCHES',     -- sig ID
    l_sig,                              -- signature information
    l_col_rows,                         -- data
    l_hdr);                             -- headers

debug('End recommended patches signature: check_rec_patches_7');   
   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in check_rec_patches_7 at step '||l_step);
  raise;
END check_rec_patches_7;


-------------------------
-- Signatures
-------------------------

PROCEDURE add_signature(
  p_sig_id           VARCHAR2,     -- Unique Signature identifier
  p_sig_sql          VARCHAR2,     -- The text of the signature query
  p_title            VARCHAR2,     -- Signature title
  p_fail_condition   VARCHAR2,     -- 'RSGT1' (RS greater than 1), 'RS' (row selected), 'NRS' (no row selected), '[count(*)] > [0]'
  p_problem_descr    VARCHAR2,     -- Problem description
  p_solution         VARCHAR2,     -- Problem solution
  p_success_msg      VARCHAR2    DEFAULT null,      -- Message on success
  p_print_condition  VARCHAR2    DEFAULT 'ALWAYS',  -- ALWAYS, SUCCESS, FAILURE, NEVER
  p_fail_type        VARCHAR2    DEFAULT 'W',       -- Warning(W), Error(E), Informational(I) is for use of data dump so no validation
  p_print_sql_output VARCHAR2    DEFAULT 'RS',      -- Y/N/RS - when to print data
  p_limit_rows       VARCHAR2    DEFAULT 'Y',       -- Y/N
  p_extra_info       HASH_TBL_4K DEFAULT CAST(null AS HASH_TBL_4K), -- Additional info
  p_child_sigs       VARCHAR_TBL DEFAULT VARCHAR_TBL(),
  p_include_in_dx_summary   VARCHAR2    DEFAULT 'N') -- This is for AT use so internal only. Set to Y if want signature result to be printed at end of output file in DX Summary section
 IS
  l_rec signature_rec;
BEGIN
  l_rec.sig_sql          := p_sig_sql;
  l_rec.title            := p_title;
  l_rec.fail_condition   := p_fail_condition;
  l_rec.problem_descr    := p_problem_descr;
  l_rec.solution         := p_solution;
  l_rec.success_msg      := p_success_msg;
  l_rec.print_condition  := p_print_condition;
  l_rec.fail_type        := p_fail_type;
  l_rec.print_sql_output := p_print_sql_output;
  l_rec.limit_rows       := p_limit_rows;
  l_rec.extra_info       := p_extra_info;
  l_rec.child_sigs       := p_child_sigs;
  l_rec.include_in_xml   := p_include_in_dx_summary;
  g_signatures(p_sig_id) := l_rec;
EXCEPTION WHEN OTHERS THEN
  print_log('Error in add_signature procedure: '||p_sig_id);
  raise;
END add_signature;

FUNCTION run_stored_sig(p_sig_id varchar2) RETURN VARCHAR2 IS
  l_col_rows COL_LIST_TBL := col_list_tbl();
  l_col_hea  VARCHAR_TBL := varchar_tbl();
  l_sig      signature_rec;
  l_key      VARCHAR2(255);
BEGIN
  print_log('Processing signature: '||p_sig_id);
  -- Get the signature record from the signature table
  BEGIN
    l_sig := g_signatures(p_sig_id);
  EXCEPTION WHEN NO_DATA_FOUND THEN
    print_log('No such signature '||p_sig_id||' error in run_stored_sig');
--CG     raise;
return 'E';
  END;
 
  -- Clear FK values if the sig has children
  IF l_sig.child_sigs.count > 0 THEN
    l_key := g_sql_tokens.first;
    WHILE l_key is not null LOOP
      IF l_key like '##$$FK_$$##' THEN
        g_sql_tokens.delete(l_key);
      END IF;
      l_key := g_sql_tokens.next(l_key);
    END LOOP;
  END IF;
  -- Run SQL
  run_sig_sql(l_sig.sig_sql, l_col_rows, l_col_hea,
              l_sig.limit_rows);
  -- Evaluate and print
  RETURN process_signature_results(
       p_sig_id,               -- signature id
       l_sig,                  -- Name/title of signature item
       l_col_rows,             -- signature SQL row values
       l_col_hea);             -- signature SQL column names

   
EXCEPTION WHEN OTHERS THEN
  print_log('Error in run_stored_sig procedure for sig_id: '||p_sig_id);
  print_log('Error: '||sqlerrm);
  print_error('PROGRAM ERROR<br/>
    Error for sig '||p_sig_id||' '||sqlerrm||'<br/>
    See the log file for additional details');
--CG   return null;
   return 'E';
END run_stored_sig;

--########################################################################################
--     Beginning of specific code of this ANALYZER
--########################################################################################
----------------------------------------------------------------
--- Validate Parameters                                      ---
----------------------------------------------------------------
PROCEDURE validate_parameters(
            p_min_volume                   IN NUMBER      DEFAULT 3500
           ,p_max_volume                   IN NUMBER      DEFAULT 5000
           ,p_max_output_rows              IN NUMBER      DEFAULT 30
           ,p_debug_mode                   IN VARCHAR2    DEFAULT 'Y')
IS
  l_revision                  VARCHAR2(25);
  l_date_char                 VARCHAR2(30);
  l_instance                  V$INSTANCE.INSTANCE_NAME%TYPE;
  l_apps_version              FND_PRODUCT_GROUPS.RELEASE_NAME%TYPE;
  l_host                      V$INSTANCE.HOST_NAME%TYPE;
  l_full_hostname             VARCHAR2(255);
  l_key                       VARCHAR2(255);
  l_system_function_var       VARCHAR2(2000);
  l_index                     NUMBER:=1;
  l_dbversion                 V$INSTANCE.VERSION%TYPE;
  invalid_parameters EXCEPTION;
  l_item_cnt            number;
  l_cp_status   VARCHAR2(15);
  l_nodename   VARCHAR2(30);
  l_cp_start_date DATE;
  l_logfile_name     VARCHAR2(240);
  l_last_update_date DATE;
  l_apps_invalid_cnt    number;
  l_fnd_invalid_cnt     number;
  l_CU1                 varchar2(15);
  l_CU2                 varchar2(15);
  l_RUP4                varchar2(15);
  l_RUP6                varchar2(15);
  l_run_alone_cnt       number := 0;
  l_run_alone_now_cnt   number := 0;
  l_std_mgr             VARCHAR2(30);
  l_enabled             VARCHAR2(1);
  l_cache               NUMBER(3);

l_exists_val       VARCHAR2(2000);


BEGIN

  -- Determine instance info
   BEGIN
    SELECT max(release_name) INTO l_apps_version
    FROM fnd_product_groups;
    SELECT instance_name, host_name, version
    INTO l_instance, l_host, l_dbversion
    FROM v$instance;
   EXCEPTION WHEN OTHERS THEN
    print_log('Error in validate_parameters gathering instance information: '
      ||sqlerrm);
    raise;
   END;
   BEGIN
 SELECT distinct domain
 INTO l_full_hostname
 FROM (SELECT db_domain AS domain
         FROM fnd_databases
    UNION ALL
    SELECT domain AS domain
    FROM fnd_nodes) domains WHERE domains.domain IS NOT NULL and rownum = 1;
    EXCEPTION
        WHEN NO_DATA_FOUND THEN
    l_full_hostname := NULL;
        WHEN OTHERS THEN
          print_log('Error in validate_parameters gathering instance information: '
          ||sqlerrm);
   END;
 
-- Revision and date values can be populated by RCS
  l_revision := rtrim(replace('$Revision: 200.24  $','$','')); 
  l_revision := ltrim(replace(l_revision,'Revision:',''));
  l_date_char := rtrim(replace('$Date: 2017/03/31 09:10:18 $','$',''));
  l_date_char := ltrim(replace(l_date_char,'Date:',''));
  l_date_char := to_char(to_date(l_date_char,'YYYY/MM/DD HH24:MI:SS'),'DD-MON-YYYY');
 
-- Create global hash for mapping internal result codes (E, W, S, I) to user friendly result codes (error, warning, successful, information)
  g_result('E') := 'error';
  g_result('W') := 'warning';
  g_result('S') := 'success';
  g_result('I') := 'info';
 

-- Create global hash for report information
  g_rep_info('Host') := l_host;
  -- the host name might already be fully qualified, need to check if it includes the domain before appending it
  IF (l_host LIKE '%.%') THEN
       g_rep_info('FullHost') := l_host;
  ELSE 
       g_rep_info('FullHost') := l_host || '.' || l_full_hostname;
  END IF;    
  g_rep_info('Instance') := l_instance;
  g_rep_info('DB Version') := l_dbversion;
  g_rep_info('Apps Version') := l_apps_version;
  g_rep_info('File Name') := 'cp_analyzer.sql';
  g_rep_info('File Version') := l_revision;  
  g_rep_info('Execution Date') := to_char(sysdate,'DD-MON-YYYY HH24:MI:SS');
  g_rep_info('Description') := ('The ' || analyzer_title ||' Analyzer ' || '<a href="https://support.oracle.com/epmos/faces/DocumentDisplay?id=1411723.1" target="_blank">(Note 1411723.1)</a> ' || ' is a self-service health-check script that reviews the overall footprint, analyzes current configurations and settings for the environment and provides feedback and recommendations on best practices. Your application data is not altered in any way when you run this analyzer.');
  ------------------------------------------------------------------------------
  -- NOTE: Add code here for validation to the parameters of your diagnostic
  ------------------------------------------------------------------------------
 
  g_max_output_rows := nvl(p_max_output_rows,20);
  g_debug_mode := nvl(p_debug_mode, 'Y');



-- Validation to verify analyzer is run on proper e-Business application version
-- In case validation at the beginning is updated/removed, adding validation here also so execution fails
  IF substr(l_apps_version,1,4) NOT IN ('11.5','12.0','12.1','12.2') THEN
 print_log('eBusiness Suite version = '||l_apps_version);
 print_log('ERROR: This Analyzer script is compatible for following version(s): 11i,12.0,12.1,12.2');
 raise invalid_parameters;
  END IF;
 
-- .log enhancements (ER # 140)
  IF NOT g_is_concurrent THEN
    print_log('EBS '||'Concurrent Processing'|| ' Analyzer Log File');
    print_log('***************************************************************');
    print_log('Host: '||g_rep_info('Host'));
    print_log('FullHost: '||g_rep_info('FullHost'));
    print_log('Instance: '||g_rep_info('Instance'));
    print_log('Database version: '||g_rep_info('DB Version'));
    print_log('Applications version: '||g_rep_info('Apps Version'));
    print_log('Analyzer version: '||g_rep_info('File Version'));
  ELSE
    print_log('Host: '||g_rep_info('Host'));
    print_log('FullHost: '||g_rep_info('FullHost'));
    print_log('Instance: '||g_rep_info('Instance'));
    print_log('Database version: '||g_rep_info('DB Version'));
    print_log('Applications version: '||g_rep_info('Apps Version'));
    print_log('Analyzer version: '||g_rep_info('File Version'));
  END IF;
debug('begin Additional Code: Additional Validation');
select count(request_id) into l_item_cnt from fnd_concurrent_requests where phase_code='C';
SELECT q.CONCURRENT_QUEUE_NAME "Short Name",  q.enabled_flag "Enabled", q.cache_size
into l_std_mgr, l_enabled, l_cache
from apps.fnd_concurrent_queues_vl q
where q.CONCURRENT_QUEUE_NAME = 'STANDARD';
select decode(process_status_code,
 'A', 'Active','C', 'Connecting','D', 'Deactiviating','G', 'Awaiting Discovery','K', 'Terminated','M', 'Migrating','P', 'Suspended','R', 'Running','S', 'Deactivated','T', 'Terminating','U', 'Unreachable','Z', 'Initializing'), node_name, process_start_date, logfile_name, last_update_date
 into l_cp_status, l_nodename, l_cp_start_date, l_logfile_name, l_last_update_date
 from fnd_concurrent_processes
 where concurrent_process_id = (select max(p.CONCURRENT_PROCESS_ID)
 from fnd_concurrent_processes p, fnd_concurrent_queues u
 WHERE p.concurrent_queue_id = u.concurrent_queue_id
 AND   p.queue_application_id = u.application_id
 AND   u.concurrent_queue_name = 'FNDICM');
select count(*) into l_apps_invalid_cnt
from dba_objects where status='INVALID'
and owner in ('APPS','APPLSYS','APPLSYSPUB','CTXSYS','PUBLIC','SYS','SYSTEM');
select count(*) into l_fnd_invalid_cnt from dba_objects
where object_name like 'FND%'
and owner in ('APPS','APPLSYS')
and status='INVALID';
select ad_patch.is_patch_applied('11i',-1,3240000) into l_CU1 from dual;
select ad_patch.is_patch_applied('11i',-1,3460000) into l_CU2 from dual;
select ad_patch.is_patch_applied('11i',-1,6435000) into l_RUP4 from dual;
select ad_patch.is_patch_applied('11i',-1,6728000) into l_RUP6 from dual;
select count(p.concurrent_program_name) into l_run_alone_cnt
from fnd_concurrent_programs p
where p.run_alone_flag = 'Y'
and p.enabled_flag = 'Y';
select count(p.concurrent_program_name) into l_run_alone_now_cnt
FROM fnd_concurrent_programs_tl t,
fnd_concurrent_programs p, fnd_application_tl a,
fnd_concurrent_requests r, fnd_languages l,
fnd_user u
WHERE a.application_id = t.application_id
and r.concurrent_program_id = t.concurrent_program_id
and t.concurrent_program_id = p.concurrent_program_id
AND r.nls_language = l.nls_language
AND l.language_code = t.language
AND l.language_code = a.language
AND r.requested_by = u.user_id
and p.run_alone_flag = 'Y';
g_reqid_cnt := l_item_cnt;
g_cp_status := l_cp_status;
g_nodename := l_nodename;
g_cp_start_date := l_cp_start_date;
g_logfile_name := l_logfile_name;
g_last_update_date := l_last_update_date;
g_apps_invalid_cnt := l_apps_invalid_cnt;
g_CU1 := l_CU1;
g_CU2 := l_CU2;
g_RUP4 := l_RUP4;
g_RUP6 := l_RUP6;
g_run_alone_cnt := l_run_alone_cnt;
g_run_alone_now_cnt := l_run_alone_now_cnt;
g_std_mgr :=  l_std_mgr;
g_enabled :=  l_enabled;
g_cache := l_cache;
g_min_vol := p_min_volume;
g_max_vol := p_max_volume;
print_log('l_CU1 = '||l_CU1);
print_log('l_CU2 = '||l_CU2);
print_log('g_RUP4 = '||g_RUP4);
print_log('g_RUP6 = '||g_RUP6);
debug('end Additional Code: Additional Validation');

  -- Create global hash for parameters. Numbers required for the output order
debug('begin populate parameters hash table');
   g_parameters.extend();
   g_parameters(g_parameters.LAST).pname := 'Minimum acceptable volume of Concurrent Request data';
   g_parameters(g_parameters.LAST).pvalue := p_min_volume;
   g_parameters.extend();
   g_parameters(g_parameters.LAST).pname := 'Maximum acceptable volume of Concurrent Request data';
   g_parameters(g_parameters.LAST).pvalue := p_max_volume;
   g_parameters.extend();
   g_parameters(g_parameters.LAST).pname := 'Maximum Rows to Display';
   g_parameters(g_parameters.LAST).pvalue := p_max_output_rows;
   g_parameters.extend();
   g_parameters(g_parameters.LAST).pname := 'Debug Mode';
   g_parameters(g_parameters.LAST).pvalue := p_debug_mode;
debug('end populate parameters hash table');

  -- Print parameters to the log
  print_log('Parameter Values');
  FOR i IN 1..g_parameters.COUNT LOOP
    print_log(to_char(i) || '. ' || g_parameters(i).pname || ': ' || g_parameters(i).pvalue);
  END LOOP;
 
  -- Create global hash of SQL token values
debug('begin populate sql tokens hash table');
debug('end populate sql tokens hash table');

  l_key := g_sql_tokens.first;
  -- Print token values to the log
  print_log('SQL Token Values');
  WHILE l_key IS NOT NULL LOOP
    print_log(l_key||': '|| g_sql_tokens(l_key));
    l_key := g_sql_tokens.next(l_key);
  END LOOP;
EXCEPTION
  WHEN INVALID_PARAMETERS THEN
    print_log('Invalid parameters provided. Process cannot continue.');
    raise;
  WHEN OTHERS THEN
    print_log('Error validating parameters: '||sqlerrm);
    raise;
END validate_parameters;

---------------------------------------------
-- Load signatures for this ANALYZER       --
---------------------------------------------
PROCEDURE load_signatures IS
  l_info  HASH_TBL_4K;
BEGIN
null;
   -----------------------------------------
  -- Add definition of signatures here ....
  ------------------------------------------

debug('begin add_signature: CP2_LONGRPTS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_LONGRPTS',
      p_sig_sql                => 'SELECT p.user_concurrent_program_name program_name, count(r.request_id),
          avg((nvl(r.actual_completion_date,sysdate) - r.actual_start_date) * 1440) avg_run_time,
          min((nvl(r.actual_completion_date,sysdate) - r.actual_start_date) * 1440) min_run_time,
          max((nvl(r.actual_completion_date,sysdate) - r.actual_start_date) * 1440) max_run_time
          from apps.fnd_concurrent_requests r, apps.fnd_concurrent_processes c, apps.fnd_concurrent_queues q,
          apps.fnd_concurrent_programs_vl p
          where p.concurrent_program_id = r.concurrent_program_id and p.application_id = r.program_application_id
          and c.concurrent_process_id = r.controlling_manager and q.concurrent_queue_id = c.concurrent_queue_id
          and q.concurrent_queue_name <> ''HIGH_IMPACT''and p.application_id >= 20000 and r.actual_start_date >= sysdate-31
          and r.status_code = ''C'' and r.phase_code in (''C'',''G'')
          and (nvl(r.actual_completion_date,r.actual_start_date) - r.actual_start_date) * 24 * 60 > 30
          and p.user_concurrent_program_name not like ''Gather%Statistics%''
          and ((nvl(r.actual_completion_date,r.actual_start_date) - r.actual_start_date) * 24 > 16
          or (r.actual_start_date-trunc(r.actual_start_date)) * 24 between 9 and 17
          or (r.actual_completion_date-trunc(r.actual_completion_date)) * 24 between 9 and 17)
          group by p.user_concurrent_program_name
          order by avg((nvl(r.actual_completion_date,sysdate) - r.actual_start_date) * 1440) desc',
      p_title                  => 'Long Running Reports During Business Hours',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'You have Long Running Reports During Business Hours',
      p_solution               => 'Review the requests listed and confirm if they are intended to run for longer amounts of time.<br>
 If the wrong date range is used or a large volume of data exists for the request, a longer run time can be expected.<br>
Monthly, Quarterly, and Yearly requests would typically run longer.<br><br>
Visit the Concurrent Processing Product Information Center (PIC) [1304305.1] for additional performance and setup documentation.',
      p_success_msg            => 'There does not appear to be any long running requests during business hours.<br>
The intent is to proactively identify requests which could represent potential performance problems.<br><br>
Visit the Concurrent Processing Product Information Center (PIC) [1304305.1] for additional performance and setup documentation.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_LONGRPTS');

debug('begin add_signature: CP1_ENV1');
  add_signature(
      p_sig_id                 => 'CP1_ENV1',
      p_sig_sql                => 'select VARIABLE_NAME, replace(value,'':'',chr(10)) "VALUE"
from FND_ENV_CONTEXT
where CONCURRENT_PROCESS_ID = (select max(p.CONCURRENT_PROCESS_ID)
from fnd_concurrent_processes p, fnd_concurrent_queues u
WHERE p.concurrent_queue_id = u.concurrent_queue_id
AND   p.queue_application_id = u.application_id
AND   u.concurrent_queue_name = ''FNDICM'')
and VARIABLE_NAME in (''APPLLKOR'',''AF_CLASSPATH'',''AF_JLIB'',''AF_JRE_TOP'',
''AF_LD_LIBRARY_PATH'',''AFJSMARG'',''AFJVAPRG'',''APPLCSF'',''APPLDCP'',
''APPLFENV'',''APPLLOG'',''APPLORB'',''APPLORC'',''APPLOUT'',''APPLPTMP'',
''APPLTMP'',''APPS_JDBC_URL'',''CA_FILEIO_64'',''CLASSPATH'',
''CONTEXT_FILE'',''CONTEXT_NAME'',''DE_DISABLE_PLS_512'',''DISPLAY'',
''EVENT_10932'',''FND_TOP'',''FNDNAM'',''FNDSM_SCRIPT'',''HOSTNAME'',
''LD_LIBRARY_PATH'',''NLS_LANG'',''NLS_NUMERIC_CHARACTERS'',
''ORACLE_HOME'',''PLATFORM'',''PRINTER'',''REPORTS60_PATH'',
''REPORTS_CLASSPATH'',''REPORTS_NO_DUMMY_PRINTER'',''REPORTS_PATH'',
''REPORTS_POST'',''REPORTS_PRE'',''REPORTS_TMP'',''TK_PRINT_STATUS'',
''TK_PRINTER'',''TNS_ADMIN'',''TWO_TASK'',''XDO_TOP'',''XENVIRONMENT'')
order by VARIABLE_NAME',
      p_title                  => 'Concurrent Processing Environment Variables',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is a problem identifying the Concurrent Processing Environment Variables',
      p_solution               => 'Verify the Concurrent Processing Environment Variables',
      p_success_msg            => 'The Internal Concurrent Manager (ICM) for '||g_nodename||' is "'||g_cp_status||'", and has been running since '||g_cp_start_date||'.<br>
   The current Concurrent Manager logs are found :<br>
   '||g_logfile_name||'.<br><br>
   Refer to [1355735.1] - Difference between APPLPTMP and APPLTMP Directories in EBS',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_ENV1');

debug('begin add_signature: CP2_ELAPSEDHIST');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_ELAPSEDHIST',
      p_sig_sql                => 'SELECT f.application_short_name "APPLICATION", substr(p.user_concurrent_program_name,1,55) "DESCRIPTION",
substr(p.concurrent_program_name,1,20) "PROGRAM", r.priority "PRIORITY",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "#TIMESRUN",
''<div align="right">''||to_char(round(sum(actual_completion_date - actual_start_date) * 1440, 2),''999,999,999,999.99'')||''</div>'' "TOTAL|MINS",
''<div align="right">''||to_char(round(avg(actual_completion_date - actual_start_date) * 1440, 2),''999,999,999,999.99'')||''</div>'' "AVG|MINS",
''<div align="right">''||to_char(round(max(actual_completion_date - actual_start_date) * 1440, 2),''999,999,999,999.99'')||''</div>'' "MAX|MINS",
''<div align="right">''||to_char(round(min(actual_completion_date - actual_start_date) * 1440, 2),''999,999,999,999.99'')||''</div>'' "MIN|MINS",
''<div align="right">''||to_char(round(stddev(actual_completion_date - actual_start_date) * 1440, 2),''999,999,999,999.99'')||''</div>'' "RUN|STHDEV MINS",
''<div align="right">''||to_char(round(stddev(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 1440, 2),''999,999,999,999.99'')||''</div>'' "WAIT|STHDEV MINS",
''<div align="right">''||to_char(round(sum(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 1440, 2),''999,999,999,999.99'')||''</div>'' "#WAITED|MINS",
''<div align="right">''||to_char(round(avg(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 1440, 2),''999,999,999,999.99'')||''</div>'' "AVG|WAIT MINS",
c.request_class_name "TYPE"
from apps.fnd_concurrent_request_class c, apps.fnd_application f, apps.fnd_concurrent_programs_vl p,
apps.fnd_concurrent_requests r
where r.program_application_id = p.application_id and r.concurrent_program_id = p.concurrent_program_id
and r.status_code in (''C'',''G'') and r.phase_code = ''C'' and p.application_id = f.application_id
and r.program_application_id = f.application_id and r.request_class_application_id = c.application_id(+)
and r.concurrent_request_class_id = c.request_class_id(+)
group by c.request_class_name, f.application_short_name, p.concurrent_program_name, p.user_concurrent_program_name, r.priority
order by count(*)',
      p_title                  => 'Elapsed Time History of Concurrent Requests',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'This section identifies the total time duration for recently completed requests.',
      p_solution               => 'The output produced can be cross referenced with the enabled managers and defined workshifts outputs,
 for better allocation of requests across the existing managers/workshifts. <br>
 For example you can consider assigning quick requests to one manager and/or workshift, and assigning slow requests to another manager and/or workshift. <br>
 Requests with varying runtimes can also be moved to their own manager, or remain with the standard manager queue.',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_ELAPSEDHIST');


debug('begin add_signature: CP4_STD_MGR_ENV');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_ENV',
      p_sig_sql                => 'SELECT q.USER_CONCURRENT_QUEUE_NAME "Manager", a.application_name, v.VARIABLE, v.VALUE
FROM apps.fnd_concurrent_queues_vl q, apps.fnd_application_vl a, FND_CONC_QUEUE_ENVIRON v
WHERE a.application_id  = q.application_id
and q.CONCURRENT_QUEUE_NAME = ''STANDARD''
and a.application_id = v.CONCURRENT_QUEUE_ID(+)',
      p_title                  => 'Environment',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'Standard Manager is not found.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed
with a "Included" Specialization" rule--"Excluded" is ok.
(Responsibility = System Administrator, Navigate --> Concurrent:
Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.
',
      p_success_msg            => 'Standard Manager is running as expected.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_ENV');

debug('begin add_signature: CP4_STD_MGR_RULES');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_RULES',
      p_sig_sql                => 'select decode(c.include_flag,''E'',''Exclude'',''I'',''Include'') "INCLUDE_FLAG",
decode (c.type_code,''C'',''Combined Rule'',''L'',''Logical DB'',
''O'',''Oracle ID'',''P'',''Program'',''R'',''Request Type'',''U'',''User'') "TYPE_CODE",
a.application_name, t.user_concurrent_program_name
from fnd_concurrent_queue_content c, fnd_concurrent_programs p,
fnd_concurrent_programs_tl t, fnd_application_tl a
where c.concurrent_queue_id = 0
and c.type_application_id = p.application_id
and c.type_id = p.concurrent_program_id
and p.application_id = a.application_id
and t.concurrent_program_id = p.concurrent_program_id
and a.language=t.language',
      p_title                  => 'Specialization Rules',
      p_fail_condition         => '[c.include_flag]=[I]',
      p_problem_descr          => 'Standard Manager has INCLUDES.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed
with a "Included" Specialization" rule--"Excluded" is ok.
(Responsibility = System Administrator, Navigate --> Concurrent:
Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.
',
      p_success_msg            => 'Standard Manager is running as expected.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('E','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_RULES');

debug('begin add_signature: CP4_STD_MGR_WRK_SHIFTS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_WRK_SHIFTS',
      p_sig_sql                => 'SELECT q.USER_CONCURRENT_QUEUE_NAME "Manager", a.application_name,
p.concurrent_time_period_name "Work Shift", p.description "Description",
qs.min_processes "Processes", qs.service_parameters "Parameter", qs.sleep_seconds "Sleep Seconds"
from apps.fnd_concurrent_queues_vl q, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where a.application_id = q.application_id
and qs.queue_application_id = q.application_id
and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id
and qs.concurrent_time_period_id = p.concurrent_time_period_id
and q.enabled_flag = ''Y''
and nvl(q.control_code,''X'') <> ''E''
and q.CONCURRENT_QUEUE_NAME = ''STANDARD''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Work Shifts',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'Standard Manager is not found.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed
with a "Included" Specialization" rule--"Excluded" is ok.
(Responsibility = System Administrator, Navigate --> Concurrent:
Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.
',
      p_success_msg            => 'Standard Manager is running as expected.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('E','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_WRK_SHIFTS');
debug('begin add_signature: CP4_STD_MGR_DEFINE_R12');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_DEFINE_R12',
      p_sig_sql                => 'SELECT q.USER_CONCURRENT_QUEUE_NAME "Manager", q.CONCURRENT_QUEUE_NAME "Short Name",  q.enabled_flag "Enabled",
a.application_name "Application Name", q.description "Description", decode(q.manager_type,''0'',''Internal Concurrent Manager'',''1'',''Concurrent Manager'', ''2'',''Internal Monitor'', ''3'',''Transaction Manager'', ''4'',''Conflict Resolution Manager'',''5'',''Scheduler/Prereleaser Manager'', ''6'',''Service Manager'') "TYPE", q.DATA_GROUP_ID "Data Group", q.RESOURCE_CONSUMER_GROUP "Consumer Group",
q.cache_size,  q.node_name "Primary Node", q.os_queue "Primary System Queue",
q.node_name2 "Second Node", q.os_queue2 "Second System Queue"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id
and a.application_id = q.application_id
and qs.queue_application_id = q.application_id
and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id
and qs.concurrent_time_period_id = p.concurrent_time_period_id
and nvl(q.control_code,''X'') <> ''E''
and q.CONCURRENT_QUEUE_NAME = ''STANDARD''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Standard Manager Definition',
      p_fail_condition         => '[q.enabled_flag] <> [Y]',
      p_problem_descr          => 'Standard Manager is not enabled.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed with a "Included" Specialization" rule<br>
"Excluded" is ok. <br>
(Responsibility = System Administrator, Navigate --> Concurrent: Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.<br><br>
As per the Oracle E-Business Suite System Administrator''s Guide - Configuration:
"A manager named Standard. The Standard manager accepts any and all requests; it has no specialization. The Standard manager is active all the time; it works 365 days a year, 24 hours a day.<br>
<b>ATTENTION:</b> You should not alter the definition of the Standard concurrent manager. If you do, and you have not defined additional managers to accept your requests, some programs may not run. Use the Standard manager as a safety net, a manager who is always available to run any request. Define additional managers to handle your installation site''s specific needs."',
      p_success_msg            => 'Standard Manager is running as expected.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL('CP4_STD_MGR_ENV','CP4_STD_MGR_RULES','CP4_STD_MGR_WRK_SHIFTS'),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_DEFINE_R12');

debug('begin add_signature: CP1_CONC_REQ1');
  add_signature(
      p_sig_id                 => 'CP1_CONC_REQ1',
      p_sig_sql                => 'select ''FND_CONCURRENT_REQUESTS'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONCURRENT_REQUESTS
union
select ''FND_RUN_REQUESTS'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_RUN_REQUESTS
union
select ''FND_CONC_REQUEST_ARGUMENTS'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONC_REQUEST_ARGUMENTS
union
select ''FND_DUAL'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_DUAL
union
select ''FND_CONCURRENT_PROCESSES'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONCURRENT_PROCESSES
union
select ''FND_CONC_STAT_LIST'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONC_STAT_LIST
union
select ''FND_CONC_STAT_SUMMARY'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONC_STAT_SUMMARY
union
select ''FND_ENV_CONTEXT'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_ENV_CONTEXT
union
select ''FND_CONC_PP_ACTIONS'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_CONC_PP_ACTIONS
union
select ''FND_RUN_REQ_PP_ACTIONS'' "TABLE", ''<div align="right">''||to_char(max(rownum),''999,999,999,999'')||''</div>'' "# ROWS" from FND_RUN_REQ_PP_ACTIONS',
      p_title                  => 'Your overall Concurrent Processing HealthCheck Status is in need of Immediate Review!',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The FND_CONCURRENT_REQUESTS Table has '||to_char(g_reqid_cnt,'999,999,999,999')||' rows of completed runtime data which exceeds the acceptable thresholds that were entered to run this Analyzer.<BR><BR>
    This Gauge is merely a simple indicator about volume of completed Concurrent Request runtime data on '||g_rep_info('Instance')||', which can be adjusted when running this Analyzer.<br>
    It displays GREEN if less than '||to_char(g_min_vol,'999,999,999,999')||' rows are found, ORANGE if less than '||to_char(g_max_vol,'999,999,999,999')||', and RED if over '||to_char(g_max_vol,'999,999,999,999')||' rows are found.',
      p_solution               => 'Clean up Concurrent Request Data and move the needle to green by scheduling the <b>FNDCPPUR - <i>Purge Concurrent Request and/or Manager Data</i></b> on a regular basis.
   <br><br>
Run these queries to gather more details about all old requests<br>
<blockquote>
<table width="100%" border="0">
  <tr>
    <td width="3%" valign="top">
    <div id="divImg5"><input type="button" id="detailImg5" onClick="showDetails(5);" value="+"></input></div>
    </td>
    <td width="97%">Show Summary of counts By Year
      <div style="display:none; width: 90%" id="detailTxt5">
  <blockquote>
   select to_char(actual_start_date,''YYYY'') "STARTED", to_char(actual_completion_date,''YYYY'') "ENDED", <br>
   count(request_id) "COUNT" <br>
   from fnd_concurrent_requests <br>
   where actual_start_date < sysdate-365      --Show Requests started over 1 year ago<br>
   group by to_char(actual_start_date,''YYYY''), to_char(actual_completion_date,''YYYY'')<br>
   order by 1;
  </blockquote>
</div></td>
  </tr>
  <tr>
    <td width="3%" valign="top">
    <div id="divImg5"><input type="button" id="detailImg11" onClick="showDetails(11);" value="+"></input></div>
    </td>
    <td width="97%">Show Summary of counts by Concurrent Program
        <div style="display:none; width: 90%" id="detailTxt11">
  <blockquote>
   select fcp.USER_CONCURRENT_PROGRAM_NAME, to_char(r.actual_start_date,''YYYY'') "STARTED",<br> to_char(r.actual_completion_date,''YYYY'') "ENDED", count(r.request_id) "COUNT" <br>
   from fnd_concurrent_requests r, fnd_concurrent_programs_tl fcp<br>
   where r.concurrent_program_id = fcp.concurrent_program_id<br>
   and r.actual_start_date < sysdate-365      --Show Requests started over 1 year ago<br>
   group by fcp.USER_CONCURRENT_PROGRAM_NAME, to_char(r.actual_start_date,''YYYY''),
   to_char(r.actual_completion_date,''YYYY'')<br>
   order by 2;
  </blockquote>
</div></td>
  </tr> 
</table>
</blockquote>
    For more information please review: <br>
 [104282.1] - Concurrent Processing - Purge Concurrent Request and/or Manager Data Program (FNDCPPUR)<br>
 [1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite
 ',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_CONC_REQ1');

debug('begin add_signature: CP3_CPADV1');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV1',
      p_sig_sql                => 'SELECT q.CONCURRENT_QUEUE_NAME "QUEUE NAME", q.USER_CONCURRENT_QUEUE_NAME "USER QUEUE NAME", 
a.application_short_name "MODULE", q.cache_size "CACHE", p.concurrent_time_period_name "TIME PERIOD",
qs.min_processes "MIN PROCESSES", qs.max_processes "MAX PROCESSES", qs.sleep_seconds "SLEEP SECS"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id
and a.application_id = q.application_id
and qs.queue_application_id = q.application_id
and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id
and qs.concurrent_time_period_id = p.concurrent_time_period_id
and q.enabled_flag = ''Y''
and nvl(q.control_code,''X'') <> ''E''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Concurrent Managers Active/Enabled and Workshifts',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Concurrent Managers Active/Enabled and Workshifts',
      p_solution               => 'This section collects the Concurrent Managers that are currently Active and Enabled to process data, and associated with a specific Workshift, and establishes a baseline list of managers defined on your system.
 The Workshifts are created to define specific times when a Manager can run requests.<br>
 The resulting data is for review and confirmation by your teams, and serves as a baseline for comparison with later outputs above. <br>
    Otherwise there is no immediate action required.<br><br>
 For more information refer to [1373727.1] - FAQ: EBS Concurrent processing Performance and Best Practices.',
      p_success_msg            => 'This section collects the Concurrent Managers that are currently Active and Enabled to process data, and associated with a specific Workshift, and establishes a baseline list of managers defined on your system.
 The Workshifts are created to define specific times when a Manager can run requests.<br>
 The resulting data is for review and confirmation by your teams, and serves as a baseline for comparison with later outputs above. <br>
    Otherwise there is no immediate action required.<br><br>
 For more information refer to [1373727.1] - FAQ: EBS Concurrent processing Performance and Best Practices.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV1');

debug('begin add_signature: CP4_STD_MGR_DEFINE_11I');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_DEFINE_11I',
      p_sig_sql                => 'SELECT q.USER_CONCURRENT_QUEUE_NAME "MANAGER", q.CONCURRENT_QUEUE_NAME "SHORT NAME",  q.enabled_flag "ENABLED",
a.application_name "APPLICATION NAME", q.description "DESCRIPTION", decode(q.manager_type,''0'',''Internal Concurrent Manager'',''1'',''Concurrent Manager'', ''2'',''Internal Monitor'', ''3'',''Transaction Manager'', ''4'',''Conflict Resolution Manager'',''5'',''Scheduler/Prereleaser Manager'', ''6'',''Service Manager'') "TYPE", q.DATA_GROUP_ID "DATA GROUP", q.RESOURCE_CONSUMER_GROUP "CONSUMER GROUP",
q.cache_size "CACHE SIZE",  q.node_name "PRIMARY NODE", q.os_queue "PRIMARY SYSTEM QUEUE",
q.node_name2 "2ND NODE", q.os_queue2 "2ND SYSTEM QUEUE"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id
and a.application_id = q.application_id
and qs.queue_application_id = q.application_id
and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id
and qs.concurrent_time_period_id = p.concurrent_time_period_id
and nvl(q.control_code,''X'') <> ''E''
and q.CONCURRENT_QUEUE_NAME = ''STANDARD''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Standard Manager Definition',
      p_fail_condition         => '[q.enabled_flag] <> [Y]',
      p_problem_descr          => 'Standard Manager is not enabled.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed with a "Included" Specialization" rule<br>
"Excluded" is ok. <br>
(Responsibility = System Administrator, Navigate --> Concurrent: Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.<br><br>
As per the Oracle E-Business Suite System Administrator''s Guide - Configuration:
"A manager named Standard. The Standard manager accepts any and all requests; it has no specialization. The Standard manager is active all the time; it works 365 days a year, 24 hours a day.<br>
<b>ATTENTION:</b> You should not alter the definition of the Standard concurrent manager. If you do, and you have not defined additional managers to accept your requests, some programs may not run. Use the Standard manager as a safety net, a manager who is always available to run any request. Define additional managers to handle your installation site''s specific needs."',
      p_success_msg            => 'Standard Manager is running as expected.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL('CP4_STD_MGR_RULES','CP4_STD_MGR_WRK_SHIFTS'),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_DEFINE_11I');

debug('begin add_signature: CP3_CPADV2');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV2',
      p_sig_sql                => 'SELECT f.concurrent_queue_name, f.concurrent_queue_id "CONC QUEUE ID",
f.user_concurrent_queue_name "QUEUE NAME", f.max_processes "MAX", f.running_processes "RUNNING",
DECODE(f.control_code, ''B'',''B=Activated'',''A'',''A=Activating'',''E'',''E=Deactivated'',
''D'',''D=Deactivating'',''R'',''R=Restarting'',''Q'',''Q=Resuming Concurrent Manager'',
''P'',''P=Suspended'',''O'',''O=Suspending Concurrent Manager'',
''H'',''H=System Hold, Fix Manager before resetting counters'',
''N'',''N=Target node/queue unavailable'',''X'',''X=Terminated'',
''T'',''T=Terminating'',''U'',''U=Updating Environment Information'',''V'',''V=Verifying'') "CONTROL CODE",
f.target_node "ACTUAL NODE", f.enabled_flag "ENABLED",
to_char(f.last_update_date,''DD-MON-RR HH24:MI:SS'') "LAST_UPDATE_DATE",
f.node_name "PRIMARY NODE", f.node_name2 "SECONDARY NODE"
FROM fnd_concurrent_queues_vl f
where f.enabled_flag = ''Y''
order by f.application_id, f.concurrent_queue_id',
      p_title                  => 'Concurrent Managers Active/Enabled Overview',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Concurrent Managers which are Active or Enabled',
      p_solution               => 'Review the fnd_concurrent_queues_vl view table',
      p_success_msg            => 'Displays a list of Active Managers',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV2');

debug('begin add_signature: CP1_ORPHANED_PURGE_DATA');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_ORPHANED_PURGE_DATA',
      p_sig_sql                => 'select ''FND_CONC_REQUEST_ARGUMENTS'' TABLE_NAME,
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT OF ORPHANED REQUEST_IDS" from fnd_conc_request_arguments
  where request_id in ((select request_id from fnd_conc_request_arguments)
                  minus (select request_id from fnd_concurrent_requests))
union
  select ''FND_CONC_PP_ACTIONS'' TABLE_NAME,
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT OF ORPHANED REQUEST_IDS" from fnd_conc_pp_actions
  where concurrent_request_id in ((select concurrent_request_id from fnd_conc_pp_actions))',
      p_title                  => 'Orphaned Purge Concurrent Data',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are orphaned concurrent request records found that will not be purged using the concurrent program (FNDCPPUR) - Purge Concurrent Request and/or Manager Data.
',
      p_solution               => 'This data must have been manually purged but did not include all associated tables which cause the orphaned records identified.<br><br>
To correct the problem deleting FND_CONCURRENT_PROCESSES can cause,
the following SQL Statement may be run on the database:<blockquote>
  delete from fnd_conc_request_arguments
  where request_id in ((select request_id from fnd_conc_request_arguments)
                  minus (select request_id from fnd_concurrent_requests));<br><br>
  delete from fnd_conc_pp_actions
  where concurrent_request_id in ((select concurrent_request_id from fnd_conc_pp_actions)
                  minus (select request_id from fnd_concurrent_requests));
</blockquote>
For more details, please review :<br>
[104282.1] - Concurrent Processing - Purge Concurrent Request and/or Manager Data Program (FNDCPPUR)',
      p_success_msg            => 'No Orphaned Concurrent Request Data found.',
      p_print_condition        => nvl('FAILURE','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_ORPHANED_PURGE_DATA');

debug('begin add_signature: CP2_CURRENTREQS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_CURRENTREQS',
      p_sig_sql                => 'SELECT w.seconds_in_wait "Secondswait", w.event "waitEvent", w.p1||chr(10)||w.p2||chr(10)||w.p3 "Session Wait",
p.spid||chr(10)||s.process "ServerClient", s.sid||chr(10)||s.serial#||chr(10)||s.sql_hash_value "SidSerialSQLHash",
u.user_name||chr(10)||PHASE_CODE||'' ''||STATUS_CODE||chr(10)||s.status "DBPhaseStatusCODEUser",
Request_id||chr(10)||priority_request_id||chr(10)||Parent_request_id "Request_id",
concurrent_program_name, user_concurrent_program_name,
requested_start_Date||chr(10)||round((sysdate- requested_start_date)*1440, 2)||''M'' "RequestStartDate",
ARGUMENT_TEXT, CONCURRENT_QUEUE_ID, QUEUE_DESCRIPTION
FROM FND_CONCURRENT_WORKER_REQUESTS, fnd_user u, v$session s, v$process p, v$session_wait w
WHERE (Phase_Code=''R'')and hold_flag != ''Y''and Requested_Start_Date <= SYSDATE
AND ('''' IS NULL OR ('''' = ''B'' AND PHASE_CODE = ''R'' AND STATUS_CODE IN (''I'', ''Q'')))and ''1'' in (0,1,4)
and requested_by=u.user_id and s.paddr=p.addr and s.sid=w.sid and oracle_process_id = p.spid
and oracle_session_id = s.audsid
order by requested_start_date',
      p_title                  => 'Requests Currently Running on a System',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Concurrent Requests currently Running on this instance.',
      p_solution               => 'This table reflects a summary for all concurrent requests running on the instance with their current state.',
      p_success_msg            => 'This reflects a summary for all concurrent requests running on the instance with their current state.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_CURRENTREQS');

debug('begin add_signature: EBS_VERSION');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'EBS_VERSION',
      p_sig_sql                => 'SELECT instance_name, release_name, host_name,
          startup_time, version
          from fnd_product_groups, v$instance',
      p_title                  => 'E-Business Suite Version',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is a problem identifying the EBS Instance Information',
      p_solution               => '',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: EBS_VERSION');

debug('begin add_signature: CP4_STD_MGR_DEFINE_CACHE');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_DEFINE_CACHE',
      p_sig_sql                => 'SELECT q.USER_CONCURRENT_QUEUE_NAME "MANAGER", q.CONCURRENT_QUEUE_NAME "SHORT NAME",  q.enabled_flag "ENABLED",
a.application_name "APPLICATION", q.description "DESCRIPTION", decode(q.manager_type,''0'',''Internal Concurrent Manager'',''1'',''Concurrent Manager'', ''2'',''Internal Monitor'', ''3'',''Transaction Manager'', ''4'',''Conflict Resolution Manager'',''5'',''Scheduler/Prereleaser Manager'', ''6'',''Service Manager'') "TYPE", q.DATA_GROUP_ID "DATA GROUP", q.RESOURCE_CONSUMER_GROUP "CONSUMER GROUP",
q.cache_size "CACHE SIZE",  q.node_name "PRIMARY NODE", q.os_queue "PRIMARY SYSTEM QUEUE",
q.node_name2 "2ND NODE", q.os_queue2 "2ND SYSTEM QUEUE"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id
and a.application_id = q.application_id
and qs.queue_application_id = q.application_id
and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id
and qs.concurrent_time_period_id = p.concurrent_time_period_id
and nvl(q.control_code,''X'') <> ''E''
and q.CONCURRENT_QUEUE_NAME = ''STANDARD''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Standard Manager Cache Size',
      p_fail_condition         => '[q.cache_size] > [5]',
      p_problem_descr          => 'Standard Manager Cache Size is set to '||g_cache||'.',
      p_solution               => 'By setting the cache size at a higher number, the concurrent manager does not have to read its requests list each time it runs a request.<br>However, the manager does not recognize any priority changes you make for a particular request if it has already read that request into its cache. Further, even if you give a higher priority to a new request, that new request must wait until the buffer is empty and the manager returns to look at the requests list. That request may have to wait a long time if you set the buffer size to a high number.<br><br>
You should use cache size to tune your concurrent managers to work most efficiently for you site''s needs. If your organization tends to reprioritize jobs going to a certain manager, that manager should have its buffer size set fairly low.<br><br>
<b>Tip:</b> Enter a value of 1 when defining a manager that runs long, time-consuming jobs, and a value of 3 or 4 for managers that run small, quick jobs."',
      p_success_msg            => 'Standard Manager Cache Size is set to '||g_cache||'.
<br><br>
According to the "Oracle Applications System Administrator''s Guide - Configuration" Defining Concurrent Managers section : <br>
Release 12 (Part No. B31453-04)<br>
Release 11i (Part No. B13925-06)<br><br>
"Cache Size (Concurrent Manager only)<br>
Enter the number of requests your manager remembers each time it reads which requests to run. For example, if a manager''s workshift has 1 target process and a cache value of 3, it will read three requests and wait until these three requests have been run before reading new requests.
<br><br>
In reading requests, the manager will only put requests it is allowed to run into its cache. For example, if you have defined your manager to run only Order Entry reports then the manager will put only Order Entry requests into its cache.
<br><br>
If you enter 1, the concurrent manager must look at its requests list each time it is ready to process another request.
',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_DEFINE_CACHE');

debug('begin add_signature: CP1_CONC_REQ2');
  add_signature(
      p_sig_id                 => 'CP1_CONC_REQ2',
      p_sig_sql                => 'select to_char(actual_completion_date,''YYYY'') "COMPLETED",
''<div align="right">''||to_char(count(request_id),''999,999,999,999'')||''</div>'' "COUNT"
  from fnd_concurrent_requests where phase_code=''C''
  group by to_char(actual_completion_date,''YYYY'')
  order by to_char(actual_completion_date,''YYYY'') desc',
      p_title                  => 'Your overall Concurrent Processing HealthCheck Status is in need of Review!',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The FND_CONCURRENT_REQUESTS Table has '||to_char(g_reqid_cnt,'999,999,999,999')||' rows of completed runtime data which is above the minimum, but below the maximum acceptable thresholds that were entered to run this Analyzer.<BR><BR>
    This Gauge is merely a simple indicator about volume of completed Concurrent Request runtime data on '||g_rep_info('Instance')||', which can be adjusted when running this Analyzer.<br>
    It displays GREEN if less than '||to_char(g_min_vol,'999,999,999,999')||' rows are found, ORANGE if less than '||to_char(g_max_vol,'999,999,999,999')||', and RED if over '||to_char(g_max_vol,'999,999,999,999')||' rows are found.',
      p_solution               => 'Clean up Concurrent Request Data and move the needle to green by scheduling the <b>FNDCPPUR - <i>Purge Concurrent Request and/or Manager Data</i></b> on a regular basis.
   <br><br>
Run these queries to gather more details about your old requests<br>
<blockquote>
<table width="100%" border="0">
  <tr>
    <td width="3%" valign="top">
    <div id="divImg5"><input type="button" id="detailImg5" onClick="showDetails(5);" value="+"></input></div>
    </td>
    <td width="97%">Show Summary of counts By Year
      <div style="display:none; width: 90%" id="detailTxt5">
  <blockquote>
   select to_char(actual_start_date,''YYYY'') "STARTED", to_char(actual_completion_date,''YYYY'') "ENDED", <br>
   count(request_id) "COUNT" <br>
   from fnd_concurrent_requests <br>
   where actual_start_date < sysdate-365      --Show Requests started over 1 year ago<br>
   group by to_char(actual_start_date,''YYYY''), to_char(actual_completion_date,''YYYY'')<br>
   order by 1;
  </blockquote>
</div></td>
  </tr>
  <tr>
    <td width="3%" valign="top">
    <div id="divImg5"><input type="button" id="detailImg11" onClick="showDetails(11);" value="+"></input></div>
    </td>
    <td width="97%">Show Summary of counts by Concurrent Program
        <div style="display:none; width: 90%" id="detailTxt11">
  <blockquote>
   select fcp.USER_CONCURRENT_PROGRAM_NAME, to_char(r.actual_start_date,''YYYY'') "STARTED",<br> to_char(r.actual_completion_date,''YYYY'') "ENDED", count(r.request_id) "COUNT" <br>
   from fnd_concurrent_requests r, fnd_concurrent_programs_tl fcp<br>
   where r.concurrent_program_id = fcp.concurrent_program_id<br>
   and r.actual_start_date < sysdate-365      --Show Requests started over 1 year ago<br>
   group by fcp.USER_CONCURRENT_PROGRAM_NAME, to_char(r.actual_start_date,''YYYY''),
   to_char(r.actual_completion_date,''YYYY'')<br>
   order by 2;
  </blockquote>
</div></td>
  </tr> 
</table>
</blockquote>
    For more information please review: [1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite
 ',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_CONC_REQ2');

debug('begin add_signature: CP1_ENV2');
  add_signature(
      p_sig_id                 => 'CP1_ENV2',
      p_sig_sql                => 'select VARIABLE_NAME, replace(value,'':'',chr(10)) "VALUE"
from FND_ENV_CONTEXT
where CONCURRENT_PROCESS_ID = (select max(p.CONCURRENT_PROCESS_ID)
from fnd_concurrent_processes p, fnd_concurrent_queues u
WHERE p.concurrent_queue_id = u.concurrent_queue_id
AND   p.queue_application_id = u.application_id
AND   u.concurrent_queue_name = ''FNDICM'')
and VARIABLE_NAME in (''APPLLKOR'',''AF_CLASSPATH'',''AF_JLIB'',''AF_JRE_TOP'',
''AF_LD_LIBRARY_PATH'',''AFJSMARG'',''AFJVAPRG'',''APPLCSF'',''APPLDCP'',
''APPLFENV'',''APPLLOG'',''APPLORB'',''APPLORC'',''APPLOUT'',''APPLPTMP'',
''APPLTMP'',''APPS_JDBC_URL'',''CA_FILEIO_64'',''CLASSPATH'',
''CONTEXT_FILE'',''CONTEXT_NAME'',''DE_DISABLE_PLS_512'',''DISPLAY'',
''EVENT_10932'',''FND_TOP'',''FNDNAM'',''FNDSM_SCRIPT'',''HOSTNAME'',
''LD_LIBRARY_PATH'',''NLS_LANG'',''NLS_NUMERIC_CHARACTERS'',
''ORACLE_HOME'',''PLATFORM'',''PRINTER'',''REPORTS60_PATH'',
''REPORTS_CLASSPATH'',''REPORTS_NO_DUMMY_PRINTER'',''REPORTS_PATH'',
''REPORTS_POST'',''REPORTS_PRE'',''REPORTS_TMP'',''TK_PRINT_STATUS'',
''TK_PRINTER'',''TNS_ADMIN'',''TWO_TASK'',''XDO_TOP'',''XENVIRONMENT'')
order by VARIABLE_NAME',
      p_title                  => 'Concurrent Processing Environment Variables',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The Concurrent Manager for '||g_nodename||' is "'||g_cp_status||'".',
      p_solution               => 'The Concurrent Manager was last started on '||g_cp_start_date||', and last updated on '||g_last_update_date||'.<br>
   The current Concurrent Manager logs are found :<br>
   '||g_logfile_name||'.<br><br>Refer to [1355735.1] - Difference between APPLPTMP and APPLTMP Directories in EBS',
      p_success_msg            => 'There is a problem identifying the Concurrent Processing Environment Variables for '||g_nodename||'.',  
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_ENV2');

debug('begin add_signature: CP3_CPADV3');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV3',
      p_sig_sql                => 'SELECT q.CONCURRENT_QUEUE_NAME "QUEUE NAME", p.concurrent_time_period_name "TIME PERIOD", qs.min_processes "MIN PROCESSES"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id and a.application_id = q.application_id
and qs.queue_application_id = q.application_id and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id and qs.concurrent_time_period_id = p.concurrent_time_period_id
and q.enabled_flag = ''Y'' and nvl(q.control_code,''X'') <> ''E'' and qs.min_processes >0 and i.status <> ''I''
order by q.concurrent_queue_name, p.concurrent_time_period_id',
      p_title                  => 'Active Managers for Applications not Installed/Used',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are Concurrent Managers that are active for Application modules not Installed or Used.',
      p_solution               => 'These unused managers can impact performance, and deactivating them can reduce current application overhead on the instance.',
      p_success_msg            => 'There are no Concurrent Managers that are active for Application modules not Installed or Used.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV3');

debug('begin add_signature: CP2_CONCREQTOTALS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_CONCREQTOTALS',
      p_sig_sql                => 'SELECT decode(phase_code, ''P'', ''Pending requests'',''R'', ''Running requests'',''C'', ''Completed requests'') "PHASE", ''<div align="right">''||to_char(count(request_id),''999,999,999,999'')||''</div>'' "# OF REQUESTS"
FROM fnd_concurrent_requests
GROUP BY phase_code',
      p_title                  => 'FND_CONCURRENT_REQUESTS Totals',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'Provides a count of concurrent requests in a state of: Pending, Running, or Completed.',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of how often you are purging Concurrent Request tables. <br>
If the total records are too large performance issues can result and FNDCPPUR should be run, otherwise there is no immediate action required.',
      p_success_msg            => 'There are no concurrent requests in a state of: Pending, Running, or Completed.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_CONCREQTOTALS');

debug('begin add_signature: CP1_INVALIDS_ALL_LOW');
  add_signature(
      p_sig_id                 => 'CP1_INVALIDS_ALL_LOW',
      p_sig_sql                => 'select d.owner, d.object_type, substr(d.object_name,0,3)||''%...'' "OBJECT_NAME", ''<div align="right">''||to_char(count(d.status),''999,999,999,999'')||''</div>'' "COUNT"
from dba_objects d
where d.status = ''INVALID''
and d.owner in (''APPS'',''APPLSYS'',''APPLSYSPUB'',''CTXSYS'',''PUBLIC'',''SYS'',''SYSTEM'')
group by d.owner, d.object_type, substr(d.object_name,0,3)
order by 4 desc',
      p_title                  => 'There are '||g_apps_invalid_cnt||' Invalid Objects Found',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_apps_invalid_cnt||' Invalid Objects found in your instance.',
      p_solution               => 'The above list summarizes quickly what products the INVALID objects belong to.<br><br>
It is recommended that you re-compile these in order to make them VALID again.<br>
We next check if any belong to FND, as this control Concurrent Processing in particular.<br>
Consider running ADADMIN and compiling the entire APPS Schema, or just for the Product in question.<br><br>
In order to avoid dependencies issues and errors, EBS customers should always use the adamin tool instead of manually compiling EBS / Apps database objects.<br>
Please review the following :<br>
EBS Invalid Object Utility [2214169.1] and<br>
Troubleshooting Guide - invalid objects in the E-Business Suite Environment 11i and 12 [1325394.1] for more information.',
      p_success_msg            => 'Nice Work !!!
There are no invalid objects found on your instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_INVALIDS_ALL_LOW');

debug('begin add_signature: CP1_CONC_REQ3');
  add_signature(
      p_sig_id                 => 'CP1_CONC_REQ3',
      p_sig_sql                => 'select to_char(actual_completion_date,''YYYY'') "COMPLETED", count(request_id) "COUNT"
  from fnd_concurrent_requests where phase_code=''C''
  group by to_char(actual_completion_date,''YYYY'')
  order by to_char(actual_completion_date,''YYYY'') desc',
      p_title                  => 'Your overall Concurrent Processing HealthCheck Status is Healthy!',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The FND_CONCURRENT_REQUESTS Table has '||to_char(g_reqid_cnt,'999,999,999,999')||' rows of completed runtime data which is within acceptable thresholds that were entered to run this Analyzer.<BR><BR>
    This Gauge is merely a simple indicator about volume of completed Concurrent Request runtime data on '||g_rep_info('Instance')||', which can be adjusted when running this Analyzer.<br>
    It displays GREEN if less than '||to_char(g_min_vol,'999,999,999,999')||' rows are found, ORANGE if less than '||to_char(g_max_vol,'999,999,999,999')||', and RED if over '||to_char(g_max_vol,'999,999,999,999')||' rows are found.',
      p_solution               => 'Clean up Concurrent Request Data and move the needle to green.<BR>
    For more information please review:<br>
    [1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite.',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_CONC_REQ3');

debug('begin add_signature: CP1_FNDRSRUN');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_FNDRSRUN',
      p_sig_sql                => 'select app_short_name "TOP", subdir "SUBDIR", filename "FILENAME", version "VERSION"
from (
select *
from ad_files f, ad_file_versions fv
where f.FILE_ID=fv.FILE_ID
and f.FILENAME like ''FNDRSRUN%''
order by fv.version_segment1 desc,
fv.version_segment2 desc, fv.version_segment3 desc,
fv.version_segment4 desc, fv.version_segment5 desc,
fv.version_segment6 desc, fv.version_segment7 desc,
fv.version_segment8 desc, fv.version_segment9 desc,
fv.version_segment10 desc, 
fv.translation_level desc)
where rownum = 1',
      p_title                  => 'Identify the version of FNDRSRUN',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is no version for FNDRSRUN form.',
      p_solution               => '',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_FNDRSRUN');

debug('begin add_signature: CP1_ENV3');
  add_signature(
      p_sig_id                 => 'CP1_ENV3',
      p_sig_sql                => 'select VARIABLE_NAME, VALUE
from FND_ENV_CONTEXT
where CONCURRENT_PROCESS_ID = (select max(p.CONCURRENT_PROCESS_ID)
from fnd_concurrent_processes p, fnd_concurrent_queues u
WHERE p.concurrent_queue_id = u.concurrent_queue_id
AND   p.queue_application_id = u.application_id
AND   u.concurrent_queue_name = ''FNDICM'')
and VARIABLE_NAME in (''APPLLKOR'',''AF_CLASSPATH'',''AF_JLIB'',''AF_JRE_TOP'',
''AF_LD_LIBRARY_PATH'',''AFJSMARG'',''AFJVAPRG'',''APPLCSF'',''APPLDCP'',
''APPLFENV'',''APPLLOG'',''APPLORB'',''APPLORC'',''APPLOUT'',''APPLPTMP'',
''APPLTMP'',''APPS_JDBC_URL'',''CA_FILEIO_64'',''CLASSPATH'',
''CONTEXT_FILE'',''CONTEXT_NAME'',''DE_DISABLE_PLS_512'',''DISPLAY'',
''EVENT_10932'',''FND_TOP'',''FNDNAM'',''FNDSM_SCRIPT'',''HOSTNAME'',
''LD_LIBRARY_PATH'',''NLS_LANG'',''NLS_NUMERIC_CHARACTERS'',
''ORACLE_HOME'',''PLATFORM'',''PRINTER'',''REPORTS60_PATH'',
''REPORTS_CLASSPATH'',''REPORTS_NO_DUMMY_PRINTER'',''REPORTS_PATH'',
''REPORTS_POST'',''REPORTS_PRE'',''REPORTS_TMP'',''TK_PRINT_STATUS'',
''TK_PRINTER'',''TNS_ADMIN'',''TWO_TASK'',''XDO_TOP'',''XENVIRONMENT'')
order by VARIABLE_NAME',
      p_title                  => 'Concurrent Processing Environment Variables',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The Concurrent Manager Environment for '||g_nodename||' may not be available.  It is currently in "'||g_cp_status||'" status.',
      p_solution               => 'Concurrent Manager was last started on '||g_cp_start_date||', and last updated on '||g_last_update_date||'.<br>
   The current Concurrent Manager logs are found :<br>
   '||g_logfile_name||'.<br><br>Refer to [1355735.1] - Difference between APPLPTMP and APPLTMP Directories in EBS',
   p_success_msg          => 'There is a problem identifying the Concurrent Processing Environment Variables for '||g_nodename||'.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_ENV3');

debug('begin add_signature: CP4_RUN_ALONE_PROGRAMS2');
  add_signature(
      p_sig_id                 => 'CP4_RUN_ALONE_PROGRAMS2',
      p_sig_sql                => 'SELECT r.request_id "REQ ID", a.application_name "APPLICATION",
t.user_concurrent_program_name "PROGRAM", p.concurrent_program_name "SHORT NAME",
DECODE(p.execution_method_code, ''I'',''PL/SQL Concurrent Program'',''K'',''Java Concurrent Program'',
''P'',''Oracle*Reports Concurrent Program'',''Q'',''SQL*Plus Concurrent Program'') "EXECUTION METHOD",
DECODE(p.queue_method_code,''B'',''B=Yes'',''I'',''I=No'') "QUEUE METHOD", u.user_name "USER",
TO_CHAR(r.requested_start_date, ''DD-MON-RR HH24:MI:SS'') "STARTED",
r.is_sub_request "IS SUB REQUEST", 
DECODE(r.PHASE_CODE, ''C'',''Completed'',''I'',''I=Inactive'',''P'',''P=Pending'',''R'',''R=Running'') "PHASE",
DECODE(r.STATUS_CODE, ''A'',''Waiting'',''B'',''B=Resuming'',''C'',''C=Normal'',
  ''D'',''D=Cancelled'',''E'',''E=Error'',''G'',''G=Warning'',
 ''H'',''H=On Hold'',''I'',''I=Normal'',''M'',''M=No Manager'',
 ''P'',''P=Scheduled'',''Q'',''Q=Standby'',''R'',''R=Normal'',
 ''S'',''S=Suspended'',''T'',''T=Terminating'',''U'',''U=Disabled'',
 ''W'',''W=Paused'',''X'',''X=Terminated'',''Z'',''Z=Waiting'') "STATUS"
FROM apps.fnd_concurrent_programs_tl t,
apps.fnd_concurrent_programs p, apps.fnd_application_tl a,
apps.fnd_concurrent_requests r,apps.fnd_languages l,
apps.fnd_user u
WHERE a.application_id = t.application_id
and r.concurrent_program_id = t.concurrent_program_id
and t.concurrent_program_id = p.concurrent_program_id
AND r.nls_language = l.nls_language
AND l.language_code = t.language
AND l.language_code = a.language
AND r.requested_by = u.user_id
and p.run_alone_flag = ''Y''',
      p_title                  => 'Run Alone Programs',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_run_alone_cnt||' <strong>Run Alone</strong> Concurrent Programs defined in this '||g_rep_info('Instance')||' instance that are enabled, and currently there are '||g_run_alone_now_cnt||' running or scheduled to run via Concurrent Manager.',
      p_solution               => 'Concurrent "Run Alone" programs will cause a momentary "Inactive No Manager" and/or "Pending" status, because no program can run while a "Run Alone" program runs.<br><br> Check the above list of program(s) that may be causing any prolonged  "Inactive No Manager" state.<br>
The "Run Alone" option should be used very sparingly and only with short / quick running programs, because it blocks all other programs while it is queued / running.
',
      p_success_msg            => 'There are '||g_run_alone_cnt||' <strong>Run Alone</strong> Concurrent Programs defined in this '||g_rep_info('Instance')||' instance, that are enabled, but currently none being run or scheduled to run via Concurrent Manager.<br><br>
It is possible to define a concurrent program to be "Run-Alone" or to be "Incompatible" with specific concurrent programs by editing the concurrent program''s definition using the
Concurrent Programs window.<br><br>
Program incompatibility and run-alone program definitions are enforced by the Conflict Resolution Manager (CRM).<br>
For more details see: Oracle E-Business Suite System Administrator''s Guide - Configuration - Concurrent Programs, page 6-65.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP4_RUN_ALONE_PROGRAMS2');

debug('begin add_signature: CP3_CPADV4');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV4',
      p_sig_sql                => 'SELECT q.CONCURRENT_QUEUE_NAME "QUEUE NAME", q.max_processes "MAX PROCESSES", q.running_processes "RUNNING", q.node_name "NODE1", q.node_name2 "NODE2",
p.concurrent_time_period_name "TIME PERIOD", qs.min_processes "MIN PROCESSES"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id and a.application_id = q.application_id
and qs.queue_application_id = q.application_id and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id and qs.concurrent_time_period_id = p.concurrent_time_period_id
and q.enabled_flag = ''Y'' and nvl(q.control_code,''X'') <> ''E'' and qs.min_processes >0 and q.manager_type = 1
and p.concurrent_time_period_name not in (''Weekend'',''Off-Peak AM'',''Off-Peak PM'')
order by qs.min_processes desc,q.concurrent_queue_name',
      p_title                  => 'Total Target Processes for Request Managers Excluding Off-Hours',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'Total Target Processes for Request Managers Excluding Off-Hours<br>
    This identifies the total number of processes that can be run for a given concurrent manager. <br>
    The greater the number of processes defined can impact increased Concurrent Processing loads. ',
      p_solution               => 'The resulting data is for review and confirmation by your teams, and serves as a baseline for comparison with later outputs above. <br>
 Otherwise there is no immediate action required.',
      p_success_msg            => 'There are no rows found for Total Target Processes for Request Managers Excluding Off-Hours',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV4');

debug('begin add_signature: CP2_CONCREQS2');
  add_signature(
      p_sig_id                 => 'CP2_CONCREQS2',
      p_sig_sql                => 'SELECT request_id "REQUEST ID", nvl(meaning, ''UNKNOWN'') "STATUS", user_concurrent_program_name "PROGRAM NAME",
to_char(actual_start_date, ''DD-MON-RR HH24:MI:SS'') "STARTED", decode(run_alone_flag, ''Y'', ''Yes'', ''No'') "RUN ALONE"
FROM   fnd_concurrent_requests fcr, fnd_lookups fl, fnd_concurrent_programs_vl fcpv
WHERE  phase_code = ''R'' AND LOOKUP_TYPE = ''CP_STATUS_CODE'' AND lookup_code = status_code
AND fcr.concurrent_program_id = fcpv.concurrent_program_id AND fcr.program_application_id = fcpv.application_id
ORDER BY actual_start_date, request_id',
      p_title                  => 'Running Requests',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no concurrent requests currently running on this '||g_rep_info('Instance')||' instance.',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently running on the system.<br>
    Otherwise there is no immediate action required.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently running on the system.<br>
    Otherwise there is no immediate action required.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP2_CONCREQS2');

debug('begin add_signature: CP1_PURGEREQS');
  add_signature(
      p_sig_id                 => 'CP1_PURGEREQS',
      p_sig_sql                => 'SELECT r.REQUEST_ID, u.user_name, r.PHASE_CODE, r.ACTUAL_START_DATE,
          c.CONCURRENT_PROGRAM_NAME, p.USER_CONCURRENT_PROGRAM_NAME, r.ARGUMENT_TEXT,
          r.RESUBMIT_INTERVAL, r.RESUBMIT_INTERVAL_UNIT_CODE, r.RESUBMIT_END_DATE
          FROM fnd_concurrent_requests r, FND_CONCURRENT_PROGRAMS_TL p, fnd_concurrent_programs c, fnd_user u
          WHERE r.CONCURRENT_PROGRAM_ID = p.CONCURRENT_PROGRAM_ID and r.requested_by = u.user_id
          and p.CONCURRENT_PROGRAM_ID = c.CONCURRENT_PROGRAM_ID
          and c.CONCURRENT_PROGRAM_NAME = ''FNDCPPUR''
          AND p.language = ''US''
          and r.ACTUAL_COMPLETION_DATE is null and r.PHASE_CODE in (''P'',''R'')
          order by c.CONCURRENT_PROGRAM_NAME, r.ARGUMENT_TEXT',
      p_title                  => 'Verify Purge and/or Manager Data Programs Scheduled to Run',
      p_fail_condition         => 'NRS',
      p_problem_descr          => '<b>There are a total of '||to_char(g_reqid_cnt,'999,999,999,999')||' records in FND_CONCURRENT_REQUESTS that are completed, but no "Purge Concurrent Request and/or Manager Data" program (FNDCPPUR) scheduled or running</b>',
      p_solution               => 'Please Review Concurrent Processing purging status with your team.<br><br>
Run the concurrent program "Purge Concurrent Request and/or Manager Data" (FNDCPPUR) with "Entity" parameter as "ALL" for all requests, or for specific requests that have large volumes of purge eligible data as seen above. The last purge of Concurrent Request data completed on No Date info available for VISION.<br>
FNDCPPUR should be scheduled and run on a regular basis to avoid performance issues. Run the query behind the SQL SCRIPT button to get the complete list of purge eligible concurrent request data.<br><br>
Additionally, the following are very good methods to follow for optimizing the process:
<ul><li>Run the job during hours of low workload. Doing this after hours will lessen the contention on the tables from running against your daily processing.</li>
<li>To get the requests under control, run the FNDCPPUR program with Age=20 or Age=18 would be a good method. That means, all requests older than 18 or 20 days will be purged.</li>
<li>Once the requests are under control, run the FNDCPPUR program with Age=7 to maintain an efficient process. This would solely depend on the level of processing that is performed at your site</li></ul>
For more information please review:<br>
[1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite<br>
[1095625.1] - Health Check Alert: Purge the eligible records from the FND_CONCURRENT_REQUESTS table<br><br>
<b>Note:</b> This section is only looking at the scheduled jobs in FND_CONCURRENT_REQUESTS table. Jobs scheduled using other tools (DBMS_JOBS, CONSUB, or PL/SQL, etc) are not reflected here, so keep this in mind.',
      p_success_msg            => '<b>There is a "Purge Concurrent Request and/or Manager Data" program (FNDCPPUR) scheduled or running on '||g_rep_info('Instance')||'.</b><br>
    There are a total of '||to_char(g_reqid_cnt,'999,999,999,999')||' records in FND_CONCURRENT_REQUESTS that are completed, and eligible for purging.<br><br>
Run the query behind the SQL SCRIPT button to get the complete list of purge eligible concurrent request data.<br><br>
Additionally, the following are very good methods to follow for optimizing the "Purge Concurrent Request and/or Manager Data" process:
<ul><li>Run the job during hours of low workload. Doing this after hours will lessen the contention on the tables from running against your daily processing.</li>
<li>To get the requests under control, run the FNDCPPUR program with Age=20 or Age=18 would be a good method. That means, all requests older than 18 or 20 days will be purged.</li>
<li>Once the requests are under control, run the FNDCPPUR program with Age=7 to maintain an efficient process. This would solely depend on the level of processing that is performed at your site</li></ul>
For more information please review:<br>
[1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite<br>
[1095625.1] - Health Check Alert: Purge the eligible records from the FND_CONCURRENT_REQUESTS table<br><br>
<b>Note:</b> This section is only looking at the scheduled jobs in FND_CONCURRENT_REQUESTS table. Jobs scheduled using other tools (DBMS_JOBS, CONSUB, or PL/SQL, etc) are not reflected here, so keep this in mind.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_PURGEREQS');

debug('begin add_signature: CP2_PENDREQ');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_PENDREQ',
      p_sig_sql                => 'SELECT ''Pending'' "PHASE", meaning "STATUS", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "# REQUESTS"
FROM   fnd_concurrent_requests, fnd_lookups
WHERE  LOOKUP_TYPE = ''CP_STATUS_CODE'' AND lookup_code = status_code AND phase_code = ''P''
GROUP BY meaning',
      p_title                  => 'Total Pending Requests by Status Code',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Pending Requests currently found on this ''||g_rep_info(''Instance'')||'' instance.',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently pending on the system. <br>
    Otherwise there is no immediate action required.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently pending on the system. <br>
    Otherwise there is no immediate action required.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_PENDREQ');

debug('begin add_signature: CP2_TOP_10_CONC_REQS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_TOP_10_CONC_REQS',
      p_sig_sql                => 'select u.user_name, cp.CONCURRENT_PROGRAM_ID "CP ID", cp.CONCURRENT_PROGRAM_NAME "SHORT NAME", cp.USER_CONCURRENT_PROGRAM_NAME "PROGRAM NAME",
''<div align="right">''||to_char(count(r.request_id),''999,999,999,999'')||''</div>'' "COUNT"
from fnd_concurrent_requests r, fnd_user u, fnd_concurrent_programs_vl cp
where r.requested_by = u.user_id
and r.CONCURRENT_PROGRAM_ID = cp.CONCURRENT_PROGRAM_ID
and u.user_name in  (select user_name from (
select u.user_name, count(r.request_id)
from fnd_concurrent_requests r, fnd_user u
where r.requested_by = u.user_id
group by u.user_name
order by 2 desc)
where rownum < 11)
group by u.user_name, cp.CONCURRENT_PROGRAM_ID, cp.CONCURRENT_PROGRAM_NAME, cp.USER_CONCURRENT_PROGRAM_NAME
order by 5 desc',
      p_title                  => 'Top 10 Users Running Concurrent Requests',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'No Users are found to be running Concurrent Requests',
      p_solution               => 'Check the FND_CONCURRENT_REQUESTS table for data.',
      p_success_msg            => 'List of top 10 users that are running/scheduling Concurrent Requests and the Concurrent Programs they are running.   This list is for performance review.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_TOP_10_CONC_REQS');

debug('begin add_signature: CP3_CPADV5');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV5',
      p_sig_sql                => 'SELECT q.CONCURRENT_QUEUE_NAME, q.USER_CONCURRENT_QUEUE_NAME, q.cache_size, qs.MAX_PROCESSES "ACTUAL", qs.min_processes "TARGET"
from apps.fnd_concurrent_queues_vl q, apps.fnd_product_installations i, apps.fnd_application_vl a,
apps.fnd_concurrent_time_periods p, apps.fnd_concurrent_queue_size qs
where i.application_id = q.application_id and a.application_id = q.application_id
and qs.queue_application_id = q.application_id and qs.concurrent_queue_id = q.concurrent_queue_id
and qs.period_application_id = p.application_id and qs.concurrent_time_period_id = p.concurrent_time_period_id
and q.enabled_flag = ''Y'' and nvl(q.control_code,''X'') <> ''E'' and qs.min_processes >0 and q.manager_type = 1
group by q.CONCURRENT_QUEUE_NAME, q.USER_CONCURRENT_QUEUE_NAME, q.cache_size, qs.min_processes, qs.MAX_PROCESSES
having decode(max(qs.min_processes),1,2,max(qs.min_processes)) > nvl(q.cache_size,1)
order by  q.concurrent_queue_name',
      p_title                  => 'Display Managers Cache Size, Actual & Target Processes',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Concurrent Queue or Managers defined in this instance.',
      p_solution               => 'A Managers cache size reflects the number of requests a manager adds to its queue, each time it reads available requests to run. <br>
For example, if a manager has 1 target process and a cache value of 3, it will read 3 requests and run those requests before returning to cache additional requests.
 <br><br>
 Tip: Enter a value of 1 when defining a manager that runs long, time-consuming jobs, and a value of 3 or 4 for managers that run small, quick jobs. <BR><br>
 For more information refer to [1373727.1] - FAQ: EBS Concurrent processing Performance and Best Practices',
      p_success_msg            => 'Please review the list of Concurrent Managers for correct Cache Size and Actual & Target Processes.<br><br>
A Managers cache size reflects the number of requests a manager adds to its queue, each time it reads available requests to run. <br>
For example, if a manager has 1 target process and a cache value of 3, it will read 3 requests and run those requests before returning to cache additional requests.
 <br><br>
Tip: Enter a value of 1 when defining a manager that runs long, time-consuming jobs, and a value of 3 or 4 for managers that run small, quick jobs. <BR><br>
For more information refer to [1373727.1] - FAQ: EBS Concurrent processing Performance and Best Practices',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV5');

debug('begin add_signature: CP1_PURGELIGIBLE');
  add_signature(
      p_sig_id                 => 'CP1_PURGELIGIBLE',
      p_sig_sql                => 'select p.USER_CONCURRENT_PROGRAM_NAME, decode(r.phase_code,''C'',''Complete'') STATUS,
''<div align="right">''||to_char(count(r.request_id),''999,999,999,999'')||''</div>'' "COUNT"
 FROM fnd_concurrent_requests r, FND_CONCURRENT_PROGRAMS_TL p
 WHERE r.CONCURRENT_PROGRAM_ID = p.CONCURRENT_PROGRAM_ID
 and r.phase_code=''C''
        and p.language = ''US''
 group by p.USER_CONCURRENT_PROGRAM_NAME, r.phase_code
 order by count(r.request_id) desc',
      p_title                  => 'Total Purge Eligible Records in FND_CONCURRENT_REQUESTS',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are a total of '||to_char(g_reqid_cnt,'999,999,999,999')||' records in FND_CONCURRENT_REQUESTS that are completed, and eligible for purging.',
      p_solution               => 'Review Concurrent Processing purging status with your team.<br><br>
    Run the concurrrent program "Purge Concurrent Request and/or Manager Data" (FNDCPPUR) with "Entity" parameter as "ALL" for all requests, or for specific requests that have large volumes of purge eligible data as seen above. The last purge of Concurrent Request data completed on No Date info available for VISION.<br><br>
FNDCPPUR should be scheduled and run on a regular basis to avoid performance issues. Run the query behind the SQL SCRIPT button to get the complete list of purge eligible concurrent request data.<br><br>
For more information please review:<br>
[1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite<br>
[1095625.1] - Health Check Alert: Purge the eligible records from the FND_CONCURRENT_REQUESTS table<br><br>
<b>Note:</b> This section is only looking at the scheduled jobs in FND_CONCURRENT_REQUESTS table. Jobs scheduled using other tools (DBMS_JOBS, CONSUB, or PL/SQL, etc) are not reflected here, so keep this in mind.',
      p_success_msg            => 'There are a total of '||to_char(g_reqid_cnt,'999,999,999,999')||' records in FND_CONCURRENT_REQUESTS that are completed, and eligible for purging.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_PURGELIGIBLE');

debug('begin add_signature: CP1_INVALIDS_FND_LOW');
  add_signature(
      p_sig_id                 => 'CP1_INVALIDS_FND_LOW',
      p_sig_sql                => 'select d.owner, d.object_name, d.object_type, d.status
from dba_objects d
where d.status = ''INVALID''
and d.owner in (''APPS'',''APPLSYS'')
and d.object_name like ''FND%''',
      p_title                  => 'Check for Invalid FND Objects',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_fnd_invalid_cnt||' Invalid FND Objects found in your instance.',
      p_solution               => 'The above list summarizes quickly what FND Objects are INVALID.<br><br>
It is recommended that you re-compile these in order to make them VALID again.<br>
FND Objects are very important, as this control Concurrent Processing in particular.<br><br>
<br>
Please review the following :<br>
EBS Invalid Object Utility [2214169.1] and<br>
Debug and Validate Invalid Objects [300056.1] for more information.',
      p_success_msg            => 'Nice Work!!
There are no Invalid FND Objects found on your instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_INVALIDS_FND_LOW');

debug('begin add_signature: CP2_PENDING_REQUESTS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_PENDING_REQUESTS',
      p_sig_sql                => 'SELECT ''Pending Requests Regularly Scheduled:'' "PENDING REQUESTS",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNTS"
from   fnd_concurrent_requests
WHERE  (requested_start_date > sysdate OR status_code = ''P'') AND phase_code = ''P''
union
SELECT ''Pending Requests Non Regularly Scheduled:'' "Pending Requests",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT"
from   fnd_concurrent_requests
WHERE  requested_start_date <= sysdate AND status_code != ''P'' AND phase_code = ''P''
union
SELECT ''Pending Requests On Hold:'' "Pending Requests",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT"
from   fnd_concurrent_requests
WHERE  hold_flag = ''Y'' AND phase_code = ''P''
union
SELECT ''Pending Requests Not On Hold:'' "Pending Requests",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT"
from   fnd_concurrent_requests
WHERE  hold_flag != ''Y'' AND phase_code = ''P''',
      p_title                  => 'Types of Pending Requests and Counts',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no rows found for pending requests.
',
      p_solution               => 'Ensure that Concurrent Manager is up and running.',
      p_success_msg            => 'Displays a list a Pending Requests for : <br>
<ul>
<li>Pending Requests Regularly Scheduled:</li>
<li>Pending Requests Non Regularly Scheduled:</li>
<li>Pending Requests On Hold:</li>
<li>Pending Requests Not On Hold:</li>
</ul>',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_PENDING_REQUESTS');

debug('begin add_signature: CP3_CPADV11');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV11',
      p_sig_sql                => 'SELECT q.concurrent_queue_name "CONCURRENT QUEUE NAME",
''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT",
''<div align="right">''||to_char(round(sum(r.actual_completion_date - r.actual_start_date) * 24, 2),''999,999,999,999.99'')||''</div>'' "ELAPSED",
''<div align="right">''||to_char(round(avg(r.actual_completion_date - r.actual_start_date) * 24, 2),''999,999,999,999.99'')||''</div>'' "AVG",
''<div align="right">''||to_char(round(stddev(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 24, 2),''999,999,999,999.99'')||''</div>'' "WSTDDEV",
''<div align="right">''||to_char(round(sum(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 24, 2),''999,999,999,999.99'')||''</div>'' "WAITED",
''<div align="right">''||to_char(round(avg(actual_start_date - greatest(r.requested_start_date,r.request_date)) * 24, 2),''999,999,999,999.99'')||''</div>'' "AVGWAIT"
from apps.fnd_concurrent_programs p, apps.fnd_concurrent_requests r, apps.fnd_concurrent_queues q,
apps.fnd_concurrent_processes p
where r.program_application_id = p.application_id and r.concurrent_program_id = p.concurrent_program_id
and r.phase_code=''C'' -- completed and r.status_code in (''C'',''G'') -- completed normal or with warning
and r.controlling_manager=p.concurrent_process_id and q.concurrent_queue_id=p.concurrent_queue_id
and r.concurrent_program_id=p.concurrent_program_id
group by q.concurrent_queue_name',
      p_title                  => 'Concurrent Manager Request Summary by Manager',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'These are the concurrent managers being used, and can be compared with the actual concurrent managers allocated at startup. <br>
    This only considers requests with completion status of normal/warning.',
      p_solution               => 'Please consider deactivation of any managers which are consistently not being used, and are listed as Active/Enabled above.',
      p_success_msg            => 'There are no concurrent managers are being used, and can be compared with the actual concurrent managers allocated at startup.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV11');

debug('begin add_signature: CP1_INVALIDS_ALL_HIGH');
  add_signature(
      p_sig_id                 => 'CP1_INVALIDS_ALL_HIGH',
      p_sig_sql                => 'select d.owner, d.object_type, substr(d.object_name,0,3)||''%...'' "OBJECT_NAME", ''<div align="right">''||to_char(count(d.status),''999,999,999,999'')||''</div>'' "COUNT"
from dba_objects d
where d.status = ''INVALID''
and d.owner in (''APPS'',''APPLSYS'',''APPLSYSPUB'',''CTXSYS'',''PUBLIC'',''SYS'',''SYSTEM'')
group by d.owner, d.object_type, substr(d.object_name,0,3)
order by 4 desc',
      p_title                  => 'Check for Invalid Objects All',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_apps_invalid_cnt||' Invalid Objects found in your E-Business Suite instance.',
      p_solution               => 'The above list summarizes quickly what products the INVALID objects belong to.<br><br>
It is recommended that you re-compile these in order to make them VALID again.<br>
We next check if any belong to FND, as they control Concurrent Processing in particular.<br>
Consider running ADADMIN and compiling the entire APPS Schema.<br><br>
In order to avoid dependencies issues and errors, EBS customers should always use the adamin tool instead of manually compiling EBS / Apps database objects.<br><br>
Please review the following :<br>
EBS Invalid Object Utility [2214169.1] and<br>
Troubleshooting Guide - invalid objects in the E-Business Suite Environment 11i and 12 [1325394.1] for more information.',
      p_success_msg            => 'Nice Work !!!
There are no invalid objects found on your instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_INVALIDS_ALL_HIGH');

debug('begin add_signature: CP1_NODE_INFO');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_NODE_INFO',
      p_sig_sql                => 'SELECT substr(fn.node_name, 1, 20) "NODE_NAME", flkup.meaning "PLATFORM", fn.node_mode, fn.server_address, substr(fn.host, 1, 15) "HOST",
       substr(fn.domain, 1, 20) "DOMAIN", substr(fn.support_cp, 1, 3) "CP", substr(fn.support_web, 1, 3) "WEB",
       substr(fn.support_admin, 1, 3) "ADMIN", substr(fn.support_forms, 1, 3) "FORMS",
       substr(fn.SUPPORT_DB, 1, 3) "DB", substr(fn.VIRTUAL_IP, 1, 30) "VIRTUAL_IP"
       from fnd_nodes fn, fnd_lookups flkup
       where flkup.lookup_type=''PLATFORM''
       and fn.platform_code=flkup.lookup_code',
      p_title                  => 'Instance Node Details',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is a problem identifying the EBS Instance Information',
      p_solution               => '',
      p_success_msg            => '',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_NODE_INFO');

debug('begin add_signature: CP4_STD_MGR');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR',
      p_sig_sql                => 'select decode(c.include_flag,''E'',''Exclude'',''I'',''Include'') "INCLUDE_FLAG",
decode (c.type_code,''C'',''Combined Rule'',''L'',''Logical DB'',
''O'',''Oracle ID'',''P'',''Program'',''R'',''Request Type'',''U'',''User'') "TYPE_CODE",
a.application_name, t.user_concurrent_program_name
from fnd_concurrent_queue_content c, fnd_concurrent_programs p,
fnd_concurrent_programs_tl t, fnd_application_tl a
where c.concurrent_queue_id = 0
and c.type_application_id = p.application_id
and c.type_id = p.concurrent_program_id
and p.application_id = a.application_id
and t.concurrent_program_id = p.concurrent_program_id
and a.language=t.language',
      p_title                  => 'Standard Manager Analysis',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'Standard Manager is not running.',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed
with a "Included" Specialization" rule--"Excluded" is ok.
(Responsibility = System Administrator, Navigate --> Concurrent:
Manager: Define)
Any changes requires that you "Verify" the Internal Concurrent Manager
on the "Administer Concurrent Managers" screen.
',
      p_success_msg            => 'Standard Manager is running.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR');

debug('begin add_signature: CP2_SCHEDULEDREQ');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_SCHEDULEDREQ',
      p_sig_sql                => 'SELECT request_id REQ_ID, fu.user_name REQUESTED_BY, nvl(meaning, ''UNKNOWN'') status, user_concurrent_program_name PROGRAM_NAME,
to_char(request_date, ''DD-MON-RR HH24:MI:SS'') SUBMITTED, to_char(requested_start_date, ''DD-MON-RR HH24:MI:SS'') START_DATE
FROM fnd_concurrent_requests fcr, fnd_lookups fl, fnd_concurrent_programs_vl fcpv, fnd_user fu
WHERE fcr.requested_by = fu.user_id
and phase_code = ''P'' AND (fcr.requested_start_date >= sysdate OR status_code = ''P'')
AND LOOKUP_TYPE = ''CP_STATUS_CODE'' AND lookup_code = status_code AND fcr.concurrent_program_id = fcpv.concurrent_program_id
AND fcr.program_application_id = fcpv.application_id
ORDER BY requested_start_date',
      p_title                  => 'Listing of Scheduled Requests',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Scheduled Requests',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently scheduled on the system.<br>
    Otherwise there is no immediate action required.<br><br>
 For more information refer to [213021.1] - Concurrent Processing (CP) / APPS Reporting Scripts',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently scheduled on the system.<br>
    Otherwise there is no immediate action required.<br><br>
 For more information refer to [213021.1] - Concurrent Processing (CP) / APPS Reporting Scripts',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_SCHEDULEDREQ');

debug('begin add_signature: CP1_PARAMETERS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_PARAMETERS',
      p_sig_sql                => 'SELECT name, value
          from v$parameter
          where upper(name) in (''AQ_TM_PROCESSES'',''JOB_QUEUE_PROCESSES'',''JOB_QUEUE_INTERVAL'',
                                ''UTL_FILE_DIR'',''NLS_LANGUAGE'',''NLS_TERRITORY'',
                                ''CPU_COUNT'',''PARALLEL_THREADS_PER_CPU'')
 UNION
 select parameter, value from v$nls_parameters where parameter in (''NLS_CHARACTERSET'')',
      p_title                  => 'Concurrent Processing Database Parameter Settings',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is a problem identifying the Concurrent Processing Database Parameter Settings',
      p_solution               => 'Verify the Concurrent Processing Database Parameter Settings are set',
      p_success_msg            => 'For more information refer to [396009.1] - Database Initialization Parameters for Oracle E-Business Suite Release 12',
      p_print_condition        => nvl('SUCCESS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_PARAMETERS');

debug('begin add_signature: CP3_CPADV12');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV12',
      p_sig_sql                => 'SELECT a.CONCURRENT_QUEUE_ID "Queue ID", a.QUEUE_APPLICATION_ID "Apps ID",
b.user_CONCURRENT_QUEUE_NAME "Concurrent Manager", decode(a.PHASE_CODE, ''P'',''PENDING'',''R'',''Running'') Phase,count(1)
FROM FND_CONCURRENT_WORKER_REQUESTS a, fnd_concurrent_queues_vl b
WHERE (a.Phase_Code = ''P'' or a.Phase_Code = ''R'') and a.hold_flag != ''Y'' and a.Requested_Start_Date <= SYSDATE
AND ('''' IS NULL OR ('''' = ''B'' AND a.PHASE_CODE = ''R'' AND a.STATUS_CODE IN (''I'', ''Q''))) and ''1'' in (0,1,4)
And a.concurrent_queue_id=b.concurrent_queue_id
group by a.CONCURRENT_QUEUE_ID, a.QUEUE_APPLICATION_ID, b.user_CONCURRENT_QUEUE_NAME, a.PHASE_CODE
order by 1',
      p_title                  => 'Check Manager Queues for Pending Requests',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are concurrent requests that are in a Pending state. ',
      p_solution               => 'The output above is for review and confirmation by your team. Typically when there are requests pending, the number should be the same as the number of actual processes. <br>
    However if there are no pending requests or requests were just submitted, the number of requests running may be less than the number of actual processes. <br>
 Also note if a concurrent program is incompatible with another program currently running, it does not start until the incompatible program has completed. In this case, the number of requests running may be less than number of actual processes even when there are requests pending.',
      p_success_msg            => 'There are no concurrent requests that are in a Pending state.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV12');

debug('begin add_signature: CP1_INVALIDS_FND_HIGH');
  add_signature(
      p_sig_id                 => 'CP1_INVALIDS_FND_HIGH',
      p_sig_sql                => 'select d.owner, d.object_name, d.object_type, d.status
from dba_objects d
where d.status = ''INVALID''
and d.owner in (''APPS'',''APPLSYS'')
and d.object_name like ''FND%''',
      p_title                  => 'Check for Invalid FND Objects',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_fnd_invalid_cnt||' Invalid FND Objects found in your instance.',
      p_solution               => 'The above list summarizes quickly what FND Objects are INVALID.<br><br>
It is recommended that you re-compile these in order to make them VALID again.<br>
FND Objects are very important, as this control Concurrent Processing in particular.<br>
In order to avoid dependencies issues and errors, EBS customers should always use the adamin tool instead of manually compiling EBS / Apps database objects.<br><br>
Please review the following :<br>
EBS Invalid Object Utility [2214169.1] and<br>
roubleshooting Guide - invalid objects in the E-Business Suite Environment 11i and 12 [1325394.1] for more information.',
      p_success_msg            => 'Nice Work!!
There are no Invalid FND Objects found on your instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_INVALIDS_FND_HIGH');

debug('begin add_signature: CP4_STD_MGR_INCL');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_INCL',
      p_sig_sql                => 'select decode(c.include_flag,''E'',''Exclude'',''I'',''Include'') "INCLUDE_FLAG",
decode (c.type_code,''C'',''Combined Rule'',''L'',''Logical DB'',
''O'',''Oracle ID'',''P'',''Program'',''R'',''Request Type'',''U'',''User'') "TYPE_CODE",
a.application_name, t.user_concurrent_program_name
from fnd_concurrent_queue_content c, fnd_concurrent_programs p,
fnd_concurrent_programs_tl t, fnd_application_tl a
where c.concurrent_queue_id = 0
and c.include_flag = ''I''
and c.type_application_id = p.application_id
and c.type_id = p.concurrent_program_id
and p.application_id = a.application_id
and t.concurrent_program_id = p.concurrent_program_id
and a.language=t.language',
      p_title                  => 'Standard Manager has an INCLUDE defined',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The Standard concurrent manager has been altered with an INCLUDE. <br>
',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed with a "Included" Specialization" rule--"Excluded" is ok. <br>
If you do, and you have not defined additional managers to accept your requests, some programs may not run. Use the Standard manager as a safety net, a manager who is always available to run any request. Define additional managers to handle your installation site''s specific needs.
<br><br>
(Responsibility = System Administrator, Navigate --> Concurrent: Manager: Define)<br>
Any changes requires that you "Verify" the Internal Concurrent Manager on the "Administer Concurrent Managers" screen.<br><br>
When changing manager specialization or program incompatibilities, remember to "Verify" the ICM on the Administer Concurrent Manager form or bounce (restart) the concurrent managers for the changes to take effect.
',
      p_success_msg            => 'No rows were selected so I am calling this a success.',
      p_print_condition        => nvl('FAILURE','ALWAYS'),
      p_fail_type              => nvl('E','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_INCL');

debug('begin add_signature: CP_STD_MGR_INCLUDES');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP_STD_MGR_INCLUDES',
      p_sig_sql                => 'select decode(c.include_flag,''E'',''Exclude'',''I'',''Include'') "INCLUDE_FLAG",
decode (c.type_code,''C'',''Combined Rule'',''L'',''Logical DB'',
''O'',''Oracle ID'',''P'',''Program'',''R'',''Request Type'',''U'',''User'') "TYPE_CODE",
a.application_name, t.user_concurrent_program_name
from fnd_concurrent_queue_content c, fnd_concurrent_programs p,
fnd_concurrent_programs_tl t, fnd_application_tl a
where c.concurrent_queue_id = 0
and c.type_application_id = p.application_id
and c.type_id = p.concurrent_program_id
and p.application_id = a.application_id
and t.concurrent_program_id = p.concurrent_program_id
and c.include_flag = ''I''
and a.language=t.language',
      p_title                  => 'Standard Manager INCLUDES',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'The Standard Manager has an INCLUDE!!
',
      p_solution               => 'You should not alter the definition of the Standard concurrent manager. <br>
If you do, and you have not defined additional managers to accept your requests, some programs may not run. Use the Standard manager as a safety net, a manager who is always available to run any request. Define additional managers to handle your installation site''s specific needs.
<br><br>
Ensure that the Standard Manager''s definition has not been changed with a "Included" Specialization rule--"Excluded" is ok. <br>
(Responsibility = System Administrator, Navigate --> Concurrent: Manager: Define)<br>
Any changes requires that you "Verify" the Internal Concurrent Manager on the "Administer Concurrent Managers" screen.
When changing manager specialization or program incompatibilities, remember to "Verify" the ICM on the Administer Concurrent Manager form or bounce (restart) the concurrent managers for the changes to take effect.
',
      p_success_msg            => 'There are no INCLUDE rules assigned to the Standard Manager.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('E','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP_STD_MGR_INCLUDES');

debug('begin add_signature: CP3_CPADV17');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_CPADV17',
      p_sig_sql                => 'SELECT  v.concurrent_queue_name "CONCURRENT QUEUE NAME", v.concurrent_queue_id "QUEUE ID",
 v.user_concurrent_queue_name "NAME", v.max_processes "TARGET", v.running_processes "ACTUAL",
 v.control_code "CODE", v.target_node "TARGET NODE",
 TO_CHAR(v.last_update_date, ''DD-MON-RR HH24:MI:SS'') "LAST UPDATE",
 v.node_name "NODE NAME", s.service_parameters "SERVICE PARAMETERS",
 c.developer_parameters "DEVELOPER PARAMETERS"
 FROM fnd_concurrent_queues_vl v, fnd_concurrent_queue_size s,
 fnd_cp_services c
 WHERE v.concurrent_queue_name like ''FNDCPOPP%''
 and v.concurrent_queue_id = s.concurrent_queue_id
 and v.manager_type = c.service_id',
      p_title                  => 'Check the Configuration of OPP',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'OPP is currently configured, identifying the: Service ID, Service Handle, and Parameters used.',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline regarding your current OPP configuration. <br>
 You can cross reference the collected information with existing notes on OPP best practices :<br>
 [1399454.1] - Tuning Output Post Processor (OPP) to Improve Performance<br>
 [1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite',
      p_success_msg            => 'OPP is currently not configured.<br><br>
    Please check existing notes on OPP best practices :<br>
 [1399454.1] - Tuning Output Post Processor (OPP) to Improve Performance<br>
 [1057802.1] - Concurrent Processing - Best Practices for Performance for Concurrent Managers in E-Business Suite',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_CPADV17');

debug('begin add_signature: CP1_INVALIDS_BY_SCHEMA');
add_signature(
      p_sig_id                 => 'CP1_INVALIDS_BY_SCHEMA',
      p_sig_sql                => 'select d.owner,
''<div align="right">''||to_char(count(d.status),''999,999,999,999'')||''</div>'' "COUNT"
from dba_objects d
where d.status = ''INVALID''
and d.owner in (''APPS'',''APPLSYS'',''APPLSYSPUB'',''CTXSYS'',''PUBLIC'',''SYS'',''SYSTEM'')
group by d.owner',
      p_title                  => 'There are '||g_apps_invalid_cnt||' Invalid Objects Found',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are '||g_apps_invalid_cnt||' Invalid Objects found in your instance schemas.',
      p_solution               => 'The above list summarizes quickly what schemas the INVALID objects belong to.<br><br>
It is recommended that you drill down into each schema and re-compile these in order to make them VALID again.<br>
We also check if any belong to FND, as this control Concurrent Processing in particular.<br>
Consider running ADADMIN and compiling the entire APPS Schema, or just for the Product in question.<br><br>
In order to avoid dependencies issues and errors, EBS customers should always use the adamin tool instead of manually compiling EBS / Apps database objects.<br>
Please follow Troubleshooting Guide - invalid objects in the E-Business Suite Environment 11i and 12 [1325394.1] for more information.',
      p_success_msg            => 'Nice Work !!!
There are no invalid objects found on your instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','Y')
      );
   l_info.delete;debug('end add_signature: CP1_INVALIDS_BY_SCHEMA');

debug('begin add_signature: CP2_PENDREQHOLD');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_PENDREQHOLD',
      p_sig_sql                => 'SELECT request_id "REQ ID", nvl(meaning, ''UNKNOWN'') "STATUS", user_concurrent_program_name "PROGRAM NAME",
to_char(request_date, ''DD-MON-RR HH24:MI:SS'') "SUBMITTED"
FROM fnd_concurrent_requests fcr, fnd_lookups fl, fnd_concurrent_programs_vl fcpv
WHERE phase_code = ''P'' AND hold_flag = ''Y'' AND fcr.requested_start_date <= sysdate
AND status_code != ''P'' AND LOOKUP_TYPE = ''CP_STATUS_CODE'' AND lookup_code = status_code
AND fcr.concurrent_program_id = fcpv.concurrent_program_id AND fcr.program_application_id = fcpv.application_id
ORDER BY request_date, request_id',
      p_title                  => 'Listing of Pending Requests on Hold',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Pending Requests on Hold and wating to be run',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently scheduled on the system. <br>
    Otherwise there is no immediate action required.<br>
    To get a complete list of Pending Requests on Hold including the Request ID, run the query behind the SQL SCRIPT button.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of Pending Requests on Hold and wating to be run. <br>
    Otherwise there is no immediate action required.<br>
    To get a complete list of Pending Requests on Hold including the Request ID, run the query behind the SQL SCRIPT button.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_PENDREQHOLD');

debug('begin add_signature: CP2_SCHEDULEDREQ2');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_SCHEDULEDREQ2',
      p_sig_sql                => 'SELECT request_id id, nvl(meaning, ''UNKNOWN'') status, user_concurrent_program_name pname,
to_char(request_date, ''DD-MON-RR HH24:MI:SS'') submitd, to_char(requested_start_date, ''DD-MON-RR HH24:MI:SS'') requestd
FROM   fnd_concurrent_requests fcr, fnd_lookups fl, fnd_concurrent_programs_vl fcpv
WHERE  phase_code = ''P'' AND hold_flag = ''N'' AND fcr.requested_start_date <= sysdate
AND status_code != ''P'' AND LOOKUP_TYPE = ''CP_STATUS_CODE'' AND lookup_code = status_code
AND fcr.concurrent_program_id = fcpv.concurrent_program_id AND fcr.program_application_id = fcpv.application_id
ORDER BY request_date, request_id',
      p_title                  => 'Listing of Scheduled Requests',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are not scheduled requests waiting to run that are currently not on hold.',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of whats currently scheduled on the system. <br>
    Otherwise there is no immediate action required.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of Pending Requests waiting to run that are currently not on hold.. <br>
    Otherwise there is no immediate action required.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_SCHEDULEDREQ2');

debug('begin add_signature: CP4_STD_MGR_VALIDATE');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_STD_MGR_VALIDATE',
      p_sig_sql                => 'select decode(c.include_flag,''E'',''Exclude'',''I'',''Include'') "INCLUDE_FLAG",
decode (c.type_code,''C'',''Combined Rule'',''L'',''Logical DB'',
''O'',''Oracle ID'',''P'',''Program'',''R'',''Request Type'',''U'',''User'') "TYPE_CODE",
a.application_name, t.user_concurrent_program_name
from fnd_concurrent_queue_content c, fnd_concurrent_programs p,
fnd_concurrent_programs_tl t, fnd_application_tl a
where c.concurrent_queue_id = 0
and c.type_application_id = p.application_id
and c.type_id = p.concurrent_program_id
and p.application_id = a.application_id
and t.concurrent_program_id = p.concurrent_program_id
and a.language=t.language',
      p_title                  => 'Validate Standard Manager Definition',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'You should not alter the definition of the Standard concurrent manager. <br>
',
      p_solution               => 'Ensure that the Standard Manager''s definition has not been changed with a "Included" Specialization" rule--"Excluded" is ok. <br>
If you do, and you have not defined additional managers to accept your requests, some programs may not run. Use the Standard manager as a safety net, a manager who is always available to run any request. Define additional managers to handle your installation site''s specific needs.
<br><br>
(Responsibility = System Administrator, Navigate --> Concurrent: Manager: Define)<br>
Any changes requires that you "Verify" the Internal Concurrent Manager on the "Administer Concurrent Managers" screen.<br><br>
When changing manager specialization or program incompatibilities, remember to "Verify" the ICM on the Administer Concurrent Manager form or bounce (restart) the concurrent managers for the changes to take effect.
',
      p_success_msg            => 'No rows were selected so I am calling this a success.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_STD_MGR_VALIDATE');

debug('begin add_signature: CP3_FND_CP_GSM_OPP_AQTBL');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP3_FND_CP_GSM_OPP_AQTBL',
      p_sig_sql                => 'select ''AQ$_FND_CP_GSM_OPP_AQTBL'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.FND_CP_GSM_OPP_AQTBL
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_S'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_S
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_T'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_T
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_T'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_T
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_H'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_H
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_I'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_I
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_I'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_I
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_G'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_G
union
select ''AQ$_FND_CP_GSM_OPP_AQTBL_L'' "NAME", ''<div align="right">''||to_char(count(*),''999,999,999,999'')||''</div>'' "COUNT" from applsys.AQ$_FND_CP_GSM_OPP_AQTBL_L',
      p_title                  => 'Status of AQ$_FND_CP_GSM_OPP_AQTBL tables',
      p_fail_condition         => '[COUNT] > [500]',
      p_problem_descr          => '<b>The AQ$_FND_CP_GSM_OPP_AQTBL table has many rows</b><br>
AQs tables are used to look for "subscriptions" by FNDSMs. <br>That is, when ICM calls for FNDSM to start, they "subscribe" to this queue to identify its status. The time taking for the  process cleanup prior to the ICM starting up the regular CMs is correlated to the number of processes that were not stopped cleanly. In case of un-clean shutdown, the process to restart will be longer as manager spends extra cycles to perform housekeeping tasks.',
      p_solution               => '<ul><li>It is highly recommended to always ensure the clean shutdown of the concurrent managers.</li>
<li>The Purge Concurrent Request and/or Manager Data Program request should be run periodically, however, it does not Purge AQ Tables.<br>
For maintaining a healthy level of records in FND_CONCURRENT_REQUESTS instead of running ''Purge Concurrent Program'' with the same parameters for all the applications, try running it for different applications depending on the number of days the data should be kept for.</li>
<li>It is recommended to schedule a cron job to query records in APPLSYS.FND_CP_GSM_OPP_AQTBL to monitor it and use DBMS_AQADM.PURGE_QUEUE_TABLE to purge the table as needed.</li>
<li>Follow the steps outlined in <b>[1156523.1] - <i>How To Purge FND_AQ Tables</i></b> on how to purge the FND_CP_GSM_OPP_AQTBL table manually to clean up the associated tables and indexes.</li></ul>',
      p_success_msg            => 'The AQ$_FND_CP_GSM_OPP_AQTBL table counts look fine.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP3_FND_CP_GSM_OPP_AQTBL');

debug('begin add_signature: CP1_PROFILES');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_PROFILES',
      p_sig_sql                => 'SELECT t.PROFILE_OPTION_ID "PROFILE OPTION ID", t.PROFILE_OPTION_NAME "NAME", z.language "LANG", z.USER_PROFILE_OPTION_NAME "DISPLAY NAME",
v.PROFILE_OPTION_VALUE "VALUE", z.DESCRIPTION
from fnd_profile_options t, fnd_profile_option_values v, fnd_profile_options_tl z
where (v.PROFILE_OPTION_ID (+) = t.PROFILE_OPTION_ID)
and (v.level_id = 10001)
and (z.PROFILE_OPTION_NAME = t.PROFILE_OPTION_NAME)
and (z.language = ''US'')
and (t.PROFILE_OPTION_NAME in (''CONC_GSM_ENABLED'',''CONC_PP_RESPONSE_TIMEOUT'',''CONC_TM_TRANSPORT_TYPE'',''GUEST_USER_PWD'',
''AFLOG_ENABLED'',''AFLOG_FILENAME'',''AFLOG_LEVEL'',''AFLOG_BUFFER_MODE'',''AFLOG_MODULE'',
''FND_FWK_COMPATIBILITY_MODE'',''FND_VALIDATION_LEVEL'',''FND_MIGRATED_TO_JRAD'',''AMPOOL_ENABLED'',
''CONC_PP_PROCESS_TIMEOUT'',''CONC_DEBUG'',''CONC_COPIES'',''CONC_FORCE_LOCAL_OUTPUT_MODE'',''CONC_HOLD'',
''CONC_CD_ID'',''CONC_PMON_METHOD'',''CONC_PP_INIT_DELAY'',''CONC_PRINT_WARNING'',''CONC_REPORT_ACCESS_LEVEL'',
''CONC_REQUEST_LIMIT'',''CONC_SINGLE_THREAD'',''CONC_TOKEN_TIMEOUT'',''CONC_VALIDATE_SUBMISSION'',
''FND_CONC_ALLOW_DEBUG'',''CP_INSTANCE_CHECK'',''FND_NATIVE_CLIENT_ENCODING'',''ICX_CLIENT_IANA_ENCODING'',
''FS_SVC_PREFIX'',''FS_MAX_TRANS'',''FND_SMTP_HOST'',''FND_SMTP_PORT'',''CONC_FORCE_LOCAL_OUTPUT_FILE_MODE'',
''CONC_DATE_INCREMENT_OPTION'',''FS_DELETE'',''FS_ENABLED'',''FS_MAX_TRANS'',''EDITOR_PS'',''FNDCPVWR_FONT_SIZE'',
''FS_MIME_PDF'',''FS_MIME_XML''))
order by t.PROFILE_OPTION_NAME',
      p_title                  => 'E-Business Suite Profile Settings',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There is a problem identifying the E-Business Suite Profile Settings',
      p_solution               => 'Verify the E-Business Suite Profile Settings',
      p_success_msg            => 'E-Business Suite Profile Settings',
      p_print_condition        => nvl('SUCCESS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_PROFILES');

debug('begin add_signature: CP4_XDO_SETTINGS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP4_XDO_SETTINGS',
      p_sig_sql                => 'select property_code "PROPERTY CODE", value, config_level "CONFIG LEVEL", data_source_code "DATA SOURCE CODE", template_code "TEMPLATE CODE", application_short_name "APP SHORT NAME", last_update_date "LAST UPDATE"
from XDO_CONFIG_VALUES order by property_code',
      p_title                  => 'XDO Settings',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'No XDO Settings for this instance.',
      p_solution               => 'Need a solution here.',
      p_success_msg            => 'XDO Settings have been found on this instance.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP4_XDO_SETTINGS');

debug('begin add_signature: CP_STD_MGR_LONG_RUN');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP_STD_MGR_LONG_RUN',
      p_sig_sql                => 'SELECT r.request_id "REQ ID", a.application_name "APPLICATION",
t.user_concurrent_program_name "PROGRAM", p.concurrent_program_name "SHORT NAME",
DECODE(p.execution_method_code, ''I'',''PL/SQL Concurrent Program'',''K'',''Java Concurrent Program'',
''P'',''Oracle*Reports Concurrent Program'',''Q'',''SQL*Plus Concurrent Program'') "EXECUTION METHOD",
DECODE(p.queue_method_code,''B'',''B=Yes'',''I'',''I=No'') "QUEUE METHOD", u.user_name "USER",
TO_CHAR(r.requested_start_date, ''DD-MON-RR HH24:MI:SS'') "STARTED",
r.is_sub_request "IS SUB REQUEST", 
DECODE(r.PHASE_CODE, ''C'',''Completed'',''I'',''I=Inactive'',''P'',''P=Pending'',''R'',''R=Running'') "PHASE",
DECODE(r.STATUS_CODE, ''A'',''Waiting'',''B'',''B=Resuming'',''C'',''C=Normal'',
  ''D'',''D=Cancelled'',''E'',''E=Error'',''G'',''G=Warning'',
 ''H'',''H=On Hold'',''I'',''I=Normal'',''M'',''M=No Manager'',
 ''P'',''P=Scheduled'',''Q'',''Q=Standby'',''R'',''R=Normal'',
 ''S'',''S=Suspended'',''T'',''T=Terminating'',''U'',''U=Disabled'',
 ''W'',''W=Paused'',''X'',''X=Terminated'',''Z'',''Z=Waiting'') "STATUS"
FROM apps.fnd_concurrent_programs_tl t,
apps.fnd_concurrent_programs p, apps.fnd_application_tl a,
apps.fnd_concurrent_requests r,apps.fnd_languages l,
apps.fnd_user u
WHERE a.application_id = t.application_id
and r.concurrent_program_id = t.concurrent_program_id
and t.concurrent_program_id = p.concurrent_program_id
AND r.nls_language = l.nls_language
AND l.language_code = t.language
AND l.language_code = a.language
AND r.requested_by = u.user_id
and p.run_alone_flag = ''Y''',
      p_title                  => 'Long Running Programs',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'This is my Warning message because rows were detected
<br><br>
"Run Alone" programs will cause a momentary "Inactive No Manager" and/or "Pending" status, because no program can run while a "Run Alone" program runs. With the following SQL, check what program(s) are causing the prolonged  "Inactive No Manager" state.
',
      p_solution               => 'My Warning solution
<br><br>
The "Run Alone" option should be used very sparingly and only with short / quick running programs, because it block all other programs while it is queued / running.
',
      p_success_msg            => 'No rows were found so this is a success, meaning no long running programs are found.???',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP_STD_MGR_LONG_RUN');

debug('begin add_signature: CP1_FND_FILE');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP1_FND_FILE',
      p_sig_sql                => 'SELECT name, value
FROM  v$parameter
WHERE name = ''utl_file_dir''',
      p_title                  => 'Check FND_FILE Setup',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'The FND_FILE Setup is not enabled.',
      p_solution               => 'Need to correct this<br>Please review [210062.1] - Concurrent Processing - Generic Service Management (GSM) in Oracle Applications, for more information.',
      p_success_msg            => '<b>FND_FILE Setup is enabled as expected.</b><br>
    For more information, please review [261693.1] - Concurrent Processing - Troubleshooting Concurrent Request ORA-20100 errors in the request logs.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('E','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP1_FND_FILE');

debug('begin add_signature: CP2_LASTMONDAILY');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_LASTMONDAILY',
      p_sig_sql                => 'SELECT trunc(REQUESTED_START_DATE) "REQUESTED START DATE", ''<div align="right">''||to_char(count(request_id),''999,999,999,999'')||''</div>'' "COUNTS"
FROM FND_CONCURRENT_REQUESTS
WHERE REQUESTED_START_DATE BETWEEN sysdate-30 AND sysdate
group by rollup(trunc(REQUESTED_START_DATE))',
      p_title                  => 'Volume of Daily Concurrent Requests for Last Month',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no rows showing Volume of Daily Concurrent Requests for Last Month',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline of your average monthly throughput, and identify any spikes or drops. <br>
    Otherwise there is no immediate action required.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline of your average monthly throughput, and identify any spikes or drops. <br>
    Otherwise there is no immediate action required.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_LASTMONDAILY');

debug('begin add_signature: BIPXDO_CONC_FORCE_LOCAL_OUTPUT_FILE_MODE');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'BIPXDO_CONC_FORCE_LOCAL_OUTPUT_FILE_MODE',
      p_sig_sql                => 'select
      b.user_profile_option_name profile_name
      , a.profile_option_name profile_short_name
      , decode(to_char(c.level_id),''10001'',''Site''
      ,''10002'',''Application''
      ,''10003'',''Responsibility''
      ,''10004'',''User''
      ,''Unknown'') Level_type
      , decode(to_char(c.level_id),''10001'',''Site''
      ,''10002'',nvl(h.application_short_name,to_char(c.level_value))
      ,''10003'',nvl(g.responsibility_name,to_char(c.level_value))
      ,''10004'',nvl(e.user_name,to_char(c.level_value))
      ,''Unknown'') level_value
      , c.PROFILE_OPTION_VALUE profile_value
    from
      apps.fnd_profile_options a
      , apps.FND_PROFILE_OPTIONS_VL b
      , apps.FND_PROFILE_OPTION_VALUES c
      , apps.FND_USER d
      , apps.FND_USER e
      , apps.FND_RESPONSIBILITY_VL g
      , apps.FND_APPLICATION h
    where
      b.user_profile_option_name like ''%Concurrent%Force%Output%''
      and a.profile_option_name = b.profile_option_name
      and a.profile_option_id = c.profile_option_id
      and a.application_id = c.application_id
      and c.last_updated_by = d.user_id (+)
      and c.level_value = e.user_id (+)
      and c.level_value = g.responsibility_id (+)
      and c.level_value = h.application_id (+)
      order by
      b.user_profile_option_name, c.level_id,
      decode(to_char(c.level_id),''10001'',''Site''
      ,''10002'',nvl(h.application_short_name,to_char(c.level_value))
      ,''10003'',nvl(g.responsibility_name,to_char(c.level_value))
      ,''10004'',nvl(e.user_name,to_char(c.level_value))
      ,''Unknown'')',
      p_title                  => 'Verify Force Local Output File Mode Profile',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'Concurrent: Force Local Output File Mode profile option is not set.',
      p_solution               => 'Please set Concurrent: Force Local Output File Mode profile option.',
      p_success_msg            => 'Concurrent: Force Local Output File Mode is set as expected',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: BIPXDO_CONC_FORCE_LOCAL_OUTPUT_FILE_MODE');

debug('begin add_signature: CP2_RUNALONE');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_RUNALONE',
      p_sig_sql                => 'SELECT CONCURRENT_PROGRAM_NAME "SHORT NAME", USER_CONCURRENT_PROGRAM_NAME "PROGRAM NAME", RUN_ALONE_FLAG "RUN ALONE", ENABLED_FLAG "ENABLED",   DESCRIPTION
FROM FND_CONCURRENT_PROGRAMS_VL
WHERE (RUN_ALONE_FLAG=''Y'')
order by RUN_ALONE_FLAG, ENABLED_FLAG desc',
      p_title                  => 'Identify/Resolve the "Pending/Standby" Issue, if Caused by Run Alone Flag',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no Requests that Identify/Resolve the "Pending/Standby" Issue, if Caused by Run Alone Flag',
      p_solution               => 'The output provided is for review and confirmation by your teams, and is intended to identify any concurrent program definitions causing Pending/Standby Requests which may require review.',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and is intended to identify any concurrent program definitions causing Pending/Standby Requests which may require review.',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_RUNALONE');

debug('begin add_signature: OPP_PENDING_REQS');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'OPP_PENDING_REQS',
      p_sig_sql                => 'select concurrent_request_id, action_type
                 from fnd_conc_pp_actions
                where action_type >= 6
               and processor_id is null',
      p_title                  => 'Check Pending OPP Requests',
      p_fail_condition         => 'RS',
      p_problem_descr          => 'There are pending OPP Requests
',
      p_solution               => 'We need a solution for pending OPP Requests if this is really a Warning scenario.<br><br>
<b>Note :</b>Output Post Processing currently does not display “Pending Requests” like any other Manager (for Example Standard Manager).<br><br>
This keep the customers in dark with respect to “workload of OPP”. They could not perform “sizing” of the OPP ; to handle the load of the system. For Standard Manager, they know how many requests pending (on the screen) . Hence they could resize the Manager process accordingly. But OPP they could not do so.
Support is currently using the following query to find pending requests against OPP (Based on Dev input)
</blockquote>
SQL> select concurrent_request_id, action_type
     from fnd_conc_pp_actions
     where action_type >= 6
     and processor_id is null;</blockquote>
Most of the time, Requests stuck in Running/Normal as the requests wait at OPP. Because they do not know the pending queue size (OPP), customer inadvertently increases the Standard Manager process to speed up which goes in vain. That results in performance issue in the concurrent manager layer.
We need to display the “Pending Requests” in Concurrent Administer Screen for “OPP”.<br><br>
Bug 24626221 - CONCURRENT ADMINISTER SCREEN TO DISPLAY PENDING REQUESTS',
      p_success_msg            => 'Success!!!<br>
There are no OPP pending requests at this time.<br><br>
<b>Note :</b>Output Post Processing currently does not display “Pending Requests” like any other Manager (for Example Standard Manager).<br><br>
This keep the customers in dark with respect to “workload of OPP”. They could not perform “sizing” of the OPP ; to handle the load of the system. For Standard Manager, they know how many requests pending (on the screen) . Hence they could resize the Manager process accordingly. But OPP they could not do so.
Support is currently using the following query to find pending requests against OPP (Based on Dev input)
</blockquote>
SQL> select concurrent_request_id, action_type
     from fnd_conc_pp_actions
     where action_type >= 6
     and processor_id is null;</blockquote>
Most of the time, Requests stuck in Running/Normal as the requests wait at OPP. Because they do not know the pending queue size (OPP), customer inadvertently increases the Standard Manager process to speed up which goes in vain. That results in performance issue in the concurrent manager layer.
We need to display the “Pending Requests” in Concurrent Administer Screen for “OPP”.<br><br>
Bug 24626221 - CONCURRENT ADMINISTER SCREEN TO DISPLAY PENDING REQUESTS',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('W','W'),
      p_print_sql_output       => nvl('Y','RS'),
      p_limit_rows             => nvl('N','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: OPP_PENDING_REQS');

debug('begin add_signature: CP2_TABLESPACES');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_TABLESPACES',
      p_sig_sql                => 'SELECT SEGMENT_NAME "TABLE NAME",
''<div align="right">''||to_char(sum(BLOCKS),''999,999,999,999'')||''</div>'' "TOTAL BLOCKS",
''<div align="right">''||to_char(sum(bytes/1024/1024),''999,999,999,999'')||''</div>'' "SIZE IN MB"
from dba_segments
where segment_name in (''FND_CONCURRENT_REQUESTS'',''FND_CONCURRENT_PROCESSES'',''FND_CONCURRENT_QUEUES'',
''FND_ENV_CONTEXT'',''FND_EVENTS'',''FND_EVENT_TOKENS'')
group by segment_name
order by 2',
      p_title                  => 'Tablespace Statistics for the FND_CONCURRENT Tables',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no rows found for Tablespace Statistics for the FND_CONCURRENT Tables',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline regarding your tablespace disk overhead. <br>
    You can cross reference the collected information with exisiting notes on tablespace sizing and defragmentation best practices',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline regarding your tablespace disk overhead. <br>
    You can cross reference the collected information with exisiting notes on tablespace sizing and defragmentation best practices',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_TABLESPACES');

debug('begin add_signature: CP2_TABLESPACES2');
   l_info('SHOW_SQL'):= 'Y';
  add_signature(
      p_sig_id                 => 'CP2_TABLESPACES2',
      p_sig_sql                => 'SELECT table_name "TABLE NAME", ''<div align="right">''||to_char(blocks,''999,999,999,999'')||''</div>'' "BLOCKS",
''<div align="right">''||to_char(empty_blocks,''999,999,999,999'')||''</div>'' "EMPTY BLOCKS",
''<div align="right">''||to_char(num_rows,''999,999,999,999'')||''</div>'' "LAST ANALYZED",
''<div align="right">''||to_char(sample_size,''999,999,999,999'')||''</div>'' "SAMPLE SIZE"
FROM   all_tables
WHERE table_name in (''FND_CONCURRENT_REQUESTS'',''FND_CONCURRENT_PROCESSES'',
''FND_CONCURRENT_QUEUES'',''FND_ENV_CONTEXT'',''FND_EVENTS'',''FND_EVENT_TOKENS'')',
      p_title                  => 'Additional Tablespace Statistics for the FND_CONCURRENT Tables',
      p_fail_condition         => 'NRS',
      p_problem_descr          => 'There are no rows found for Additional Tablespace Statistics for the FND_CONCURRENT Tables',
      p_solution               => 'The output provided is for review and confirmation by your teams, and serves as a baseline regarding your tablespace disk overhead. <br>
    You can cross reference the collected information with exisiting notes on tablespace sizing and defragmentation best practices',
      p_success_msg            => 'The output provided is for review and confirmation by your teams, and serves as a baseline regarding your tablespace disk overhead. <br>
    You can cross reference the collected information with exisiting notes on tablespace sizing and defragmentation best practices',
      p_print_condition        => nvl('ALWAYS','ALWAYS'),
      p_fail_type              => nvl('I','W'),
      p_print_sql_output       => nvl('RS','RS'),
      p_limit_rows             => nvl('Y','Y'),
      p_extra_info             => l_info,
      p_child_sigs             => VARCHAR_TBL(),
      p_include_in_dx_summary  => nvl('Y','N')
      );
   l_info.delete;
debug('end add_signature: CP2_TABLESPACES2');
 
EXCEPTION WHEN OTHERS THEN
  print_log('Error in load_signatures');
  raise;
END load_signatures;

---------------------------------
-- MAIN ENTRY POINT
---------------------------------
PROCEDURE main(
            p_min_volume                   IN NUMBER      DEFAULT 3500
           ,p_max_volume                   IN NUMBER      DEFAULT 5000
           ,p_max_output_rows              IN NUMBER      DEFAULT 30
           ,p_debug_mode                   IN VARCHAR2    DEFAULT 'Y')
 IS
  l_sql_result VARCHAR2(1);
  l_step       VARCHAR2(5);
  l_analyzer_end_time   TIMESTAMP;
  l_completion_status  BOOLEAN;
BEGIN
  -- re-initialize values
  g_sect_no := 1;
  g_sig_id := 0;
  g_item_id := 0;  -- CG REMOVE
  g_sig_count := 0 ;
  -- initialize the global results hash
  g_results('S') := 0;
  g_results('W') := 0;
  g_results('E') := 0;
  g_results('I') := 0; 
  -- CG CHANGE This should be generated automagically but need to rethink the init/validation steps. We need to initialize the g_debug_mode flag before the file init!
  g_debug_mode := nvl(p_debug_mode, 'Y');
  IF g_is_concurrent THEN
     g_rep_info('Calling From'):='Concurrent Program';
  ELSE
     g_rep_info('Calling From'):='SQL Script';
  END IF;
  l_step := '10';
  initialize_files;
 
  l_step := '15';
  set_cloud_flag;
  IF (g_cloud_flag) THEN
     debug ('CG Cloud flag: TRUE');
  ELSE 
     debug ('CG Cloud flag: FALSE');
  END IF;
 
  -- Title of analyzer!! - do not add word 'analyzer' at the end as it is appended in code where title is called  
  analyzer_title := 'Concurrent Processing';
  l_step := '20';
   validate_parameters(
     p_min_volume                   => p_min_volume
    ,p_max_volume                   => p_max_volume
    ,p_max_output_rows              => p_max_output_rows
    ,p_debug_mode                   => p_debug_mode  );

  l_step := '30';
  l_step := '25';
  print_page_header; 
  l_step := '30';
  print_rep_header(analyzer_title);
  print_execdetails;
  print_parameters;
  l_step := '40';
  load_signatures;
 
  l_step := '45';
  create_hyperlink_table;
  l_step := '50';
  -- Start of Sections and signatures
  l_step := '60';
  debug('begin section: Main Section');
  -- Print the menu of the section screen
  start_main_section;
debug('begin section: EBS_CP_OVERVIEW');
start_section('E-Business Applications Concurrent Processing Analyzer Overview');
if (g_reqid_cnt < 100) THEN
 show_data_gauge;
 set_item_result(run_stored_sig('CP1_CONC_REQ3'));
 elsif (g_reqid_cnt > 99) THEN
  show_gauge_chart;
  if (g_reqid_cnt > 5000) THEN
   set_item_result(run_stored_sig('CP1_CONC_REQ1'));
   elsif (g_reqid_cnt > 3500) THEN
   set_item_result(run_stored_sig('CP1_CONC_REQ2'));
   else
   set_item_result(run_stored_sig('CP1_CONC_REQ3'));
  end if;
end if;
   set_item_result(run_stored_sig('CP1_ORPHANED_PURGE_DATA'));
   set_item_result(run_stored_sig('EBS_VERSION'));
   set_item_result(run_stored_sig('CP1_FNDRSRUN'));
   set_item_result(run_stored_sig('CP1_PURGEREQS'));
   set_item_result(run_stored_sig('CP1_PURGELIGIBLE'));
   set_item_result(run_stored_sig('CP1_NODE_INFO'));
   set_item_result(run_stored_sig('CP1_PARAMETERS'));
 if (g_cp_status = 'Active') THEN
    set_item_result(run_stored_sig('CP1_ENV1'));
 elsif (g_cp_status = 'Deactivated') THEN
    set_item_result(run_stored_sig('CP1_ENV2'));
 else
    set_item_result(run_stored_sig('CP1_ENV3'));
 end if;
   set_item_result(run_stored_sig('CP1_PROFILES'));
set_item_result(run_stored_sig('CP1_INVALIDS_BY_SCHEMA'));
if (g_apps_invalid_cnt > 100) then
   set_item_result(run_stored_sig('CP1_INVALIDS_ALL_HIGH'));
else
   set_item_result(run_stored_sig('CP1_INVALIDS_ALL_LOW'));
end if;
if (g_fnd_invalid_cnt > 5) then
   set_item_result(run_stored_sig('CP1_INVALIDS_FND_HIGH'));
else
   set_item_result(run_stored_sig('CP1_INVALIDS_FND_LOW'));
end if;
   set_item_result(run_stored_sig('CP1_FND_FILE'));
   set_item_result(check_rec_patches_7);
   IF g_rep_info('Apps Version')>='12.2' THEN
      set_item_result(check_rec_patches_2);
   END IF;
   IF (g_rep_info('Apps Version') < '12.0' ) THEN
      set_item_result(check_rec_patches_1);
   END IF;
if ((g_rep_info('Apps Version') < '12.0' ) and (g_CU2 = 'EXPLICIT') and (g_CU1 = 'NOT_APPLIED')) then
    set_item_result(check_rec_patches_1); --Check 11i Recommended Patches
elsif ((g_rep_info('Apps Version') < '12.1' ) and (g_RUP6 = 'EXPLICIT')) then
    set_item_result(check_rec_patches_3); --Check R12.0 Recommended Patches minus RUP4
elsif ((g_rep_info('Apps Version') < '12.1' ) and (g_RUP6 = 'NOT_APPLIED') and (g_RUP4 = 'NOT_APPLIED')) then
    set_item_result(check_rec_patches_2); --Check R12.0 Recommended Patches Min RUP4
else
    set_item_result(check_rec_patches_4); --Check Recommended Patches
end if;
end_section;
debug('end section: EBS_CP_OVERVIEW');
debug('begin section: EBS_CP_REQUEST');
start_section('E-Business Applications Concurrent Request Analysis');
   set_item_result(run_stored_sig('CP2_LONGRPTS'));
   set_item_result(run_stored_sig('CP2_ELAPSEDHIST'));
   set_item_result(run_stored_sig('CP2_CURRENTREQS'));
   set_item_result(run_stored_sig('CP2_CONCREQTOTALS'));
   set_item_result(run_stored_sig('CP2_CONCREQS2'));
   set_item_result(run_stored_sig('CP2_PENDREQ'));
   set_item_result(run_stored_sig('CP2_TOP_10_CONC_REQS'));
   set_item_result(run_stored_sig('CP2_PENDING_REQUESTS'));
   set_item_result(run_stored_sig('CP2_SCHEDULEDREQ'));
   set_item_result(run_stored_sig('CP2_PENDREQHOLD'));
   set_item_result(run_stored_sig('CP2_SCHEDULEDREQ2'));
   set_item_result(run_stored_sig('CP2_LASTMONDAILY'));
   set_item_result(run_stored_sig('CP2_RUNALONE'));
   set_item_result(run_stored_sig('CP2_TABLESPACES'));
   set_item_result(run_stored_sig('CP2_TABLESPACES2'));
end_section;
debug('end section: EBS_CP_REQUEST');
debug('begin section: EBS_CONC_MGR');
start_section('E-Business Applications Concurrent Manager Analysis');
   set_item_result(run_stored_sig('CP3_CPADV1'));
   set_item_result(run_stored_sig('CP3_CPADV2'));
   set_item_result(run_stored_sig('CP3_CPADV3'));
   set_item_result(run_stored_sig('CP3_CPADV4'));
   set_item_result(run_stored_sig('CP3_CPADV5'));
   set_item_result(run_stored_sig('CP3_CPADV11'));
   set_item_result(run_stored_sig('CP3_CPADV12'));
   set_item_result(run_stored_sig('CP3_CPADV17'));
   set_item_result(run_stored_sig('CP3_FND_CP_GSM_OPP_AQTBL'));
   set_item_result(run_stored_sig('BIPXDO_CONC_FORCE_LOCAL_OUTPUT_FILE_MODE'));
   set_item_result(run_stored_sig('OPP_PENDING_REQS'));
   set_item_result(run_stored_sig('CP4_XDO_SETTINGS'));
end_section;
debug('end section: EBS_CONC_MGR');
debug('begin section: STANDARD_MANAGER');
start_section('Standard Manager Analysis');
   IF g_std_mgr = 'STANDARD' and g_enabled = 'Y' and
(g_rep_info('Apps Version') >= '12.2.4' )  THEN
      set_item_result(run_stored_sig('CP4_STD_MGR_DEFINE_R12'));
      set_item_result(run_stored_sig('CP4_STD_MGR_DEFINE_CACHE'));
   END IF;
   IF g_std_mgr = 'STANDARD' and g_enabled = 'Y' and
(g_rep_info('Apps Version') < '12.2.4' )  THEN
      set_item_result(run_stored_sig('CP4_STD_MGR_DEFINE_11I'));
      set_item_result(run_stored_sig('CP4_STD_MGR_DEFINE_CACHE'));
   END IF;
   set_item_result(run_stored_sig('CP4_RUN_ALONE_PROGRAMS2'));
   set_item_result(run_stored_sig('CP4_STD_MGR'));
   set_item_result(run_stored_sig('CP4_STD_MGR_INCL'));
   set_item_result(run_stored_sig('CP_STD_MGR_INCLUDES'));
   set_item_result(run_stored_sig('CP4_STD_MGR_VALIDATE'));
   set_item_result(run_stored_sig('CP4_XDO_SETTINGS'));
   set_item_result(run_stored_sig('CP_STD_MGR_LONG_RUN'));
end_section;
debug('end section: STANDARD_MANAGER');

  -- End of Sections and signatures
 
  end_main_section;
  l_step := '140';
 
  g_analyzer_elapsed := stop_timer(g_analyzer_start_time);
  get_current_time(l_analyzer_end_time);
  print_execution_time (l_analyzer_end_time); 
 
  print_mainpage;
 
  print_footer;

  print_hidden_xml;
 
  close_files;
 
  IF g_is_concurrent THEN
     l_completion_status:=FND_CONCURRENT.SET_COMPLETION_STATUS('NORMAL','');
  END IF;
EXCEPTION WHEN others THEN
  g_retcode := 2;
  g_errbuf := 'Error in main at step '||l_step||': '||sqlerrm;
  print_log(g_errbuf);
  
  IF g_is_concurrent THEN
     l_completion_status:=FND_CONCURRENT.SET_COMPLETION_STATUS('ERROR',g_errbuf);
  END IF;
END main;

BEGIN

   null;


   main(
     p_min_volume                   => p_min_volume
    ,p_max_volume                   => p_max_volume  );

EXCEPTION WHEN OTHERS THEN
  dbms_output.put_line('Error encountered: '||sqlerrm);

END;

/
show errors
exit;
-- Exit required for bundling project so do not remove

No comments:

Post a Comment

[ERROR]: The value of s_patch_service_name is not set correctly in atleast one of the context files.

[ERROR]: The value of s_patch_service_name is not set correctly in atleast one of the context files. I got the issue below wh...