home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 5 Edit / 05-Edit.zip / listpm2.zip / source / appmain.cpp next >
C/C++ Source or Header  |  1996-07-08  |  2KB  |  61 lines

  1. /*
  2.     listPM list files under Presentation Manager. Uses Open Class Libarary.
  3.     Copyright (C) 1996  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.     3987 South Gessner #224
  21.     Houston Tx 77063
  22.     Paul.Elliott@Hrnowl.LoneStar.Org
  23. */
  24. #include "appmain.hpp"
  25.  
  26.  
  27. /*
  28.  * Universal main routine.
  29.  * solves the following problem:
  30.  * when a processes' main threads ends it kill all sub threads
  31.  * reguardless of weather they have more work to do.
  32.  * This main routine solves this by waiting for all threads be for exiting.
  33.  * it starts a main thread specified by user, then waits for all threads.
  34.  * also it loads the argc and argv arguements into current application
  35.  * before starting a thread that must be defined by user which will
  36.  * do program main work.
  37.  * program must  define  MainThreadFn::run()
  38.  * which is code to do the work of the program.
  39.  *
  40.  */
  41. int main ( int argc, char * argv [] )
  42. {
  43.  
  44.    // set arguments into the application.
  45.    IApplication::current().setArgs( argc, argv );
  46.  
  47.    // processing for main thread here.
  48.  
  49.    // create and start main thread
  50.    IThread main_thread (  new MainThreadFn );
  51.    // new NainThreadFn will be stored into managed pointer
  52.    // so it will be deleted when this thread exits.
  53.  
  54.  
  55.    // if we have started threads, we must wait for them
  56.    // because otherwise the will be killed when main thread exits.
  57.    IThread::current().waitForAllThreads();
  58.  
  59.    return 0;
  60. };
  61.