#ifndef __SGE_JOB_QMASTER_H #define __SGE_JOB_QMASTER_H /*___INFO__MARK_BEGIN__*/ /************************************************************************* * * The Contents of this file are made available subject to the terms of * the Sun Industry Standards Source License Version 1.2 * * Sun Microsystems Inc., March, 2001 * * * Sun Industry Standards Source License Version 1.2 * ================================================= * The contents of this file are subject to the Sun Industry Standards * Source License Version 1.2 (the "License"); You may not use this file * except in compliance with the License. You may obtain a copy of the * License at http://gridengine.sunsource.net/Gridengine_SISSL_license.html * * Software provided under this License is provided on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS, * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING. * See the License for the specific provisions governing your rights and * obligations concerning the Software. * * The Initial Developer of the Original Code is: Sun Microsystems, Inc. * * Copyright: 2001 by Sun Microsystems, Inc. * * All Rights Reserved. * ************************************************************************/ /*___INFO__MARK_END__*/ #ifndef __SGE_GDIP_H # include "sge_gdiP.h" #endif #include "sge_event.h" #include "sge_qmaster_timed_event.h" #include "uti/sge_monitor.h" #include "gdi/sge_gdi_ctx.h" #include "gdi/sge_gdi_packet.h" #include "sgeobj/sge_event.h" int sge_gdi_add_job(sge_gdi_ctx_class_t *ctx, lListElem **jep, lList **alpp, lList **lpp, char *ruser, char *rhost, uid_t uid, gid_t gid, char *group, sge_gdi_packet_class_t *packet, sge_gdi_task_class_t *task, monitoring_t *monitor); int sge_gdi_copy_job(sge_gdi_ctx_class_t *ctx, lListElem *jep, lList **alpp, lList **lpp, char *ruser, char *rhost, uid_t uid, gid_t gid, char *group, sge_gdi_packet_class_t *packet, sge_gdi_task_class_t *task, monitoring_t *monitor); int sge_gdi_mod_job(sge_gdi_ctx_class_t *ctx, lListElem *jep, lList **alpp, char *ruser, char *rhost, int sub_command); int sge_gdi_del_job(sge_gdi_ctx_class_t *ctx, lListElem *jep, lList **alpp, char *ruser, char *rhost, int sub_command, monitoring_t *monitor); void sge_add_job_event(ev_event type, lListElem *jep, lListElem *jatep); bool job_has_valid_account_string(const char *name, lList **answer_list); bool is_pe_master_task_send(lListElem *jatep); bool all_slave_jobs_finished(lListElem *jatep); void tag_all_host_gdil(lListElem *jatep); void sge_add_jatask_event(ev_event type, lListElem *jep, lListElem *jatask); void job_suc_pre(lListElem *jep); void job_suc_pre_ad(lListElem *jep); void sge_init_job_number(void); void sge_store_job_number(sge_gdi_ctx_class_t *ctx, te_event_t anEvent, monitoring_t *monitor); void job_ja_task_send_abort_mail(const lListElem *job, const lListElem *ja_task, const char *ruser, const char *rhost, const char *err_str); void job_mark_job_as_deleted(sge_gdi_ctx_class_t *ctx, lListElem *j, lListElem *t); void sge_job_spool(sge_gdi_ctx_class_t *); bool spool_write_script(lList **answer_list, u_long32 jobid, lListElem *jep); bool spool_delete_script(lList **answer_list, u_long32 jobid, lListElem *jep); bool spool_read_script(lList **answer_list, u_long32 jobid, lListElem *jep); u_long32 sge_get_job_number(sge_gdi_ctx_class_t *ctx, monitoring_t *monitor); int deny_soft_consumables(lList **alpp, lList *srl, const lList *master_centry_list); int job_verify_project(const lListElem *job, lList **alpp, const char *user, const char *group); int job_verify_predecessors(lListElem *job, lList **alpp); int verify_suitable_queues(lList **alpp, lListElem *jep, int *trigger, bool is_modify); int job_verify_predecessors_ad(lListElem *job, lList **alpp); #endif /* __SGE_JOB_QMASTER_H */