112027Sjungma@eit.uni-kl.de/*****************************************************************************
212027Sjungma@eit.uni-kl.de
312027Sjungma@eit.uni-kl.de  Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
412027Sjungma@eit.uni-kl.de  more contributor license agreements.  See the NOTICE file distributed
512027Sjungma@eit.uni-kl.de  with this work for additional information regarding copyright ownership.
612027Sjungma@eit.uni-kl.de  Accellera licenses this file to you under the Apache License, Version 2.0
712027Sjungma@eit.uni-kl.de  (the "License"); you may not use this file except in compliance with the
812027Sjungma@eit.uni-kl.de  License.  You may obtain a copy of the License at
912027Sjungma@eit.uni-kl.de
1012027Sjungma@eit.uni-kl.de    http://www.apache.org/licenses/LICENSE-2.0
1112027Sjungma@eit.uni-kl.de
1212027Sjungma@eit.uni-kl.de  Unless required by applicable law or agreed to in writing, software
1312027Sjungma@eit.uni-kl.de  distributed under the License is distributed on an "AS IS" BASIS,
1412027Sjungma@eit.uni-kl.de  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
1512027Sjungma@eit.uni-kl.de  implied.  See the License for the specific language governing
1612027Sjungma@eit.uni-kl.de  permissions and limitations under the License.
1712027Sjungma@eit.uni-kl.de
1812027Sjungma@eit.uni-kl.de *****************************************************************************/
1912027Sjungma@eit.uni-kl.de
2012027Sjungma@eit.uni-kl.de/*****************************************************************************
2112027Sjungma@eit.uni-kl.de
2212027Sjungma@eit.uni-kl.de  sc_main_main.cpp - Wrapper around user's toplevel routine `sc_main'.
2312027Sjungma@eit.uni-kl.de
2412027Sjungma@eit.uni-kl.de  Original Author: Andy Goodrich, Forte Design Systems
2512027Sjungma@eit.uni-kl.de
2612027Sjungma@eit.uni-kl.de CHANGE LOG APPEARS AT THE END OF THE FILE
2712027Sjungma@eit.uni-kl.de *****************************************************************************/
2812027Sjungma@eit.uni-kl.de
2912027Sjungma@eit.uni-kl.de
3012027Sjungma@eit.uni-kl.de#include "sysc/kernel/sc_cmnhdr.h"
3112027Sjungma@eit.uni-kl.de#include "sysc/kernel/sc_externs.h"
3212027Sjungma@eit.uni-kl.de#include "sysc/kernel/sc_except.h"
3312027Sjungma@eit.uni-kl.de#include "sysc/utils/sc_iostream.h"
3412027Sjungma@eit.uni-kl.de#include "sysc/utils/sc_report.h"
3512027Sjungma@eit.uni-kl.de#include "sysc/utils/sc_report_handler.h"
3612027Sjungma@eit.uni-kl.de#include "sysc/utils/sc_utils_ids.h"
3712027Sjungma@eit.uni-kl.de#include <vector>
3812027Sjungma@eit.uni-kl.de
3912027Sjungma@eit.uni-kl.denamespace sc_core {
4012027Sjungma@eit.uni-kl.de
4112027Sjungma@eit.uni-kl.deextern void pln();
4212027Sjungma@eit.uni-kl.de
4312027Sjungma@eit.uni-kl.destatic int    argc_copy;	// Copy of argc value passed to sc_elab_and_sim.
4412027Sjungma@eit.uni-kl.destatic char** argv_copy;	// Copy of argv value passed to sc_elab_and_sim.
4512027Sjungma@eit.uni-kl.de
4612027Sjungma@eit.uni-kl.destatic
4712027Sjungma@eit.uni-kl.deinline
4812027Sjungma@eit.uni-kl.devoid
4912027Sjungma@eit.uni-kl.demessage_function( const char* s )
5012027Sjungma@eit.uni-kl.de{
5112027Sjungma@eit.uni-kl.de    ::std::cout << "\n" << s << ::std::endl;
5212027Sjungma@eit.uni-kl.de}
5312027Sjungma@eit.uni-kl.de
5412027Sjungma@eit.uni-kl.debool sc_in_action = false;
5512027Sjungma@eit.uni-kl.de
5612027Sjungma@eit.uni-kl.deint sc_argc()
5712027Sjungma@eit.uni-kl.de{
5812027Sjungma@eit.uni-kl.de    return argc_copy;
5912027Sjungma@eit.uni-kl.de}
6012027Sjungma@eit.uni-kl.de
6112027Sjungma@eit.uni-kl.deconst char* const* sc_argv()
6212027Sjungma@eit.uni-kl.de{
6312027Sjungma@eit.uni-kl.de    return argv_copy;
6412027Sjungma@eit.uni-kl.de}
6512027Sjungma@eit.uni-kl.de
6612027Sjungma@eit.uni-kl.de
6712027Sjungma@eit.uni-kl.deint
6812027Sjungma@eit.uni-kl.desc_elab_and_sim( int argc, char* argv[] )
6912027Sjungma@eit.uni-kl.de{
7012027Sjungma@eit.uni-kl.de    int status = 1;
7112027Sjungma@eit.uni-kl.de    argc_copy = argc;
7212027Sjungma@eit.uni-kl.de    argv_copy = argv;
7312027Sjungma@eit.uni-kl.de    std::vector<char*> argv_call;
7412027Sjungma@eit.uni-kl.de    for ( int i = 0; i < argc; i++ )
7512027Sjungma@eit.uni-kl.de        argv_call.push_back(argv[i]);
7612027Sjungma@eit.uni-kl.de
7712027Sjungma@eit.uni-kl.de    try
7812027Sjungma@eit.uni-kl.de    {
7912027Sjungma@eit.uni-kl.de        pln();
8012027Sjungma@eit.uni-kl.de
8112027Sjungma@eit.uni-kl.de        // Perform initialization here
8212027Sjungma@eit.uni-kl.de        sc_in_action = true;
8312027Sjungma@eit.uni-kl.de
8412027Sjungma@eit.uni-kl.de        status = sc_main( argc, &argv_call[0] );
8512027Sjungma@eit.uni-kl.de
8612027Sjungma@eit.uni-kl.de        // Perform cleanup here
8712027Sjungma@eit.uni-kl.de        sc_in_action = false;
8812027Sjungma@eit.uni-kl.de    }
8912027Sjungma@eit.uni-kl.de    catch( const sc_report& x )
9012027Sjungma@eit.uni-kl.de    {
9112027Sjungma@eit.uni-kl.de	message_function( x.what() );
9212027Sjungma@eit.uni-kl.de    }
9312027Sjungma@eit.uni-kl.de    catch( ... )
9412027Sjungma@eit.uni-kl.de    {
9512027Sjungma@eit.uni-kl.de        // translate other escaping exceptions
9612027Sjungma@eit.uni-kl.de        sc_report*  err_p = sc_handle_exception();
9712027Sjungma@eit.uni-kl.de        if( err_p ) message_function( err_p->what() );
9812027Sjungma@eit.uni-kl.de        delete err_p;
9912027Sjungma@eit.uni-kl.de    }
10012027Sjungma@eit.uni-kl.de
10112027Sjungma@eit.uni-kl.de    // IF DEPRECATION WARNINGS WERE ISSUED TELL THE USER HOW TO TURN THEM OFF
10212027Sjungma@eit.uni-kl.de
10312027Sjungma@eit.uni-kl.de    if ( sc_report_handler::get_count( SC_ID_IEEE_1666_DEPRECATION_ ) > 0 )
10412027Sjungma@eit.uni-kl.de    {
10512027Sjungma@eit.uni-kl.de        std::stringstream ss;
10612027Sjungma@eit.uni-kl.de
10712027Sjungma@eit.uni-kl.de#       define MSGNL  "\n             "
10812027Sjungma@eit.uni-kl.de#       define CODENL "\n  "
10912027Sjungma@eit.uni-kl.de
11012027Sjungma@eit.uni-kl.de        ss <<
11112027Sjungma@eit.uni-kl.de          "You can turn off warnings about" MSGNL
11212027Sjungma@eit.uni-kl.de          "IEEE 1666 deprecated features by placing this method call" MSGNL
11312027Sjungma@eit.uni-kl.de          "as the first statement in your sc_main() function:\n" CODENL
11412027Sjungma@eit.uni-kl.de          "sc_core::sc_report_handler::set_actions( "
11512027Sjungma@eit.uni-kl.de          "\"" << SC_ID_IEEE_1666_DEPRECATION_ << "\"," CODENL
11612027Sjungma@eit.uni-kl.de          "                                         " /* indent param */
11712027Sjungma@eit.uni-kl.de          "sc_core::SC_DO_NOTHING );"
11812027Sjungma@eit.uni-kl.de          << std::endl;
11912027Sjungma@eit.uni-kl.de
12012027Sjungma@eit.uni-kl.de        SC_REPORT_INFO( SC_ID_IEEE_1666_DEPRECATION_, ss.str().c_str() );
12112027Sjungma@eit.uni-kl.de    }
12212027Sjungma@eit.uni-kl.de
12312027Sjungma@eit.uni-kl.de    return status;
12412027Sjungma@eit.uni-kl.de}
12512027Sjungma@eit.uni-kl.de
12612027Sjungma@eit.uni-kl.de} // namespace sc_core
12712027Sjungma@eit.uni-kl.de
12812027Sjungma@eit.uni-kl.de// $Log: sc_main_main.cpp,v $
12912027Sjungma@eit.uni-kl.de// Revision 1.9  2011/08/26 20:46:10  acg
13012027Sjungma@eit.uni-kl.de//  Andy Goodrich: moved the modification log to the end of the file to
13112027Sjungma@eit.uni-kl.de//  eliminate source line number skew when check-ins are done.
13212027Sjungma@eit.uni-kl.de//
13312027Sjungma@eit.uni-kl.de// Revision 1.8  2011/05/09 04:07:48  acg
13412027Sjungma@eit.uni-kl.de//  Philipp A. Hartmann:
13512027Sjungma@eit.uni-kl.de//    (1) Restore hierarchy in all phase callbacks.
13612027Sjungma@eit.uni-kl.de//    (2) Ensure calls to before_end_of_elaboration.
13712027Sjungma@eit.uni-kl.de//
13812027Sjungma@eit.uni-kl.de// Revision 1.7  2011/02/18 20:27:14  acg
13912027Sjungma@eit.uni-kl.de//  Andy Goodrich: Updated Copyrights.
14012027Sjungma@eit.uni-kl.de//
14112027Sjungma@eit.uni-kl.de// Revision 1.6  2011/02/13 21:47:37  acg
14212027Sjungma@eit.uni-kl.de//  Andy Goodrich: update copyright notice.
14312027Sjungma@eit.uni-kl.de//
14412027Sjungma@eit.uni-kl.de// Revision 1.5  2010/03/15 18:29:25  acg
14512027Sjungma@eit.uni-kl.de//  Andy Goodrich: Changed the default stack size to 128K from 64K.
14612027Sjungma@eit.uni-kl.de//
14712027Sjungma@eit.uni-kl.de// Revision 1.4  2009/10/14 19:06:48  acg
14812027Sjungma@eit.uni-kl.de//  Andy Goodrich: changed the way the "copy" of argv is handled. It is
14912027Sjungma@eit.uni-kl.de//  now passed to sc_main, and the original is referenced via argv_copy.
15012027Sjungma@eit.uni-kl.de//
15112027Sjungma@eit.uni-kl.de// Revision 1.3  2008/05/22 17:06:25  acg
15212027Sjungma@eit.uni-kl.de//  Andy Goodrich: updated copyright notice to include 2008.
15312027Sjungma@eit.uni-kl.de//
15412027Sjungma@eit.uni-kl.de// Revision 1.2  2008/04/11 20:41:28  acg
15512027Sjungma@eit.uni-kl.de//  Andy Goodrich: changed the return value in sc_elab_and_sim() to be 1
15612027Sjungma@eit.uni-kl.de//  when an exception occurs in sc_main() rather than 0.
15712027Sjungma@eit.uni-kl.de//
15812027Sjungma@eit.uni-kl.de// Revision 1.1.1.1  2006/12/15 20:20:05  acg
15912027Sjungma@eit.uni-kl.de// SystemC 2.3
16012027Sjungma@eit.uni-kl.de//
16112027Sjungma@eit.uni-kl.de// Revision 1.4  2006/01/25 00:31:19  acg
16212027Sjungma@eit.uni-kl.de//  Andy Goodrich: Changed over to use a standard message id of
16312027Sjungma@eit.uni-kl.de//  SC_ID_IEEE_1666_DEPRECATION for all deprecation messages.
16412027Sjungma@eit.uni-kl.de//
16512027Sjungma@eit.uni-kl.de// Revision 1.3  2006/01/13 18:44:29  acg
16612027Sjungma@eit.uni-kl.de// Added $Log to record CVS changes into the source.
16712027Sjungma@eit.uni-kl.de//
168