Files
@ d02e1ee09098
Branch filter:
Location: DistRen/src/server/slave.c - annotation
d02e1ee09098
3.8 KiB
text/plain
Nada
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 | 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 1f744ce71f83 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 c88f2cae0705 901eddfe43e9 144cab775ebd b95115259ec9 c89c9fbb46f7 144cab775ebd c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 1f744ce71f83 0b48f673ed7f c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 0b48f673ed7f c89c9fbb46f7 c89c9fbb46f7 d02e1ee09098 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 c89c9fbb46f7 d891672fc009 d891672fc009 0b48f673ed7f c89c9fbb46f7 0b48f673ed7f c89c9fbb46f7 c89c9fbb46f7 b95115259ec9 b95115259ec9 c89c9fbb46f7 b95115259ec9 b95115259ec9 c89c9fbb46f7 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 d02e1ee09098 0b48f673ed7f b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 b95115259ec9 0b48f673ed7f 7598c8d2871a d891672fc009 7598c8d2871a 7598c8d2871a 901eddfe43e9 901eddfe43e9 901eddfe43e9 901eddfe43e9 901eddfe43e9 901eddfe43e9 901eddfe43e9 901eddfe43e9 0b48f673ed7f 0b48f673ed7f d891672fc009 7598c8d2871a 0b48f673ed7f 0b48f673ed7f 144cab775ebd d891672fc009 0b48f673ed7f 0b48f673ed7f 1f744ce71f83 c88f2cae0705 | /*
Copyright 2009 Nathan Phillip Brink, Ethan Zonca, Matthew Orlando
This file is a part of DistRen.
DistRen is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
DistRen is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with DistRen. If not, see <http://www.gnu.org/licenses/>.
*/
/*
* **********************************************************************************
* Slave functions / etc resides below. Wouldn't a seperate file make this easier??
*
* Slave listens on server for a command in the format of each function...
* We need if's for returns... ==> watchdog
* **********************************************************************************
*/
// Provides DISTREN_REQUEST* which is in reality, DISTREN_SEND(signal) in the minds of your average joe
#include "protocol.h"
#include "options.h" // Confuse, etc.
#include <string.h>
int slavestatus = 0; // Ugh global vars
int main(int argc, char *argv[])
{
/* Parses arguments, skips if there are no args */
if(argc>1
&& (strcmp("-c", argv[1]) == 0))
{
char *username;
char *email;
if(argc != 4)
{
fprintf(stderr, "I need more arguments!\n%d is not enough!\n Invoke 'slave -c <username> <emailaddr> to register. \n Already registered? Edit your distrenslave.conf file!'", argc - 1);
return 234;
}
username = argv[2];
email = argv[3];
if(!strchr(email, '@'))
{
fprintf(stderr, "I want to see an '@' in your email address!\n%s may be good enough for you, but I need more!\n", email);
return 235;
}
*key = register_user(username, email); // register_user returns a uniquely random url to a key
get("http://protofusion.org/distren/key/%s",key);
fprintf(stderr, "you registered, hopefully successfully. Invoke distrend with no args now.");
exec('echo %s >> distrend.conf',key);
}
/* End arg parser */
char *username;
char *key;
username = NULL;
key = NULL;
cfg_t * my_cfg;
cfg_opt_t myopts = {
CFG_SIMPLE_STR("username"), &username),
CFG_SIMPLE_STR("key"), &key),
CFG_END()
};
struct options_common *commonopts
options_init(argc,argv,&my_cfg, &myopts, "slave", &commonopts);
if(key == NULL || username == NULL){
fprintf(stderr,"You didn't register! Please register or add your username to distrenslave.conf");
}
else if(key != NULL || username != NULL){
loginuser(username); // Logs in user to the server
}
else{
fprintf(stderr,"Something is terribly wrong!!!");
}
if('slave recieves "start frame#, job#"'){
fprintf(stderr, "Got frame %d in job %d, preparing to render...",frame,job);
get('http://distren.protofusion.org/srv/job#.tgz');
exec('tar -xvf job#.tgz /tmp/distren/job#'); // somehow
exec_blender(jobname.blendfile, jobnum.framenum.JPG, jobnum); // (check the args, we'll need to adjust for different output formats, include this in the blendjob struct later)
while('blender is running'){
SLAVESTATUS=1; // really quite pointless now, but why not. Could be nice for logging.
tell_the_server(DISTREN_REQUEST_PROGRESS);
fprintf(stderr, "Rendering frame %d in job %d...",framenum,jobnum);
delay(1000); // or not... this should be more event-driven, but should still give a heartbeat to the server
}
SLAVESTATUS=2; // When done rendering, set this.
}
if(SLAVESTATUS==2){
fprintf(stderr, "Finished frame %d in job %d",framenum,jobnum);
SLAVESTATUS=0;
}
if(SLAVESTATUS==0){
tell_the_server(DISTREN_REQUEST_DONEFRAME);
fprintf(stderr, "Idle. No frames to render.");
}
return 0;
}
|