bool JICLocal::checkUniverse( int univ ) { switch( univ ) { case CONDOR_UNIVERSE_LOCAL: case CONDOR_UNIVERSE_VANILLA: case CONDOR_UNIVERSE_JAVA: // for now, we don't support much. :) return true; case CONDOR_UNIVERSE_STANDARD: case CONDOR_UNIVERSE_SCHEDULER: case CONDOR_UNIVERSE_MPI: case CONDOR_UNIVERSE_GRID: // these are at least valid tries, but we don't work with // any of them in stand-alone starter mode... yet. dprintf( D_ALWAYS, "ERROR: %s %s (%d) not supported without the " "schedd and/or shadow, aborting\n", ATTR_JOB_UNIVERSE, CondorUniverseName(univ), univ ); return false; default: // downright unsupported universes dprintf( D_ALWAYS, "ERROR: %s %s (%d) is not supported\n", ATTR_JOB_UNIVERSE, CondorUniverseName(univ), univ ); return false; } }
void initShadow( ClassAd* ad ) { int universe; if( ! ad->LookupInteger(ATTR_JOB_UNIVERSE, universe) ) { // change to the right universes when everything works. dprintf( D_ALWAYS, "WARNING %s not specified, assuming VANILLA\n", ATTR_JOB_UNIVERSE ); universe = CONDOR_UNIVERSE_VANILLA; } dprintf( D_ALWAYS, "Initializing a %s shadow for job %d.%d\n", CondorUniverseName(universe), cluster, proc ); int wantPS = 0; ad->LookupBool("WantParallelScheduling", wantPS); if (wantPS) { universe = CONDOR_UNIVERSE_PARALLEL; } switch ( universe ) { case CONDOR_UNIVERSE_PARALLEL: Shadow = new ParallelShadow(); break; case CONDOR_UNIVERSE_VANILLA: case CONDOR_UNIVERSE_JAVA: case CONDOR_UNIVERSE_VM: Shadow = new UniShadow(); break; case CONDOR_UNIVERSE_MPI: Shadow = new MPIShadow(); break; default: dprintf( D_ALWAYS, "This version of the shadow cannot support " "universe %d (%s)\n", universe, CondorUniverseName(universe) ); EXCEPT( "Universe not supported" ); } Shadow->init( ad, schedd_addr, xfer_queue_contact_info ); }
bool JICLocalSchedd::getUniverse( void ) { int univ; // first, see if we've already got it in our ad if( ! job_ad->LookupInteger(ATTR_JOB_UNIVERSE, univ) ) { dprintf( D_ALWAYS, "\"%s\" not found in job ClassAd\n", ATTR_JOB_UNIVERSE ); return false; } if( univ != CONDOR_UNIVERSE_LOCAL ) { dprintf( D_ALWAYS, "ERROR: %s %s (%d) is not supported by JICLocalSchedd\n", ATTR_JOB_UNIVERSE, CondorUniverseName(univ), univ ); return false; } return true; }