\b;Programs dispatched by Houston Below is a program that has been developed by our engineers. It instructs the \l;shielder\u object\botshld; to follow and protect the \l;phazer\u object\botphaz;. \c; \s;extern void object::FollowPhazer() \s;{ \s; \l;object\u cbot\type; item; // info. about phazer \s; \l;point\u cbot\type; dest; // position where to go \s; \l;float\u cbot\type; dist; // distance to phazer \s; \s; item = \l;radar\u cbot\radar;(\l;PhazerShooter\u cbot\category;); \s; \l;if\u cbot\if; ( item == null ) \s; { \s; \l;message\u cbot\message;("No phazer found"); \s; \l;return\u cbot\return;; // stop the program \s; } \s; \l;shield\u cbot\shield;(1, 25); // activate the shield \s; \s; \l;while\u cbot\while; ( true ) // repeat forever \s; { \s; item = \l;radar\u cbot\radar;(PhazerShooter);// look for phazer \s; \l;if\u cbot\if; ( item == null ) break; \s; \s; dist = \l;distance\u cbot\dist;(item.position, position); \s; \l;if\u cbot\if; ( dist < 5 ) \s; { // if closer than 5 m: \s; \l;wait\u cbot\wait;(1); // wait \s; } \s; \l;else\u cbot\if; // otherwise: \s; { // Calculate a position 5 m before the phazer \s; dest.x = (item.position.x-position.x)*((dist-5)/dist)+position.x; \s; dest.y = (item.position.y-position.y)*((dist-5)/dist)+position.y; \s; dest.z = (item.position.z-position.z)*((dist-5)/dist)+position.z; \s; \l;goto\u cbot\goto;(dest, 0, 1, 1); // and go there \s; } \s; } \s;} \n; \b;Archives Index of the programs dispatched in former missions: o \c;\l;ServiceTower1\u mlvolca2;\n; o \c;\l;CollectTitanium3\u mlvolca1;\n; o \c;\l;KillAnt1\u mlsaari2;\n; o \c;\l;CollectTitanium2\u mlcrys2;\n; o \c;\l;CollectTitanium1\u mlcrys1;\n; o \c;\l;Recharge2\u mltropi3;\n; o \c;\l;Recharge1\u mllune4;\n; o \c;\l;SwitchCell1\u mllune1;\n;