From bc9583f9f05c86aa21da0d1b9081660a64d9ce31 Mon Sep 17 00:00:00 2001
From: mihaf <miha.fosnaric@gmail.com>
Date: Wed, 26 Mar 2014 14:06:52 +0000
Subject: [PATCH] pswitch can be changed on the fly.

---
 src/main.c |   17 +++++++++++++++--
 1 files changed, 15 insertions(+), 2 deletions(-)

diff --git a/src/main.c b/src/main.c
index 54d868f..eef5835 100644
--- a/src/main.c
+++ b/src/main.c
@@ -22,9 +22,10 @@
 	ts_vesicle *vesicle;
 	ts_tape *tape;
 	ts_uint start_iteration=0;
+	force_from_tape=0;
 	parse_args(argv,argc); // sets global variable command_line_args (defined in io.h)
 	ts_fprintf(stdout,"Starting program...\n\n");
-	if(force_from_tape){
+	if(command_line_args.force_from_tape){
 		ts_fprintf(stdout,"************************************************\n");
 		ts_fprintf(stdout,"**** Generating initial geometry from tape *****\n");
 		ts_fprintf(stdout,"************************************************\n\n");
@@ -37,8 +38,20 @@
 		ts_fprintf(stdout,"**********************************************************************\n\n");
 		tape=parsetape("tape");
 		vesicle=restore_state(&start_iteration);
+        if(vesicle==NULL){
+            ts_fprintf(stderr, "Dump file does not exist or is not a regular file! Did you mean to invoke trisurf with --force-from-tape option?\n\n");
+            return 1;
+        }
+		// nove vrednosti iz tapea...
+		vesicle->bending_rigidity=tape->xk0;
+		vtx_set_global_values(vesicle);
+		vesicle->pswitch =tape->pswitch;
+		vesicle->pressure=tape->pressure;
+		vesicle->dmax=tape->dmax*tape->dmax;
+		poly_assign_filament_xi(vesicle,tape);
+		vesicle->clist->dmin_interspecies = tape->dmin_interspecies*tape->dmin_interspecies;
 
-		if(command_line_args.reset_iteration_count) start_iteration=tape->inititer+1;
+		if(command_line_args.reset_iteration_count) start_iteration=tape->inititer;
 		else start_iteration++;
 
 		if(start_iteration>=tape->iterations){

--
Gitblit v1.9.3