jobs.c
author viric@llimona
Mon, 02 Apr 2007 17:53:52 +0200
changeset 74 bb1b20d79acf
parent 66 f70a27afd92e
child 92 05004c52ecff
permissions -rw-r--r--
Marking the TODO for 0.3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
49
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     1
/*
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     2
    Task Spooler - a task queue system for the unix user
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     3
    Copyright (C) 2007  LluĂ­s Batlle i Rossell
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     4
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     5
    Please find the license in the provided COPYING file.
09bb8a5583e9 Added the license.
lbatlle@npdl268.bpo.hp.com
parents: 44
diff changeset
     6
*/
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
     7
#include <stdlib.h>
44
4dcf05746ece Better include files.
viric@llimona
parents: 42
diff changeset
     8
#include <unistd.h>
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
     9
#include <stdio.h>
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    10
#include <assert.h>
44
4dcf05746ece Better include files.
viric@llimona
parents: 42
diff changeset
    11
#include <string.h>
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    12
#include "msg.h"
32
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
    13
#include "main.h"
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    14
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
    15
static enum
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
    16
{
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
    17
    FREE, /* No task is running */
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
    18
    WAITING /* A task is running, and the server is waiting */
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
    19
} state = FREE;
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
    20
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    21
struct Job
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    22
{
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    23
    struct Job *next;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    24
    int jobid;
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
    25
    char *command;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    26
    enum Jobstate state;
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
    27
    int errorlevel;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
    28
    char *output_filename;
27
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
    29
    int store_output;
35
83d0da612dc4 Kill the running job works fine.
viric@llimona
parents: 32
diff changeset
    30
    int pid;
55
678ca291d545 Now the '-nf' doesn't leave a job in 'finished' state.
viric@llimona
parents: 54
diff changeset
    31
    int should_keep_finished;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    32
};
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    33
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    34
struct Notify
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    35
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    36
    int socket;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    37
    int jobid;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    38
    struct Notify *next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    39
};
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    40
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    41
/* Globals */
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    42
static struct Job *firstjob = 0;
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
    43
static struct Job *first_finished_job = 0;
44
4dcf05746ece Better include files.
viric@llimona
parents: 42
diff changeset
    44
static int jobids = 0;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
    45
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    46
static struct Notify *first_notify = 0;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
    47
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    48
static void send_list_line(int s, const char * str)
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    49
{
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    50
    struct msg m;
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    51
21
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    52
    /* Message */
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    53
    m.type = LIST_LINE;
21
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    54
    m.u.line_size = strlen(str) + 1;
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    55
21
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    56
    send_msg(s, &m);
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    57
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    58
    /* Send the line */
a797f96a022f Lines for list doesn't have limit.
viric@llimona
parents: 20
diff changeset
    59
    send_bytes(s, str, m.u.line_size);
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    60
}
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
    61
53
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    62
static void send_urgent_ok(int s)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    63
{
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    64
    struct msg m;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    65
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    66
    /* Message */
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    67
    m.type = URGENT_OK;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    68
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    69
    send_msg(s, &m);
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    70
}
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    71
66
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    72
static void send_swap_jobs_ok(int s)
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    73
{
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    74
    struct msg m;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    75
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    76
    /* Message */
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    77
    m.type = SWAP_JOBS_OK;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    78
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    79
    send_msg(s, &m);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    80
}
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
    81
53
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    82
static struct Job * find_previous_job(struct Job *final)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    83
{
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    84
    struct Job *p;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    85
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    86
    /* Show Queued or Running jobs */
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    87
    p = firstjob;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    88
    while(p != 0)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    89
    {
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    90
        if (p->next == final)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    91
            return p;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    92
        p = p->next;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    93
    }
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    94
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    95
    return 0;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    96
}
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
    97
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
    98
static struct Job * findjob(int jobid)
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
    99
{
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   100
    struct Job *p;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   101
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   102
    /* Show Queued or Running jobs */
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   103
    p = firstjob;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   104
    while(p != 0)
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   105
    {
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   106
        if (p->jobid == jobid)
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   107
            return p;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   108
        p = p->next;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   109
    }
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   110
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   111
    return 0;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   112
}
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   113
32
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   114
static struct Job * find_finished_job(int jobid)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   115
{
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   116
    struct Job *p;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   117
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   118
    /* Show Queued or Running jobs */
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   119
    p = first_finished_job;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   120
    while(p != 0)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   121
    {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   122
        if (p->jobid == jobid)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   123
            return p;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   124
        p = p->next;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   125
    }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   126
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   127
    return 0;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   128
}
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   129
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   130
void s_mark_job_running()
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   131
{
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   132
    firstjob->state = RUNNING;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   133
}
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   134
63
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   135
const char * jstate2string(enum Jobstate s)
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   136
{
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   137
    char * jobstate;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   138
    switch(s)
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   139
    {
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   140
        case QUEUED:
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   141
            jobstate = "queued";
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   142
            break;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   143
        case RUNNING:
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   144
            jobstate = "running";
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   145
            break;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   146
        case FINISHED:
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   147
            jobstate = "finished";
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   148
            break;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   149
    }
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   150
    return jobstate;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   151
}
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   152
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   153
void s_list(int s)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   154
{
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   155
    struct Job *p;
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
   156
    char buffer[LINE_LEN];
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   157
39
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   158
    sprintf(buffer, "%-4s%-10s%-20s%-8s%-37s\n",
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   159
            "ID",
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   160
            "State",
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   161
            "Output",
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   162
            "E-Level",
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   163
            "Command");
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
   164
    send_list_line(s,buffer);
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   165
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   166
    /* Show Queued or Running jobs */
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   167
    p = firstjob;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   168
    while(p != 0)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   169
    {
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   170
        const char * jobstate;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   171
        const char * output_filename;
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   172
        jobstate = jstate2string(p->state);
27
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   173
        if (p->store_output)
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   174
        {
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   175
            if (p->state == RUNNING)
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   176
            {
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   177
                if (p->output_filename == 0)
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   178
                    /* This may happen due to concurrency
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   179
                     * problems */
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   180
                    output_filename = "(...)";
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   181
                else
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   182
                    output_filename = p->output_filename;
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   183
            } else
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   184
                output_filename = "(file)";
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   185
        } else
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   186
            output_filename = "stdout";
27
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   187
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   188
           
39
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   189
        sprintf(buffer, "%-4i%-10s%-20s%-8s%-37s\n",
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
   190
                p->jobid,
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   191
                jobstate,
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   192
                output_filename,
39
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   193
                "",
5
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
   194
                p->command);
bc5e251418f3 The LIST_LINEs are outputed by the client.
viric@llimona
parents: 3
diff changeset
   195
        send_list_line(s,buffer);
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   196
        p = p->next;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   197
    }
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   198
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   199
    p = first_finished_job;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   200
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   201
    if (p != 0)
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   202
    {
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   203
        /* Show Finished jobs */
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   204
        while(p != 0)
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   205
        {
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   206
            const char * jobstate;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   207
            const char * output_filename;
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   208
            jobstate = jstate2string(p->state);
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   209
            if (p->output_filename == 0)
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   210
                output_filename = "stdout";
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   211
            else
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   212
                output_filename = p->output_filename;
39
849ec300325c Better list output.
viric@llimona
parents: 35
diff changeset
   213
            sprintf(buffer, "%-4i%-10s%-20s%-8i%-37s\n",
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   214
                    p->jobid,
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   215
                    jobstate,
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   216
                    output_filename,
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   217
                    p->errorlevel,
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   218
                    p->command);
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   219
            send_list_line(s,buffer);
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   220
            p = p->next;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   221
        }
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   222
    }
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   223
}
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   224
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   225
static struct Job * newjobptr()
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   226
{
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   227
    struct Job *p;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   228
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   229
    if (firstjob == 0)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   230
    {
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   231
        firstjob = (struct Job *) malloc(sizeof(*firstjob));
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   232
        firstjob->next = 0;
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   233
        firstjob->output_filename = 0;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   234
        firstjob->command = 0;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   235
        return firstjob;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   236
    }
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   237
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   238
    p = firstjob;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   239
    while(p->next != 0)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   240
        p = p->next;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   241
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   242
    p->next = (struct Job *) malloc(sizeof(*p));
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   243
    p->next->next = 0;
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   244
    p->next->output_filename = 0;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   245
    p->next->command = 0;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   246
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   247
    return p->next;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   248
}
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   249
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   250
/* Returns job id */
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   251
int s_newjob(int s, struct msg *m)
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   252
{
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   253
    struct Job *p;
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   254
    int res;
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   255
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   256
    p = newjobptr();
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   257
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   258
    p->jobid = jobids++;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   259
    p->state = QUEUED;
27
886bdb2f4632 Fixed the Output File information in the list.
viric@llimona
parents: 26
diff changeset
   260
    p->store_output = m->u.newjob.store_output;
55
678ca291d545 Now the '-nf' doesn't leave a job in 'finished' state.
viric@llimona
parents: 54
diff changeset
   261
    p->should_keep_finished = m->u.newjob.should_keep_finished;
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   262
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   263
    /* load the command */
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   264
    p->command = malloc(m->u.newjob.command_size);
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   265
    /* !!! Check retval */
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   266
    res = recv_bytes(s, p->command, m->u.newjob.command_size);
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   267
    assert(res != -1);
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   268
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   269
    return p->jobid;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   270
}
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   271
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   272
void s_removejob(int jobid)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   273
{
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   274
    struct Job *p;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   275
    struct Job *newnext;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   276
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   277
    if (firstjob->jobid == jobid)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   278
    {
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   279
        struct Job *newfirst;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   280
        /* First job is to be removed */
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   281
        newfirst = firstjob->next;
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   282
        free(firstjob->command);
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   283
        free(firstjob->output_filename);
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   284
        free(firstjob);
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   285
        firstjob = newfirst;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   286
        return;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   287
    }
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   288
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   289
    p = firstjob;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   290
    /* Not first job */
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   291
    while (p->next != 0)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   292
    {
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   293
        if (p->next->jobid == jobid)
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   294
            break;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   295
        p = p->next;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   296
    }
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   297
    assert(p->next != 0);
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   298
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   299
    newnext = p->next->next;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   300
18
af4898956964 Now commands of any-length are accepted.
viric@llimona
parents: 9
diff changeset
   301
    free(p->next->command);
3
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   302
    free(p->next);
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   303
    p->next = newnext;
2fb8a6bdd024 More code.
viric@llimona
parents:
diff changeset
   304
}
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   305
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   306
/* -1 if no one should be run. */
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   307
int next_run_job()
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   308
{
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   309
    if (state == WAITING)
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   310
        return -1;
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   311
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   312
    if (firstjob != 0)
9
9acd8ae3190c First usable version!
lbatlle@npdl268.bpo.hp.com
parents: 8
diff changeset
   313
    {
9acd8ae3190c First usable version!
lbatlle@npdl268.bpo.hp.com
parents: 8
diff changeset
   314
        state = WAITING;
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   315
        return firstjob->jobid;
9
9acd8ae3190c First usable version!
lbatlle@npdl268.bpo.hp.com
parents: 8
diff changeset
   316
    }
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   317
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   318
    return -1;
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   319
}
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   320
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   321
/* Returns 1000 if no limit, The limit otherwise. */
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   322
static int get_max_finished_jobs()
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   323
{
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   324
    char *limit;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   325
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   326
    limit = getenv("TS_MAXFINISHED");
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   327
    if (limit == NULL)
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   328
        return 1000;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   329
    return abs(atoi(limit));
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   330
}
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   331
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   332
/* Add the job to the finished queue. */
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   333
static void new_finished_job(struct Job *j)
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   334
{
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   335
    struct Job *p;
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   336
    int count, max;
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   337
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   338
    max = get_max_finished_jobs();
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   339
    count = 0;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   340
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   341
    if (first_finished_job == 0 && count < max)
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   342
    {
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   343
        first_finished_job = j;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   344
        first_finished_job->next = 0;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   345
        return;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   346
    }
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   347
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   348
    ++count;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   349
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   350
    p = first_finished_job;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   351
    while(p->next != 0)
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   352
    {
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   353
        p = p->next;
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   354
        ++count;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   355
    }
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   356
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   357
    /* If too many jobs, wipe out the first */
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   358
    if (count >= max)
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   359
    {
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   360
        struct Job *tmp;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   361
        tmp = first_finished_job;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   362
        first_finished_job = first_finished_job->next;
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   363
        free(tmp->command);
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   364
        free(tmp->output_filename);
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   365
        free(tmp);
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   366
    }
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   367
    p->next = j;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   368
    p->next->next = 0;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   369
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   370
    return;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   371
}
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   372
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   373
void job_finished(int errorlevel)
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   374
{
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   375
    struct Job *newfirst;
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   376
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   377
    assert(state == WAITING);
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   378
    assert(firstjob != 0);
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   379
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   380
    assert(firstjob->state == RUNNING);
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   381
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   382
    /* Mark state */
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   383
    firstjob->state = FINISHED;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   384
    firstjob->errorlevel = errorlevel;
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   385
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   386
    /* Add it to the finished queue */
26
19d1bfdaa885 Fixed a bug with the job list.
viric@llimona
parents: 22
diff changeset
   387
    newfirst = firstjob->next;
55
678ca291d545 Now the '-nf' doesn't leave a job in 'finished' state.
viric@llimona
parents: 54
diff changeset
   388
    if (firstjob->should_keep_finished)
678ca291d545 Now the '-nf' doesn't leave a job in 'finished' state.
viric@llimona
parents: 54
diff changeset
   389
        new_finished_job(firstjob);
19
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   390
5efc347cca8d The finished jobs store the errorlevel, and can be listed.
viric@llimona
parents: 18
diff changeset
   391
    /* Remove it from the run queue */
26
19d1bfdaa885 Fixed a bug with the job list.
viric@llimona
parents: 22
diff changeset
   392
    firstjob = newfirst;
8
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   393
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   394
    state = FREE;
03339adb7014 Some more code for execution.
viric@llimona
parents: 5
diff changeset
   395
}
20
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   396
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   397
void s_clear_finished()
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   398
{
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   399
    struct Job *p;
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   400
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   401
    if (first_finished_job == 0)
20
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   402
        return;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   403
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   404
    p = first_finished_job;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   405
    first_finished_job = 0;
20
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   406
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   407
    while (p != 0)
20
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   408
    {
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   409
        struct Job *tmp;
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   410
        tmp = p->next;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   411
        free(p->command);
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   412
        free(p->output_filename);
20
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   413
        free(p);
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   414
        p = tmp;
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   415
    }
d85b4c0745fa "-c" added, for clearing the finished tasks' list.
viric@llimona
parents: 19
diff changeset
   416
}
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   417
35
83d0da612dc4 Kill the running job works fine.
viric@llimona
parents: 32
diff changeset
   418
void s_process_runjob_ok(int jobid, char *oname, int pid)
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   419
{
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   420
    struct Job *p;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   421
    p = findjob(jobid);
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   422
    assert(p != 0);
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   423
    assert(p->state == RUNNING);
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   424
35
83d0da612dc4 Kill the running job works fine.
viric@llimona
parents: 32
diff changeset
   425
    p->pid = pid;
22
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   426
    p->output_filename = oname;
afdc8410633f Now output can go to filenames.
viric@llimona
parents: 21
diff changeset
   427
}
32
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   428
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   429
void s_send_output(int s, int jobid)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   430
{
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   431
    struct Job *p = 0;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   432
    struct msg m;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   433
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   434
    if (jobid == -1)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   435
    {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   436
        /* This means that we want the tail of the running task, or that
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   437
         * of the last job run */
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   438
        if (state == WAITING)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   439
        {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   440
            p = firstjob;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   441
            assert(p != 0);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   442
        }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   443
        else
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   444
        {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   445
            p = first_finished_job;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   446
            if (p == 0)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   447
            {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   448
                send_list_line(s, "No jobs.\n");
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   449
                return;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   450
            }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   451
            while(p->next != 0)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   452
                p = p->next;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   453
        }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   454
    } else
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   455
    {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   456
        if (state == WAITING && firstjob->jobid == jobid)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   457
            p = firstjob;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   458
        else
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   459
            p = find_finished_job(jobid);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   460
    }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   461
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   462
    if (p == 0)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   463
    {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   464
        char tmp[50];
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   465
        sprintf(tmp, "Job %i not finished or not running.\n", jobid);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   466
        send_list_line(s, tmp);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   467
        return;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   468
    }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   469
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   470
    m.type = ANSWER_OUTPUT;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   471
    if (!p->store_output)
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   472
    {
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   473
        send_list_line(s, "The job hasn't output stored.\n");
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   474
        return;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   475
    }
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   476
    m.u.output.store_output = p->store_output;
35
83d0da612dc4 Kill the running job works fine.
viric@llimona
parents: 32
diff changeset
   477
    m.u.output.pid = p->pid;
32
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   478
    m.u.output.ofilename_size = strlen(p->output_filename) + 1;
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   479
    send_msg(s, &m);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   480
    send_bytes(s, p->output_filename, m.u.output.ofilename_size);
3531439f2770 Tail works.
viric@llimona
parents: 27
diff changeset
   481
}
41
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   482
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   483
void s_remove_job(int s, int jobid)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   484
{
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   485
    struct Job *p = 0;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   486
    struct msg m;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   487
    struct Job *before_p = 0;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   488
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   489
    if (jobid == -1)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   490
    {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   491
        /* Find the last job added */
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   492
        p = firstjob;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   493
        if (p != 0)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   494
        {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   495
            while (p->next != 0)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   496
            {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   497
                before_p = p;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   498
                p = p->next;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   499
            }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   500
        }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   501
    }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   502
    else
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   503
    {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   504
        p = firstjob;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   505
        if (p != 0)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   506
        {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   507
            while (p->next != 0 && p->jobid != jobid)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   508
            {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   509
                before_p = p;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   510
                p = p->next;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   511
            }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   512
        }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   513
    }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   514
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   515
    if (p == 0 || p->state != QUEUED || before_p == 0)
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   516
    {
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   517
        char tmp[50];
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   518
        if (jobid == -1)
44
4dcf05746ece Better include files.
viric@llimona
parents: 42
diff changeset
   519
            sprintf(tmp, "The last job cannot be removed.\n");
41
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   520
        else
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   521
            sprintf(tmp, "The job %i cannot be removed.\n", jobid);
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   522
        send_list_line(s, tmp);
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   523
        return;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   524
    }
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   525
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   526
    before_p->next = p->next;
64
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   527
    free(p->command);
2a17c9c7b1d5 Added a limit to the number of finished jobs.
viric@llimona
parents: 63
diff changeset
   528
    free(p->output_filename);
41
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   529
    free(p);
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   530
    m.type = REMOVEJOB_OK;
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   531
    send_msg(s, &m);
cad41574feda Added 'remove job'.
viric@llimona
parents: 39
diff changeset
   532
}
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   533
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   534
static void add_to_notify_list(int s, int jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   535
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   536
    struct Notify *n;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   537
    struct Notify *new;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   538
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   539
    new = (struct Notify *) malloc(sizeof(*n));
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   540
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   541
    new->socket = s;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   542
    new->jobid = jobid;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   543
    new->next = 0;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   544
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   545
    n = first_notify;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   546
    if (n == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   547
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   548
        first_notify = new;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   549
        return;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   550
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   551
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   552
    while(n->next != 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   553
        n = n->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   554
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   555
    n->next = new;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   556
}
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   557
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   558
static void send_waitjob_ok(int s, int errorlevel)
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   559
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   560
    struct msg m;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   561
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   562
    m.type = WAITJOB_OK;
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   563
    m.u.errorlevel = errorlevel;
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   564
    send_msg(s, &m);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   565
}
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   566
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   567
static struct Job *
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   568
get_job(int jobid)
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   569
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   570
    struct Job *j;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   571
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   572
    j = findjob(jobid);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   573
    if (j != NULL)
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   574
        return j;
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   575
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   576
    j = find_finished_job(jobid);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   577
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   578
    if (j != NULL)
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   579
        return j;
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   580
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   581
    return 0;
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   582
}
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   583
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   584
/* Don't complain, if the socket doesn't exist */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   585
void s_remove_notification(int s)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   586
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   587
    struct Notify *n;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   588
    struct Notify *previous;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   589
    n = first_notify;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   590
    while (n != 0 && n->socket != s)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   591
        n = n->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   592
    if (n == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   593
        return;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   594
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   595
    /* Remove the notification */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   596
    previous = first_notify;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   597
    if (n == previous)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   598
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   599
        free(first_notify);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   600
        first_notify = 0;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   601
        return;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   602
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   603
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   604
    /* if not the first... */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   605
    while(previous->next != n)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   606
        previous = previous->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   607
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   608
    previous->next = n->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   609
    free(n);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   610
}
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   611
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   612
/* This is called when a job finishes */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   613
void check_notify_list(int jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   614
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   615
    struct Notify *n;
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   616
    struct Job *j;
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   617
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   618
    n = first_notify;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   619
    while (n != 0 && n->jobid != jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   620
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   621
        n = n->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   622
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   623
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   624
    if (n == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   625
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   626
        return;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   627
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   628
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   629
    j = get_job(jobid);
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   630
    /* If the job finishes, notify the waiter */
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   631
    if (j->state == FINISHED)
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   632
    {
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   633
        send_waitjob_ok(n->socket, j->errorlevel);
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   634
        s_remove_notification(n->socket);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   635
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   636
}
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   637
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   638
void s_wait_job(int s, int jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   639
{
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   640
    struct Job *p = 0;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   641
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   642
    if (jobid == -1)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   643
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   644
        /* Find the last job added */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   645
        p = firstjob;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   646
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   647
        if (p != 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   648
            while (p->next != 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   649
                p = p->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   650
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   651
        /* Look in finished jobs if needed */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   652
        if (p == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   653
        {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   654
            p = first_finished_job;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   655
            if (p != 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   656
                while (p->next != 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   657
                    p = p->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   658
        }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   659
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   660
    else
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   661
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   662
        p = firstjob;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   663
        while (p != 0 && p->jobid != jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   664
            p = p->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   665
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   666
        /* Look in finished jobs if needed */
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   667
        if (p == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   668
        {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   669
            p = first_finished_job;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   670
            while (p != 0 && p->jobid != jobid)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   671
                p = p->next;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   672
        }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   673
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   674
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   675
    if (p == 0)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   676
    {
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   677
        char tmp[50];
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   678
        if (jobid == -1)
44
4dcf05746ece Better include files.
viric@llimona
parents: 42
diff changeset
   679
            sprintf(tmp, "The last job cannot be waited.\n");
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   680
        else
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   681
            sprintf(tmp, "The job %i cannot be waited.\n", jobid);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   682
        send_list_line(s, tmp);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   683
        return;
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   684
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   685
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   686
    if (p->state == FINISHED)
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   687
    {
51
aa6e05d77537 '-w' returns the waited errorlevel. Added a testbench.
viric@llimona
parents: 49
diff changeset
   688
        send_waitjob_ok(s, p->errorlevel);
42
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   689
    }
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   690
    else
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   691
        add_to_notify_list(s, p->jobid);
f093d0964cf5 Added wait for jobs.
viric@llimona
parents: 41
diff changeset
   692
}
53
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   693
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   694
void s_move_urgent(int s, int jobid)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   695
{
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   696
    struct Job *p = 0;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   697
    struct Job *tmp1;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   698
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   699
    if (jobid == -1)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   700
    {
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   701
        /* Find the last job added */
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   702
        p = firstjob;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   703
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   704
        if (p != 0)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   705
            while (p->next != 0)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   706
                p = p->next;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   707
    }
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   708
    else
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   709
    {
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   710
        p = firstjob;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   711
        while (p != 0 && p->jobid != jobid)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   712
            p = p->next;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   713
    }
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   714
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   715
    if (p == 0 || firstjob->next == 0)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   716
    {
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   717
        char tmp[50];
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   718
        if (jobid == -1)
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   719
            sprintf(tmp, "The last job cannot be urged.\n");
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   720
        else
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   721
            sprintf(tmp, "The job %i cannot be urged.\n", jobid);
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   722
        send_list_line(s, tmp);
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   723
        return;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   724
    }
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   725
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   726
    /* Interchange the pointers */
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   727
    tmp1 = find_previous_job(p);
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   728
    tmp1->next = p->next;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   729
    p->next = firstjob->next;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   730
    firstjob->next = p;
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   731
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   732
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   733
    send_urgent_ok(s);
731c41817842 '-u' (urgency) implemented.
viric@llimona
parents: 51
diff changeset
   734
}
63
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   735
66
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   736
void s_swap_jobs(int s, int jobid1, int jobid2)
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   737
{
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   738
    struct Job *p1, *p2;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   739
    struct Job *prev1, *prev2;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   740
    struct Job *tmp;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   741
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   742
    p1 = findjob(jobid1);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   743
    p2 = findjob(jobid2);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   744
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   745
    if (p1 == 0 || p2 == 0 || p1 == firstjob || p2 == firstjob)
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   746
    {
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   747
        char prev[60];
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   748
        sprintf(prev, "The jobs %i and %i cannot be swapped.\n", jobid1, jobid2);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   749
        send_list_line(s, prev);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   750
        return;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   751
    }
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   752
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   753
    /* Interchange the pointers */
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   754
    prev1 = find_previous_job(p1);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   755
    prev2 = find_previous_job(p2);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   756
    prev1->next = p2;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   757
    prev2->next = p1;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   758
    tmp = p1->next;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   759
    p1->next = p2->next;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   760
    p2->next = tmp;
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   761
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   762
    send_swap_jobs_ok(s);
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   763
}
f70a27afd92e Adding "swap jobs" with -U. Fixed a big problem with fds 0, 1, 2.
viric@mandarina
parents: 64
diff changeset
   764
63
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   765
static void send_state(int s, enum Jobstate state)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   766
{
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   767
    struct msg m;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   768
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   769
    m.type = ANSWER_STATE;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   770
    m.u.state = state;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   771
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   772
    send_msg(s, &m);
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   773
}
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   774
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   775
void s_send_state(int s, int jobid)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   776
{
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   777
    struct Job *p = 0;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   778
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   779
    if (jobid == -1)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   780
    {
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   781
        /* Find the last job added */
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   782
        p = firstjob;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   783
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   784
        if (p != 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   785
            while (p->next != 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   786
                p = p->next;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   787
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   788
        /* Look in finished jobs if needed */
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   789
        if (p == 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   790
        {
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   791
            p = first_finished_job;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   792
            if (p != 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   793
                while (p->next != 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   794
                    p = p->next;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   795
        }
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   796
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   797
    }
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   798
    else
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   799
    {
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   800
        p = get_job(jobid);
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   801
    }
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   802
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   803
    if (p == 0)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   804
    {
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   805
        char tmp[50];
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   806
        if (jobid == -1)
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   807
            sprintf(tmp, "The last job cannot be stated.\n");
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   808
        else
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   809
            sprintf(tmp, "The job %i cannot be stated.\n", jobid);
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   810
        send_list_line(s, tmp);
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   811
        return;
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   812
    }
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   813
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   814
    /* Interchange the pointers */
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   815
    send_state(s, p->state);
47be318f4cbc Added "-s" for querying the job state.
viric@llimona
parents: 55
diff changeset
   816
}