home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 5 Edit / 05-Edit.zip / listpm7.zip / appmain.cpp < prev    next >
C/C++ Source or Header  |  1999-06-12  |  2KB  |  63 lines

  1. /*
  2.     listPM list files under Presentation Manager. Uses Open Class Libarary.
  3.     Copyright (C) 1998, 1999  Paul Elliott
  4.  
  5.     This program is free software; you can redistribute it and/or modify
  6.     it under the terms of the GNU General Public License as published by
  7.     the Free Software Foundation; either version 2 of the License, or
  8.     (at your option) any later version.
  9.  
  10.     This program is distributed in the hope that it will be useful,
  11.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13.     GNU General Public License for more details.
  14.  
  15.     You should have received a copy of the GNU General Public License
  16.     along with this program; if not, write to the Free Software
  17.     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  18.  
  19.     Paul Elliott
  20.     PMB # 181
  21.     11900 Metric Blvd Ste. J
  22.     Austin Tx 78758-3117
  23.     pelliott@io.com
  24.  
  25. */
  26. #include "appmain.hpp"
  27.  
  28.  
  29. /*
  30.  * Universal main routine.
  31.  * solves the following problem:
  32.  * when a processes' main threads ends it kill all sub threads
  33.  * reguardless of weather they have more work to do.
  34.  * This main routine solves this by waiting for all threads be for exiting.
  35.  * it starts a main thread specified by user, then waits for all threads.
  36.  * also it loads the argc and argv arguements into current application
  37.  * before starting a thread that must be defined by user which will
  38.  * do program main work.
  39.  * program must  define  MainThreadFn::run()
  40.  * which is code to do the work of the program.
  41.  *
  42.  */
  43. int main ( int argc, char * argv [] )
  44. {
  45.  
  46.    // set arguments into the application.
  47.    IApplication::current().setArgs( argc, argv );
  48.  
  49.    // processing for main thread here.
  50.  
  51.    // create and start main thread
  52.    IThread main_thread (  new MainThreadFn );
  53.    // new NainThreadFn will be stored into managed pointer
  54.    // so it will be deleted when this thread exits.
  55.  
  56.  
  57.    // if we have started threads, we must wait for them
  58.    // because otherwise the will be killed when main thread exits.
  59.    IThread::current().waitForAllThreads();
  60.  
  61.    return 0;
  62. };
  63.