X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2Fengine%2FBL_SALOMEServices.hxx;h=89273d8acca198bb2310df6a91b3523c0819a694;hb=002325475b17a7b93c51d8946e884a1404024a68;hp=f5e597d673863c10783b3c552b87016d6c1c5dd2;hpb=97482df035ee6e97dde980312a5b02d356b03702;p=modules%2Fjobmanager.git diff --git a/src/engine/BL_SALOMEServices.hxx b/src/engine/BL_SALOMEServices.hxx index f5e597d..89273d8 100644 --- a/src/engine/BL_SALOMEServices.hxx +++ b/src/engine/BL_SALOMEServices.hxx @@ -1,63 +1,110 @@ -// Copyright (C) 2009 CEA/DEN, EDF R&D +// Copyright (C) 2009-2022 CEA/DEN, EDF R&D // -// This library is free software; you can redistribute it and/or -// modify it under the terms of the GNU Lesser General Public -// License as published by the Free Software Foundation; either -// version 2.1 of the License. +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. // -// This library is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -// Lesser General Public License for more details. +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. // -// You should have received a copy of the GNU Lesser General Public -// License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef _BL_SALOMESERVICES_HXX_ #define _BL_SALOMESERVICES_HXX_ +#include "BL_Engine.hxx" #include "BL_Traces.hxx" #include "BL_Job.hxx" +#include "BL_NamingService_Wrapper.hxx" #include "SALOME_NamingService.hxx" #include "SALOME_LifeCycleCORBA.hxx" #include "SALOME_ContainerManager.hh" +#include "BL_JobsManager.hxx" #include #include #include +#include "JOBMANAGER_IDL.hh" + + namespace BL{ - class SALOMEServices + class JobsManager; + + struct BL_Engine_EXPORT ResourceDescr + { + std::string name; + std::string hostname; + std::string protocol; + std::string username; + std::string applipath; + std::list componentList; + + std::string OS; + unsigned int mem_mb; + unsigned int cpu_clock; + unsigned int nb_node; + unsigned int nb_proc_per_node; + std::string batch; + std::string mpiImpl; + std::string iprotocol; + + bool can_launch_batch_jobs; + bool can_run_containers; + std::string working_directory; + }; + + class BL_Engine_EXPORT SALOMEServices : + public POA_JOBMANAGER::LauncherObserver { public: SALOMEServices(); virtual ~SALOMEServices(); bool initNS(); + void end(); + + void set_manager(BL::JobsManager * manager) {_manager = manager;} + + std::list getResourceList(bool batch_only); + BL::ResourceDescr getResourceDescr(const std::string& name); + void addResource(BL::ResourceDescr & new_resource); + void removeResource(const std::string & name); - std::list getMachineList(); + std::string save_jobs(const std::string & file_name); + std::string load_jobs(const std::string & file_name); + std::string create_job(BL::Job * job); std::string start_job(BL::Job * job); std::string refresh_job(BL::Job * job); std::string delete_job(BL::Job * job); + std::string stop_job(BL::Job * job); std::string get_results_job(BL::Job * job); + std::string get_assigned_hostnames(BL::Job * job); // Get names or ids of hosts assigned to the job - protected: - std::string start_yacs_job(BL::Job * job); + BL::Job * get_new_job(int job_number); + + virtual void notify(const char* event_name, const char * event_data); private: CORBA::ORB_var _orb; - SALOME_NamingService * _salome_naming_service; + BL_SALOME_NamingService_Wrapper * _salome_naming_service; SALOME_LifeCycleCORBA * _lcc; Engines::SalomeLauncher_var _salome_launcher; Engines::ResourcesManager_var _resources_manager; + BL::JobsManager * _manager; + bool _state; };