Changeset - 7647047dfa9d
[Not reviewed]
default
0 1 0
ethanzonca - 16 years ago 2009-08-03 00:21:59

Psedo-code edit, buggy, needs work.
1 file changed with 28 insertions and 7 deletions:
0 comments (0 inline, 0 general)
src/server/slave.c
Show inline comments
 
@@ -25,6 +25,7 @@
 
#include <string.h>
 
#include <stdio.h>
 
#include <unistd.h>
 
#include "asprintf.h"
 

	
 
int slavestatus = 0; // Ugh global vars
 

	
 
@@ -106,18 +107,36 @@ options_init(argc,argv,&my_cfg, myopts, 
 

	
 

	
 
/* Somewhat pseudo Rendering code */
 
/*
 
	if('slave recieves "start frame#, job#"'){
 

	
 
/* These should all be filled by remotio and other code */
 
int jobnum;
 
int framenum;
 
int slaveget;
 
int telldone;
 
int blender_is_running;
 
char *jobdatapath = "/path/to/job.tgz";
 
char *outputpath = "/path/to/output.jpg";
 

	
 
char *pathtoblend; // oh, blender-specific horribleness
 

	
 
// If the slave is getting a frame (fill jobnum, framenum, and slaveget vars when this happens)
 
	if(slaveget ==1){
 
		fprintf(stderr, "Received %d in job %d, preparing to render...",framenum,jobnum);
 
		get('http://distren.protofusion.org/srv/job%d.tgz', jobnum); // use curl
 
		char *jobdataurl;
 

	
 

	
 
		_distren_asprintf(&jobdataurl, "http://protofusion.org/distren/stor/job%d.tgz",jobnum);
 

	
 
		curlget(jobdataurl, jobdatapath); // downloads job data from the url to the path stated
 
		_distren_asprintf(&pathtoblend, "%s/job.blend", jobdatapath ); // @TODO: Fix jobdatapath so it knows where to get the file for real :D
 
		exec('tar -xvf job%d.tgz /tmp/distren/job%d',jobnum,jobnum); // somehow
 
		exec_blender("GIVE ME SOME ARGS!"); // (check the args, we'll need to adjust for different output formats, include this in the blendjob struct later)
 
		exec_blender(blendjob, pathtoblend, outputpath, framenum); // So this should grab data from the struct? I have no idea. @TODO: Ohnobinki, we should clear this up.
 

	
 
		// Consider placing the following in the exec_blender() function
 
			while(blender_is_running == 1){
 
				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
 
				sleep(5); // or not... this should be more event-driven, but should still give a heartbeat to the server
 
			}
 

	
 

	
 
@@ -125,12 +144,14 @@ options_init(argc,argv,&my_cfg, myopts, 
 
	}
 
	if(telldone==1){
 
		fprintf(stderr, "Finished frame %d in job %d, uploading...",framenum,jobnum);
 
		curl_POST("/path/to/output.jpg", "http://protofusion.org/distren/output/job%d",jobnum);
 
		char *outputurl;
 
		_distren_asprintf(&outputurl, "http://protofusion.org/distren/stor/job%d/",jobnum); // Throws the jobnum nicely in the string
 
		curlpost(outputpath, outputurl); // posts the output at outputpath to the server at outputurl
 
		tell_the_server(DISTREN_REQUEST_DONEFRAME); // AKA "I'm done rendering that frame you sent me"
 
		telldone=0;
 
		// Slave now becomes idle, doesn't need to tell the server anything, ssh handles this.
 
	}
 
*/
 

	
 

	
 
  return 0;
 
}
0 comments (0 inline, 0 general)