mirror of
https://github.com/Aurorastation/Aurora.3.git
synced 2025-12-25 17:41:56 +00:00
traitor factions update. Added some new sprites and weapons. New weapon: Delivery grenade. Can spawn an x amount of mob/object y in a constant radius. It is currently used for carp and manhack delivery grenades. !! Important !!: Certain telecomms computers were causing very nasty machine disruption through some very silly mishap involving re-programming a computer's network. Basically, it was breaking machine procs every time you messed with them. This should hopefully make telecomms a lot more stable. Fixed a bug where the reflexes nanoaug would not actually dodge the projectile if the person was clicking directly inside the target's 32x32 border. I changed around some core PDA messaging functions in preparation to PDA Chatrooms (yes Legality it's happening). However I'm going to hold off actually implementing it until Messycakes is either completed with his PDA UI overhaul or just stops working on it. Committed two patches from separate people in the forums. Chemical Cigarettes by Neek (http://nanotrasen.com/phpBB3/viewtopic.php?f=16&t=8775) and Clicking genetics blocks by Willox (http://nanotrasen.com/phpBB3/viewtopic.php?f=16&t=8857). Check their respective threads for more details. Sorry I couldn't get this earlier, guys! Revision: r3755 Author: vageyenaman
1597 lines
61 KiB
Plaintext
1597 lines
61 KiB
Plaintext
/////////////////////////// DNA DATUM
|
|
|
|
#define STRUCDNASIZE 27
|
|
|
|
/datum/dna
|
|
var/unique_enzymes = null
|
|
var/struc_enzymes = null
|
|
var/uni_identity = null
|
|
var/original_name = "Unknown"
|
|
var/b_type = "A+"
|
|
|
|
/datum/dna/proc/check_integrity(var/mob/living/carbon/character)
|
|
if(character && ishuman(character))
|
|
if(length(uni_identity) != 39)
|
|
//Lazy.
|
|
var/mob/living/carbon/human/character2 = character
|
|
var/temp
|
|
var/hair = 0
|
|
var/beard
|
|
|
|
// determine DNA fragment from hairstyle
|
|
// :wtc:
|
|
// If the character2 doesn't have initialized hairstyles / beardstyles, initialize it for them!
|
|
if(!character2.hair_style)
|
|
character2.hair_style = new/datum/sprite_accessory/hair/short
|
|
|
|
if(!character2.facial_hair_style)
|
|
character2.facial_hair_style = new/datum/sprite_accessory/facial_hair/shaved
|
|
|
|
var/list/styles = typesof(/datum/sprite_accessory/hair) - /datum/sprite_accessory/hair
|
|
var/hrange = round(4095 / styles.len)
|
|
|
|
if(character2.hair_style)
|
|
var/style = styles.Find(character2.hair_style.type)
|
|
if(style)
|
|
hair = style * hrange - rand(1,hrange-1)
|
|
|
|
// Beard dna code - mostly copypasted from hair code to allow for more dynamic facial hair style additions
|
|
var/list/face_styles = typesof(/datum/sprite_accessory/facial_hair) - /datum/sprite_accessory/facial_hair
|
|
var/f_hrange = round(4095 / face_styles.len)
|
|
|
|
var/f_style = face_styles.Find(character2.facial_hair_style.type)
|
|
if(f_style)
|
|
beard = f_style * f_hrange - rand(1,f_hrange-1)
|
|
else
|
|
beard = 0
|
|
|
|
temp = add_zero2(num2hex((character2.r_hair),1), 3)
|
|
temp += add_zero2(num2hex((character2.b_hair),1), 3)
|
|
temp += add_zero2(num2hex((character2.g_hair),1), 3)
|
|
temp += add_zero2(num2hex((character2.r_facial),1), 3)
|
|
temp += add_zero2(num2hex((character2.b_facial),1), 3)
|
|
temp += add_zero2(num2hex((character2.g_facial),1), 3)
|
|
temp += add_zero2(num2hex(((character2.s_tone + 220) * 16),1), 3)
|
|
temp += add_zero2(num2hex((character2.r_eyes),1), 3)
|
|
temp += add_zero2(num2hex((character2.g_eyes),1), 3)
|
|
temp += add_zero2(num2hex((character2.b_eyes),1), 3)
|
|
|
|
var/gender
|
|
|
|
if (character2.gender == MALE)
|
|
gender = add_zero2(num2hex((rand(1,(2050+BLOCKADD))),1), 3)
|
|
else
|
|
gender = add_zero2(num2hex((rand((2051+BLOCKADD),4094)),1), 3)
|
|
|
|
temp += gender
|
|
temp += add_zero2(num2hex((beard),1), 3)
|
|
temp += add_zero2(num2hex((hair),1), 3)
|
|
|
|
uni_identity = temp
|
|
if(length(struc_enzymes)!= 81)
|
|
var/mutstring = ""
|
|
for(var/i = 1, i <= 26, i++)
|
|
mutstring += add_zero2(num2hex(rand(1,1024)),3)
|
|
|
|
struc_enzymes = mutstring
|
|
if(length(unique_enzymes) != 32)
|
|
unique_enzymes = md5(character.real_name)
|
|
if(original_name == "Unknown")
|
|
original_name = character.real_name
|
|
else if(character && ismonkey(character))
|
|
uni_identity = "00600200A00E0110148FC01300B009"
|
|
struc_enzymes = "43359156756131E13763334D1C369012032164D4FE4CD61544B6C03F251B6C60A42821D26BA3B0FD6"
|
|
unique_enzymes = md5(character.name)
|
|
//////////blah
|
|
var/gendervar
|
|
if (character.gender == "male")
|
|
gendervar = add_zero2(num2hex((rand(1,2049)),1), 3)
|
|
else
|
|
gendervar = add_zero2(num2hex((rand(2051,4094)),1), 3)
|
|
uni_identity += gendervar
|
|
uni_identity += "12C"
|
|
uni_identity += "4E2"
|
|
b_type = "A+"
|
|
original_name = character.real_name
|
|
else
|
|
if(length(uni_identity) != 39) uni_identity = "00600200A00E0110148FC01300B0095BD7FD3F4"
|
|
if(length(struc_enzymes)!= 81) struc_enzymes = "43359156756131E13763334D1C369012032164D4FE4CD61544B6C03F251B6C60A42821D26BA3B02D6"
|
|
|
|
// reg_dna[unique_enzymes] = character.real_name
|
|
|
|
/datum/dna/proc/ready_dna(mob/living/carbon/human/character)
|
|
|
|
var/temp
|
|
var/hair
|
|
var/beard
|
|
|
|
// determine DNA fragment from hairstyle
|
|
// :wtc:
|
|
|
|
var/list/styles = typesof(/datum/sprite_accessory/hair) - /datum/sprite_accessory/hair
|
|
var/hrange = round(4095 / styles.len)
|
|
|
|
var/style = styles.Find(character.hair_style.type)
|
|
if(style)
|
|
hair = style * hrange - rand(1,hrange-1)
|
|
else
|
|
hair = 0
|
|
|
|
// Beard dna code - mostly copypasted from hair code to allow for more dynamic facial hair style additions
|
|
var/list/face_styles = typesof(/datum/sprite_accessory/facial_hair) - /datum/sprite_accessory/facial_hair
|
|
var/f_hrange = round(4095 / face_styles.len)
|
|
|
|
var/f_style = face_styles.Find(character.facial_hair_style.type)
|
|
if(f_style)
|
|
beard = f_style * f_hrange - rand(1,f_hrange-1)
|
|
else
|
|
beard = 0
|
|
|
|
temp = add_zero2(num2hex((character.r_hair),1), 3)
|
|
temp += add_zero2(num2hex((character.b_hair),1), 3)
|
|
temp += add_zero2(num2hex((character.g_hair),1), 3)
|
|
temp += add_zero2(num2hex((character.r_facial),1), 3)
|
|
temp += add_zero2(num2hex((character.b_facial),1), 3)
|
|
temp += add_zero2(num2hex((character.g_facial),1), 3)
|
|
temp += add_zero2(num2hex(((character.s_tone + 220) * 16),1), 3)
|
|
temp += add_zero2(num2hex((character.r_eyes),1), 3)
|
|
temp += add_zero2(num2hex((character.g_eyes),1), 3)
|
|
temp += add_zero2(num2hex((character.b_eyes),1), 3)
|
|
|
|
var/gender
|
|
|
|
if (character.gender == MALE)
|
|
gender = add_zero2(num2hex((rand(1,(2050+BLOCKADD))),1), 3)
|
|
else
|
|
gender = add_zero2(num2hex((rand((2051+BLOCKADD),4094)),1), 3)
|
|
|
|
temp += gender
|
|
temp += add_zero2(num2hex((beard),1), 3)
|
|
temp += add_zero2(num2hex((hair),1), 3)
|
|
|
|
uni_identity = temp
|
|
|
|
var/mutstring = ""
|
|
for(var/i = 1, i <= 26, i++)
|
|
mutstring += add_zero2(num2hex(rand(1,1024)),3)
|
|
|
|
struc_enzymes = mutstring
|
|
|
|
unique_enzymes = md5(character.real_name)
|
|
original_name = character.real_name
|
|
reg_dna[unique_enzymes] = character.real_name
|
|
|
|
/////////////////////////// DNA DATUM
|
|
|
|
/////////////////////////// DNA HELPER-PROCS
|
|
/proc/getleftblocks(input,blocknumber,blocksize)
|
|
var/string
|
|
|
|
if (blocknumber > 1)
|
|
string = copytext(input,1,((blocksize*blocknumber)-(blocksize-1)))
|
|
return string
|
|
else
|
|
return null
|
|
|
|
/proc/getrightblocks(input,blocknumber,blocksize)
|
|
var/string
|
|
if (blocknumber < (length(input)/blocksize))
|
|
string = copytext(input,blocksize*blocknumber+1,length(input)+1)
|
|
return string
|
|
else
|
|
return null
|
|
|
|
/proc/getblockstring(input,block,subblock,blocksize,src,ui) // src is probably used here just for urls; ui is 1 when requesting for the unique identifier screen, 0 for structural enzymes screen
|
|
var/string
|
|
var/subpos = 1 // keeps track of the current sub block
|
|
var/blockpos = 1 // keeps track of the current block
|
|
|
|
|
|
for(var/i = 1, i <= length(input), i++) // loop through each letter
|
|
|
|
var/pushstring
|
|
|
|
if(subpos == subblock && blockpos == block) // if the current block/subblock is selected, mark it
|
|
pushstring = "</font color><b>[copytext(input, i, i+1)]</b><font color='blue'>"
|
|
else
|
|
if(ui) //This is for allowing block clicks to be differentiated
|
|
pushstring = "<a href='?src=\ref[src];uimenuset=[num2text(blockpos)];uimenusubset=[num2text(subpos)]'>[copytext(input, i, i+1)]</a>"
|
|
else
|
|
pushstring = "<a href='?src=\ref[src];semenuset=[num2text(blockpos)];semenusubset=[num2text(subpos)]'>[copytext(input, i, i+1)]</a>"
|
|
|
|
string += pushstring // push the string to the return string
|
|
|
|
if(subpos >= blocksize) // add a line break for every block
|
|
string += " </font color><font color='#285B5B'>|</font color><font color='blue'> "
|
|
subpos = 0
|
|
blockpos++
|
|
|
|
subpos++
|
|
|
|
return string
|
|
|
|
|
|
/proc/getblock(input,blocknumber,blocksize)
|
|
var/result
|
|
result = copytext(input ,(blocksize*blocknumber)-(blocksize-1),(blocksize*blocknumber)+1)
|
|
return result
|
|
|
|
/proc/getblockbuffer(input,blocknumber,blocksize)
|
|
var/result[3]
|
|
var/block = copytext(input ,(blocksize*blocknumber)-(blocksize-1),(blocksize*blocknumber)+1)
|
|
for(var/i = 1, i <= 3, i++)
|
|
result[i] = copytext(block, i, i+1)
|
|
return result
|
|
|
|
/proc/setblock(istring, blocknumber, replacement, blocksize)
|
|
if(!istring || !blocknumber || !replacement || !blocksize) return 0
|
|
var/result = getleftblocks(istring, blocknumber, blocksize) + replacement + getrightblocks(istring, blocknumber, blocksize)
|
|
return result
|
|
|
|
/proc/add_zero2(t, u)
|
|
var/temp1
|
|
while (length(t) < u)
|
|
t = "0[t]"
|
|
temp1 = t
|
|
if (length(t) > u)
|
|
temp1 = copytext(t,2,u+1)
|
|
return temp1
|
|
|
|
/proc/miniscramble(input,rs,rd)
|
|
var/output
|
|
output = null
|
|
if (input == "C" || input == "D" || input == "E" || input == "F")
|
|
output = pick(prob((rs*10));"4",prob((rs*10));"5",prob((rs*10));"6",prob((rs*10));"7",prob((rs*5)+(rd));"0",prob((rs*5)+(rd));"1",prob((rs*10)-(rd));"2",prob((rs*10)-(rd));"3")
|
|
if (input == "8" || input == "9" || input == "A" || input == "B")
|
|
output = pick(prob((rs*10));"4",prob((rs*10));"5",prob((rs*10));"A",prob((rs*10));"B",prob((rs*5)+(rd));"C",prob((rs*5)+(rd));"D",prob((rs*5)+(rd));"2",prob((rs*5)+(rd));"3")
|
|
if (input == "4" || input == "5" || input == "6" || input == "7")
|
|
output = pick(prob((rs*10));"4",prob((rs*10));"5",prob((rs*10));"A",prob((rs*10));"B",prob((rs*5)+(rd));"C",prob((rs*5)+(rd));"D",prob((rs*5)+(rd));"2",prob((rs*5)+(rd));"3")
|
|
if (input == "0" || input == "1" || input == "2" || input == "3")
|
|
output = pick(prob((rs*10));"8",prob((rs*10));"9",prob((rs*10));"A",prob((rs*10));"B",prob((rs*10)-(rd));"C",prob((rs*10)-(rd));"D",prob((rs*5)+(rd));"E",prob((rs*5)+(rd));"F")
|
|
if (!output) output = "5"
|
|
return output
|
|
|
|
/proc/isblockon(hnumber, bnumber , var/UI = 0)
|
|
|
|
var/temp2
|
|
temp2 = hex2num(hnumber)
|
|
|
|
if(UI)
|
|
if(temp2 >= 2050)
|
|
return 1
|
|
else
|
|
return 0
|
|
|
|
if (bnumber == HULKBLOCK || bnumber == TELEBLOCK)
|
|
if (temp2 >= 3500 + BLOCKADD)
|
|
return 1
|
|
else
|
|
return 0
|
|
if (bnumber == XRAYBLOCK || bnumber == FIREBLOCK)
|
|
if (temp2 >= 3050 + BLOCKADD)
|
|
return 1
|
|
else
|
|
return 0
|
|
|
|
|
|
if (temp2 >= 2050 + BLOCKADD)
|
|
return 1
|
|
else
|
|
return 0
|
|
|
|
/proc/randmutb(mob/M as mob)
|
|
if(!M) return
|
|
var/num
|
|
var/newdna
|
|
num = pick(GLASSESBLOCK,COUGHBLOCK,FAKEBLOCK,NERVOUSBLOCK,CLUMSYBLOCK,TWITCHBLOCK,HEADACHEBLOCK,BLINDBLOCK,DEAFBLOCK)
|
|
M.dna.check_integrity()
|
|
newdna = setblock(M.dna.struc_enzymes,num,toggledblock(getblock(M.dna.struc_enzymes,num,3)),3)
|
|
M.dna.struc_enzymes = newdna
|
|
return
|
|
|
|
/proc/randmutg(mob/M as mob)
|
|
if(!M) return
|
|
var/num
|
|
var/newdna
|
|
num = pick(HULKBLOCK,XRAYBLOCK,FIREBLOCK,TELEBLOCK)
|
|
M.dna.check_integrity()
|
|
newdna = setblock(M.dna.struc_enzymes,num,toggledblock(getblock(M.dna.struc_enzymes,num,3)),3)
|
|
M.dna.struc_enzymes = newdna
|
|
return
|
|
|
|
/proc/scramble(var/type, mob/M as mob, var/p)
|
|
if(!M) return
|
|
M.dna.check_integrity()
|
|
if(type)
|
|
for(var/i = 1, i <= 26, i++)
|
|
if(prob(p))
|
|
M.dna.uni_identity = setblock(M.dna.uni_identity, i, add_zero2(num2hex(rand(1,4095), 1), 3), 3)
|
|
updateappearance(M, M.dna.uni_identity)
|
|
|
|
else
|
|
for(var/i = 1, i <= 26, i++)
|
|
if(prob(p))
|
|
M.dna.struc_enzymes = setblock(M.dna.struc_enzymes, i, add_zero2(num2hex(rand(1,4095), 1), 3), 3)
|
|
domutcheck(M, null)
|
|
return
|
|
|
|
/proc/randmuti(mob/M as mob)
|
|
if(!M) return
|
|
var/num
|
|
var/newdna
|
|
num = pick(1,2,3,4,5,6,7,8,9,10,11,12,13)
|
|
M.dna.check_integrity()
|
|
newdna = setblock(M.dna.uni_identity,num,add_zero2(num2hex(rand(1,4095),1),3),3)
|
|
M.dna.uni_identity = newdna
|
|
return
|
|
|
|
/proc/toggledblock(hnumber) //unused
|
|
var/temp3
|
|
var/chtemp
|
|
temp3 = hex2num(hnumber)
|
|
if (temp3 < 2050)
|
|
chtemp = rand(2050,4095)
|
|
return add_zero2(num2hex(chtemp,1),3)
|
|
else
|
|
chtemp = rand(1,2049)
|
|
return add_zero2(num2hex(chtemp,1),3)
|
|
/////////////////////////// DNA HELPER-PROCS
|
|
|
|
/////////////////////////// DNA MISC-PROCS
|
|
/proc/updateappearance(mob/M as mob , structure)
|
|
if(istype(M, /mob/living/carbon/human))
|
|
M.dna.check_integrity()
|
|
var/mob/living/carbon/human/H = M
|
|
H.r_hair = hex2num(getblock(structure,1,3))
|
|
H.b_hair = hex2num(getblock(structure,2,3))
|
|
H.g_hair = hex2num(getblock(structure,3,3))
|
|
H.r_facial = hex2num(getblock(structure,4,3))
|
|
H.b_facial = hex2num(getblock(structure,5,3))
|
|
H.g_facial = hex2num(getblock(structure,6,3))
|
|
H.s_tone = round(((hex2num(getblock(structure,7,3)) / 16) - 220))
|
|
H.r_eyes = hex2num(getblock(structure,8,3))
|
|
H.g_eyes = hex2num(getblock(structure,9,3))
|
|
H.b_eyes = hex2num(getblock(structure,10,3))
|
|
|
|
if (isblockon(getblock(structure, 11,3),11 , 1))
|
|
H.gender = FEMALE
|
|
else
|
|
H.gender = MALE
|
|
|
|
|
|
/// BEARDS
|
|
|
|
var/beardnum = hex2num(getblock(structure,12,3))
|
|
var/list/facial_styles = typesof(/datum/sprite_accessory/facial_hair) - /datum/sprite_accessory/facial_hair
|
|
var/fstyle = round(1 +(beardnum / 4096)*facial_styles.len)
|
|
|
|
var/fpath = text2path("[facial_styles[fstyle]]")
|
|
var/datum/sprite_accessory/facial_hair/fhair = new fpath
|
|
|
|
H.face_icon_state = fhair.icon_state
|
|
H.f_style = fhair.icon_state
|
|
H.facial_hair_style = fhair
|
|
|
|
|
|
// HAIR
|
|
var/hairnum = hex2num(getblock(structure,13,3))
|
|
var/list/styles = typesof(/datum/sprite_accessory/hair) - /datum/sprite_accessory/hair
|
|
var/style = round(1 +(hairnum / 4096)*styles.len)
|
|
|
|
var/hpath = text2path("[styles[style]]")
|
|
var/datum/sprite_accessory/hair/hair = new hpath
|
|
|
|
H.hair_icon_state = hair.icon_state
|
|
H.h_style = hair.icon_state
|
|
H.hair_style = hair
|
|
|
|
H.update_face()
|
|
H.update_body()
|
|
|
|
H.warn_flavor_changed()
|
|
|
|
return 1
|
|
else
|
|
return 0
|
|
|
|
/proc/ismuton(var/block,var/mob/M)
|
|
return isblockon(getblock(M.dna.struc_enzymes, block,3),block)
|
|
|
|
/proc/domutcheck(mob/living/M as mob, connected, inj)
|
|
if (!M) return
|
|
//mutations
|
|
/*
|
|
TK =(1<<0) 1
|
|
COLD_RESISTANCE =(1<<1) 2
|
|
XRAY =(1<<2) 4
|
|
HULK =(1<<3) 8
|
|
CLUMSY =(1<<4) 16
|
|
//FAT =(1<<5) 32
|
|
HUSK =(1<<6) 64
|
|
LASER =(1<<7) 128
|
|
HEAL =(1<<8) 256
|
|
mNobreath =(1<<9) 512
|
|
mRemote =(1<<10) 1024
|
|
mRegen =(1<<11) 2048
|
|
mRun =(1<<12) 4096
|
|
mRemotetalk =(1<<13) 8192
|
|
mMorph =(1<<14) 16384
|
|
mBlend =(1<<15) 32768
|
|
|
|
mutations2:
|
|
mHallucination =(1<<0) 1
|
|
mFingerprints =(1<<1) 2
|
|
mShock =(1<<2) 4
|
|
mSmallsize =(1<<3) 8
|
|
*/
|
|
|
|
//disabilities
|
|
//1 = blurry eyes
|
|
//2 = headache
|
|
//4 = coughing
|
|
//8 = twitch
|
|
//16 = nervous
|
|
//32 = deaf
|
|
//64 = mute
|
|
//128 = blind
|
|
|
|
M.dna.check_integrity()
|
|
|
|
M.disabilities = 0
|
|
M.mutations = list()
|
|
|
|
M.see_in_dark = 2
|
|
M.see_invisible = 0
|
|
|
|
|
|
if(ismuton(NOBREATHBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue You feel no need to breathe."
|
|
M.mutations.Add(mNobreath)
|
|
if(ismuton(REMOTEVIEWBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue Your mind expands"
|
|
M.mutations.Add(mRemote)
|
|
if(ismuton(REGENERATEBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue You feel strange"
|
|
M.mutations.Add(mRegen)
|
|
if(ismuton(INCREASERUNBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue You feel quick"
|
|
M.mutations.Add(mRun)
|
|
if(ismuton(REMOTETALKBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue You expand your mind outwards"
|
|
M.mutations.Add(mRemotetalk)
|
|
if(ismuton(MORPHBLOCK,M))
|
|
if(prob(50))
|
|
M.mutations.Add(mMorph)
|
|
M << "\blue Your skin feels strange"
|
|
if(ismuton(BLENDBLOCK,M))
|
|
if(prob(50))
|
|
M.mutations.Add(mBlend)
|
|
M << "\blue You feel alone"
|
|
if(ismuton(HALLUCINATIONBLOCK,M))
|
|
if(prob(50))
|
|
M.mutations.Add(mHallucination)
|
|
M << "\blue Your mind says 'Hello'"
|
|
if(ismuton(NOPRINTSBLOCK,M))
|
|
if(prob(50))
|
|
M.mutations.Add(mFingerprints)
|
|
M << "\blue Your fingers feel numb"
|
|
if(ismuton(SHOCKIMMUNITYBLOCK,M))
|
|
if(prob(50))
|
|
M.mutations.Add(mShock)
|
|
M << "\blue You feel strange"
|
|
if(ismuton(SMALLSIZEBLOCK,M))
|
|
if(prob(50))
|
|
M << "\blue Your skin feels rubbery"
|
|
M.mutations.Add(mSmallsize)
|
|
|
|
|
|
|
|
if (isblockon(getblock(M.dna.struc_enzymes, HULKBLOCK,3),HULKBLOCK))
|
|
if(inj || prob(5))
|
|
M << "\blue Your muscles hurt."
|
|
M.mutations.Add(HULK)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, HEADACHEBLOCK,3),HEADACHEBLOCK))
|
|
M.disabilities |= 2
|
|
M << "\red You get a headache."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, FAKEBLOCK,3),FAKEBLOCK))
|
|
M << "\red You feel strange."
|
|
if (prob(95))
|
|
if(prob(50))
|
|
randmutb(M)
|
|
else
|
|
randmuti(M)
|
|
else
|
|
randmutg(M)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, COUGHBLOCK,3),COUGHBLOCK))
|
|
M.disabilities |= 4
|
|
M << "\red You start coughing."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, CLUMSYBLOCK,3),CLUMSYBLOCK))
|
|
M << "\red You feel lightheaded."
|
|
M.mutations.Add(CLUMSY)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, TWITCHBLOCK,3),TWITCHBLOCK))
|
|
M.disabilities |= 8
|
|
M << "\red You twitch."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, XRAYBLOCK,3),XRAYBLOCK))
|
|
if(inj || prob(30))
|
|
M << "\blue The walls suddenly disappear."
|
|
M.sight |= (SEE_MOBS|SEE_OBJS|SEE_TURFS)
|
|
M.see_in_dark = 8
|
|
M.see_invisible = 2
|
|
M.mutations.Add(XRAY)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, NERVOUSBLOCK,3),NERVOUSBLOCK))
|
|
M.disabilities |= 16
|
|
M << "\red You feel nervous."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, FIREBLOCK,3),FIREBLOCK))
|
|
if(inj || prob(30))
|
|
M << "\blue Your body feels warm."
|
|
M.mutations.Add(COLD_RESISTANCE)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, BLINDBLOCK,3),BLINDBLOCK))
|
|
M.disabilities |= 128
|
|
M << "\red You can't seem to see anything."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, TELEBLOCK,3),TELEBLOCK))
|
|
if(inj || prob(15))
|
|
M << "\blue You feel smarter."
|
|
M.mutations.Add(TK)
|
|
if (isblockon(getblock(M.dna.struc_enzymes, DEAFBLOCK,3),DEAFBLOCK))
|
|
M.disabilities |= 32
|
|
M.ear_deaf = 1
|
|
M << "\red Its kinda quiet.."
|
|
if (isblockon(getblock(M.dna.struc_enzymes, GLASSESBLOCK,3),GLASSESBLOCK))
|
|
M.disabilities |= 1
|
|
M << "Your eyes feel weird..."
|
|
|
|
|
|
//////////////////////////////////////////////////////////// Monkey Block
|
|
if (isblockon(getblock(M.dna.struc_enzymes, MONKEYBLOCK,3),MONKEYBLOCK) && istype(M, /mob/living/carbon/human))
|
|
// human > monkey
|
|
var/mob/living/carbon/human/H = M
|
|
H.monkeyizing = 1
|
|
if(!connected)
|
|
for(var/obj/item/W in (H.contents))
|
|
if (W==H.w_uniform) // will be teared
|
|
continue
|
|
H.drop_from_slot(W)
|
|
M.rebuild_appearance()
|
|
M.monkeyizing = 1
|
|
M.canmove = 0
|
|
M.icon = null
|
|
M.invisibility = 101
|
|
var/atom/movable/overlay/animation = new( M.loc )
|
|
animation.icon_state = "blank"
|
|
animation.icon = 'mob.dmi'
|
|
animation.master = src
|
|
flick("h2monkey", animation)
|
|
sleep(48)
|
|
del(animation)
|
|
|
|
var/mob/living/carbon/monkey/O = new(src)
|
|
del(O.organs)
|
|
O.organs = H.organs
|
|
for(var/name in O.organs)
|
|
var/datum/organ/external/organ = O.organs[name]
|
|
organ.owner = O
|
|
for(var/obj/item/weapon/implant/implant in organ.implant)
|
|
implant.imp_in = O
|
|
|
|
if(M)
|
|
if (M.dna)
|
|
O.dna = M.dna
|
|
M.dna = null
|
|
|
|
|
|
for(var/datum/disease/D in M.viruses)
|
|
O.viruses += D
|
|
D.affected_mob = O
|
|
M.viruses -= D
|
|
|
|
|
|
for(var/obj/T in (M.contents))
|
|
del(T)
|
|
//for(var/R in M.organs)
|
|
// del(M.organs[text("[]", R)])
|
|
|
|
O.loc = M.loc
|
|
|
|
if(M.mind)
|
|
M.mind.transfer_to(O)
|
|
|
|
if (connected) //inside dna thing
|
|
var/obj/machinery/dna_scannernew/C = connected
|
|
O.loc = C
|
|
C.occupant = O
|
|
connected = null
|
|
O.name = text("monkey ([])",copytext(md5(M.real_name), 2, 6))
|
|
O.take_overall_damage(M.getBruteLoss() + 40, M.getFireLoss())
|
|
O.adjustToxLoss(M.getToxLoss() + 20)
|
|
O.adjustOxyLoss(M.getOxyLoss())
|
|
O.stat = M.stat
|
|
O.a_intent = "hurt"
|
|
O.flavor_text = M.flavor_text
|
|
O.warn_flavor_changed()
|
|
O.rebuild_appearance()
|
|
del(M)
|
|
return
|
|
|
|
if (!isblockon(getblock(M.dna.struc_enzymes, MONKEYBLOCK,3),MONKEYBLOCK) && !istype(M, /mob/living/carbon/human))
|
|
// monkey > human,
|
|
var/mob/living/carbon/monkey/Mo = M
|
|
Mo.monkeyizing = 1
|
|
if(!connected)
|
|
for(var/obj/item/W in (Mo.contents))
|
|
Mo.drop_from_slot(W)
|
|
M.rebuild_appearance()
|
|
M.monkeyizing = 1
|
|
M.canmove = 0
|
|
M.icon = null
|
|
M.invisibility = 101
|
|
var/atom/movable/overlay/animation = new( M.loc )
|
|
animation.icon_state = "blank"
|
|
animation.icon = 'mob.dmi'
|
|
animation.master = src
|
|
flick("monkey2h", animation)
|
|
sleep(48)
|
|
del(animation)
|
|
|
|
var/mob/living/carbon/human/O = new( src )
|
|
if (isblockon(getblock(M.dna.uni_identity, 11,3),11))
|
|
O.gender = FEMALE
|
|
else
|
|
O.gender = MALE
|
|
O.dna = M.dna
|
|
M.dna = null
|
|
del(O.organs)
|
|
O.organs = M.organs
|
|
for(var/name in O.organs)
|
|
var/datum/organ/external/organ = O.organs[name]
|
|
organ.owner = O
|
|
for(var/obj/item/weapon/implant/implant in organ.implant)
|
|
implant.imp_in = O
|
|
|
|
for(var/datum/disease/D in M.viruses)
|
|
O.viruses += D
|
|
D.affected_mob = O
|
|
M.viruses -= D
|
|
|
|
//for(var/obj/T in M)
|
|
// del(T)
|
|
|
|
O.loc = M.loc
|
|
|
|
if(M.mind)
|
|
M.mind.transfer_to(O)
|
|
|
|
if (connected) //inside dna thing
|
|
var/obj/machinery/dna_scannernew/C = connected
|
|
O.loc = C
|
|
C.occupant = O
|
|
connected = null
|
|
|
|
var/i
|
|
while (!i)
|
|
var/randomname
|
|
if (O.gender == MALE)
|
|
randomname = capitalize(pick(first_names_male) + " " + capitalize(pick(last_names)))
|
|
else
|
|
randomname = capitalize(pick(first_names_female) + " " + capitalize(pick(last_names)))
|
|
if (findname(randomname))
|
|
continue
|
|
else
|
|
O.real_name = randomname
|
|
i++
|
|
updateappearance(O,O.dna.uni_identity)
|
|
O.take_overall_damage(M.getBruteLoss(), M.getFireLoss())
|
|
O.adjustToxLoss(M.getToxLoss())
|
|
O.adjustOxyLoss(M.getOxyLoss())
|
|
O.stat = M.stat
|
|
O.flavor_text = M.flavor_text
|
|
O.warn_flavor_changed()
|
|
O.rebuild_appearance()
|
|
del(M)
|
|
return
|
|
//////////////////////////////////////////////////////////// Monkey Block
|
|
if (M)
|
|
M.rebuild_appearance()
|
|
return null
|
|
/////////////////////////// DNA MISC-PROCS
|
|
|
|
|
|
/////////////////////////// DNA MACHINES
|
|
/obj/machinery/dna_scannernew/New()
|
|
..()
|
|
component_parts = list()
|
|
component_parts += new /obj/item/weapon/circuitboard/clonescanner(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/scanning_module(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/manipulator(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/micro_laser(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/console_screen(src)
|
|
component_parts += new /obj/item/weapon/cable_coil(src)
|
|
component_parts += new /obj/item/weapon/cable_coil(src)
|
|
RefreshParts()
|
|
|
|
/obj/machinery/dna_scannernew/allow_drop()
|
|
return 0
|
|
|
|
/obj/machinery/dna_scannernew/relaymove(mob/user as mob)
|
|
if (user.stat)
|
|
return
|
|
src.go_out()
|
|
return
|
|
|
|
/obj/machinery/dna_scannernew/verb/eject()
|
|
set src in oview(1)
|
|
set category = "Object"
|
|
set name = "Eject DNA Scanner"
|
|
|
|
if (usr.stat != 0)
|
|
return
|
|
src.go_out()
|
|
add_fingerprint(usr)
|
|
return
|
|
|
|
/obj/machinery/dna_scannernew/verb/move_inside()
|
|
set src in oview(1)
|
|
set category = "Object"
|
|
set name = "Enter DNA Scanner"
|
|
|
|
if (usr.stat != 0)
|
|
return
|
|
if (src.occupant)
|
|
usr << "\blue <B>The scanner is already occupied!</B>"
|
|
return
|
|
if (usr.abiotic2())
|
|
usr << "\blue <B>Subject cannot have abiotic items on.</B>"
|
|
return
|
|
usr.pulling = null
|
|
usr.client.perspective = EYE_PERSPECTIVE
|
|
usr.client.eye = src
|
|
usr.loc = src
|
|
src.occupant = usr
|
|
src.icon_state = "scanner_1"
|
|
/*
|
|
for(var/obj/O in src) // THIS IS P. STUPID -- LOVE, DOOHL
|
|
//O = null
|
|
del(O)
|
|
//Foreach goto(124)
|
|
*/
|
|
src.add_fingerprint(usr)
|
|
return
|
|
|
|
/obj/machinery/dna_scannernew/attackby(obj/item/weapon/grab/G as obj, user as mob)
|
|
if ((!( istype(G, /obj/item/weapon/grab) ) || !( ismob(G.affecting) )))
|
|
return
|
|
if (src.occupant)
|
|
user << "\blue <B>The scanner is already occupied!</B>"
|
|
return
|
|
if (G.affecting.abiotic2())
|
|
user << "\blue <B>Subject cannot have abiotic items on.</B>"
|
|
return
|
|
var/mob/M = G.affecting
|
|
if (M.client)
|
|
M.client.perspective = EYE_PERSPECTIVE
|
|
M.client.eye = src
|
|
M.loc = src
|
|
src.occupant = M
|
|
src.icon_state = "scanner_1"
|
|
/*
|
|
for(var/obj/O in src) // this is stupid too
|
|
O.loc = src.loc
|
|
//Foreach goto(154)
|
|
*/
|
|
src.add_fingerprint(user)
|
|
//G = null
|
|
|
|
// search for ghosts, if the corpse is empty and the scanner is connected to a cloner
|
|
// if(locate(/obj/machinery/computer/cloning, get_step(src, EAST)))
|
|
//
|
|
// if (!M.client)
|
|
// for(var/mob/dead/observer/ghost in world)
|
|
// if(ghost.corpse == M && ghost.client)
|
|
// ghost << "<b><font color = #330033><font size = 3>Your corpse has been placed into a cloning scanner. Return to your body if you want to be resurrected/cloned!</b> (Verbs -> Ghost -> Re-enter corpse)</font color>"
|
|
// break
|
|
del(G)
|
|
return
|
|
|
|
/obj/machinery/dna_scannernew/proc/go_out()
|
|
if ((!( src.occupant ) || src.locked))
|
|
return
|
|
|
|
if (src.occupant.client)
|
|
src.occupant.client.eye = src.occupant.client.mob
|
|
src.occupant.client.perspective = MOB_PERSPECTIVE
|
|
src.occupant.loc = src.loc
|
|
src.occupant.update_clothing()
|
|
src.occupant = null
|
|
src.icon_state = "scanner_0"
|
|
return
|
|
|
|
/obj/machinery/dna_scannernew/ex_act(severity)
|
|
switch(severity)
|
|
if(1.0)
|
|
for(var/atom/movable/A as mob|obj in src)
|
|
A.loc = src.loc
|
|
ex_act(severity)
|
|
//Foreach goto(35)
|
|
//SN src = null
|
|
del(src)
|
|
return
|
|
if(2.0)
|
|
if (prob(50))
|
|
for(var/atom/movable/A as mob|obj in src)
|
|
A.loc = src.loc
|
|
ex_act(severity)
|
|
//Foreach goto(108)
|
|
//SN src = null
|
|
del(src)
|
|
return
|
|
if(3.0)
|
|
if (prob(25))
|
|
for(var/atom/movable/A as mob|obj in src)
|
|
A.loc = src.loc
|
|
ex_act(severity)
|
|
//Foreach goto(181)
|
|
//SN src = null
|
|
del(src)
|
|
return
|
|
else
|
|
return
|
|
|
|
|
|
/obj/machinery/dna_scannernew/blob_act()
|
|
if(prob(75))
|
|
for(var/atom/movable/A as mob|obj in src)
|
|
A.loc = src.loc
|
|
del(src)
|
|
|
|
/obj/machinery/scan_consolenew/ex_act(severity)
|
|
|
|
switch(severity)
|
|
if(1.0)
|
|
//SN src = null
|
|
del(src)
|
|
return
|
|
if(2.0)
|
|
if (prob(50))
|
|
//SN src = null
|
|
del(src)
|
|
return
|
|
else
|
|
return
|
|
|
|
/obj/machinery/scan_consolenew/blob_act()
|
|
|
|
if(prob(75))
|
|
del(src)
|
|
|
|
/obj/machinery/scan_consolenew/power_change()
|
|
if(stat & BROKEN)
|
|
icon_state = "broken"
|
|
else if(powered())
|
|
icon_state = initial(icon_state)
|
|
stat &= ~NOPOWER
|
|
else
|
|
spawn(rand(0, 15))
|
|
src.icon_state = "c_unpowered"
|
|
stat |= NOPOWER
|
|
|
|
/obj/machinery/computer/scan_consolenew/New()
|
|
..()
|
|
spawn(5)
|
|
for(dir in list(NORTH,EAST,SOUTH,WEST))
|
|
connected = locate(/obj/machinery/dna_scannernew, get_step(src, dir))
|
|
if(!isnull(connected))
|
|
break
|
|
spawn(250)
|
|
src.injectorready = 1
|
|
return
|
|
return
|
|
|
|
/obj/machinery/computer/scan_consolenew/attackby(obj/item/W as obj, mob/user as mob)
|
|
if ((istype(W, /obj/item/weapon/disk/data)) && (!src.diskette))
|
|
user.drop_item()
|
|
W.loc = src
|
|
src.diskette = W
|
|
user << "You insert [W]."
|
|
src.updateUsrDialog()
|
|
|
|
/obj/machinery/computer/scan_consolenew/process() //not really used right now
|
|
processing_objects.Remove(src) //Lets not have it waste CPU
|
|
if(stat & (NOPOWER|BROKEN))
|
|
return
|
|
if (!( src.status )) //remove this
|
|
return
|
|
return
|
|
|
|
/obj/machinery/computer/scan_consolenew/attack_paw(user as mob)
|
|
return src.attack_hand(user)
|
|
|
|
/obj/machinery/computer/scan_consolenew/attack_ai(user as mob)
|
|
return src.attack_hand(user)
|
|
|
|
/obj/machinery/computer/scan_consolenew/attack_hand(user as mob)
|
|
if(..())
|
|
return
|
|
if(!(user in message))
|
|
user << "\blue This machine looks extremely complex. You'd probably need a decent knowledge of Genetics to understand it."
|
|
message += user
|
|
var/dat
|
|
if (src.delete && src.temphtml) //Window in buffer but its just simple message, so nothing
|
|
src.delete = src.delete
|
|
|
|
else if (!src.delete && src.temphtml) //Window in buffer - its a menu, dont add clear message
|
|
dat = text("[]<BR><BR><A href='?src=\ref[];clear=1'>Main Menu</A>", src.temphtml, src)
|
|
else
|
|
if (src.connected) //Is something connected?
|
|
var/mob/occupant = src.connected.occupant
|
|
dat = "<font color='blue'><B>Occupant Statistics:</B></FONT><BR>" //Blah obvious
|
|
if(occupant && occupant.dna) //is there REALLY someone in there?
|
|
if(NOCLONE in occupant.mutations)
|
|
dat += "The occupant's DNA structure is ruined beyond recognition, please insert a subject with an intact DNA structure.<BR><BR>" //NOPE. -Pete
|
|
dat += text("<A href='?src=\ref[];buffermenu=1'>View/Edit/Transfer Buffer</A><BR><BR>", src)
|
|
dat += text("<A href='?src=\ref[];radset=1'>Radiation Emitter Settings</A><BR><BR>", src)
|
|
else
|
|
if (!istype(occupant,/mob/living/carbon/human))
|
|
sleep(1)
|
|
var/t1
|
|
switch(occupant.stat) // obvious, see what their status is
|
|
if(0)
|
|
t1 = "Conscious"
|
|
if(1)
|
|
t1 = "Unconscious"
|
|
else
|
|
t1 = "*dead*"
|
|
dat += text("[]\tHealth %: [] ([])</FONT><BR>", (occupant.health > 50 ? "<font color='blue'>" : "<font color='red'>"), occupant.health, t1)
|
|
dat += text("<font color='green'>Radiation Level: []%</FONT><BR><BR>", occupant.radiation)
|
|
dat += text("Unique Enzymes : <font color='blue'>[]</FONT><BR>", uppertext(occupant.dna.unique_enzymes))
|
|
dat += text("Unique Identifier: <font color='blue'>[]</FONT><BR>", occupant.dna.uni_identity)
|
|
dat += text("Structural Enzymes: <font color='blue'>[]</FONT><BR><BR>", occupant.dna.struc_enzymes)
|
|
dat += text("<A href='?src=\ref[];unimenu=1'>Modify Unique Identifier</A><BR>", src)
|
|
dat += text("<A href='?src=\ref[];strucmenu=1'>Modify Structural Enzymes</A><BR><BR>", src)
|
|
dat += text("<A href='?src=\ref[];buffermenu=1'>View/Edit/Transfer Buffer</A><BR><BR>", src)
|
|
dat += text("<A href='?src=\ref[];genpulse=1'>Pulse Radiation</A><BR>", src)
|
|
dat += text("<A href='?src=\ref[];radset=1'>Radiation Emitter Settings</A><BR><BR>", src)
|
|
dat += text("<A href='?src=\ref[];rejuv=1'>Inject Rejuvenators</A><BR><BR>", src)
|
|
else
|
|
dat += "The scanner is empty.<BR><BR>"
|
|
dat += text("<A href='?src=\ref[];buffermenu=1'>View/Edit/Transfer Buffer</A><BR><BR>", src)
|
|
dat += text("<A href='?src=\ref[];radset=1'>Radiation Emitter Settings</A><BR><BR>", src)
|
|
if (!( src.connected.locked ))
|
|
dat += text("<A href='?src=\ref[];locked=1'>Lock (Unlocked)</A><BR>", src)
|
|
else
|
|
dat += text("<A href='?src=\ref[];locked=1'>Unlock (Locked)</A><BR>", src)
|
|
//Other stuff goes here
|
|
if (!isnull(src.diskette))
|
|
dat += text("<A href='?src=\ref[];eject_disk=1'>Eject Disk</A><BR>", src)
|
|
dat += text("<BR><BR><A href='?src=\ref[];mach_close=scannernew'>Close</A>", user)
|
|
else
|
|
dat = "<font color='red'> Error: No DNA Modifier connected. </FONT>"
|
|
user << browse(dat, "window=scannernew;size=700x625")
|
|
onclose(user, "scannernew")
|
|
return
|
|
|
|
/obj/machinery/computer/scan_consolenew/Topic(href, href_list)
|
|
if(..())
|
|
return
|
|
if(!istype(usr.loc, /turf))
|
|
return
|
|
if ((usr.contents.Find(src) || in_range(src, usr) && istype(src.loc, /turf)) || (istype(usr, /mob/living/silicon)))
|
|
usr.machine = src
|
|
if (href_list["locked"])
|
|
if ((src.connected && src.connected.occupant))
|
|
src.connected.locked = !( src.connected.locked )
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["genpulse"])
|
|
src.delete = 1
|
|
src.temphtml = text("Working ... Please wait ([] Seconds)", src.radduration)
|
|
usr << browse(temphtml, "window=scannernew;size=550x650")
|
|
onclose(usr, "scannernew")
|
|
var/lock_state = src.connected.locked
|
|
src.connected.locked = 1//lock it
|
|
sleep(10*src.radduration)
|
|
if (!src.connected.occupant)
|
|
temphtml = null
|
|
delete = 0
|
|
return null
|
|
if (prob(95))
|
|
if(prob(75))
|
|
randmutb(src.connected.occupant)
|
|
else
|
|
randmuti(src.connected.occupant)
|
|
else
|
|
if(prob(95))
|
|
randmutg(src.connected.occupant)
|
|
else
|
|
randmuti(src.connected.occupant)
|
|
src.connected.occupant.radiation += ((src.radstrength*3)+src.radduration*3)
|
|
src.connected.locked = lock_state
|
|
temphtml = null
|
|
delete = 0
|
|
if (href_list["radset"])
|
|
src.temphtml = text("Radiation Duration: <B><font color='green'>[]</B></FONT><BR>", src.radduration)
|
|
src.temphtml += text("Radiation Intensity: <font color='green'><B>[]</B></FONT><BR><BR>", src.radstrength)
|
|
src.temphtml += text("<A href='?src=\ref[];radleminus=1'>--</A> Duration <A href='?src=\ref[];radleplus=1'>++</A><BR>", src, src)
|
|
src.temphtml += text("<A href='?src=\ref[];radinminus=1'>--</A> Intesity <A href='?src=\ref[];radinplus=1'>++</A><BR>", src, src)
|
|
src.delete = 0
|
|
if (href_list["radleplus"])
|
|
if (src.radduration < 20)
|
|
src.radduration++
|
|
src.radduration++
|
|
dopage(src,"radset")
|
|
if (href_list["radleminus"])
|
|
if (src.radduration > 2)
|
|
src.radduration--
|
|
src.radduration--
|
|
dopage(src,"radset")
|
|
if (href_list["radinplus"])
|
|
if (src.radstrength < 10)
|
|
src.radstrength++
|
|
dopage(src,"radset")
|
|
if (href_list["radinminus"])
|
|
if (src.radstrength > 1)
|
|
src.radstrength--
|
|
dopage(src,"radset")
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["unimenu"])
|
|
//src.temphtml = text("Unique Identifier: <font color='blue'>[]</FONT><BR><BR>", src.connected.occupant.dna.uni_identity)
|
|
//src.temphtml = text("Unique Identifier: <font color='blue'>[getleftblocks(src.connected.occupant.dna.uni_identity,uniblock,3)][src.subblock == 1 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),1,1)+"</U></B>" : getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),1,1)][src.subblock == 2 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),2,1)+"</U></B>" : getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),2,1)][src.subblock == 3 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),3,1)+"</U></B>" : getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),3,1)][getrightblocks(src.connected.occupant.dna.uni_identity,uniblock,3)]</FONT><BR><BR>")
|
|
|
|
// New way of displaying DNA blocks
|
|
src.temphtml = text("Unique Identifier: <font color='blue'>[getblockstring(src.connected.occupant.dna.uni_identity,uniblock,subblock,3, src,1)]</FONT><br><br>")
|
|
|
|
src.temphtml += text("Selected Block: <font color='blue'><B>[]</B></FONT><BR>", src.uniblock)
|
|
src.temphtml += text("<A href='?src=\ref[];unimenuminus=1'><-</A> Block <A href='?src=\ref[];unimenuplus=1'>-></A><BR><BR>", src, src)
|
|
src.temphtml += text("Selected Sub-Block: <font color='blue'><B>[]</B></FONT><BR>", src.subblock)
|
|
src.temphtml += text("<A href='?src=\ref[];unimenusubminus=1'><-</A> Sub-Block <A href='?src=\ref[];unimenusubplus=1'>-></A><BR><BR>", src, src)
|
|
src.temphtml += "<B>Modify Block:</B><BR>"
|
|
src.temphtml += text("<A href='?src=\ref[];unipulse=1'>Irradiate</A><BR>", src)
|
|
src.delete = 0
|
|
if (href_list["unimenuplus"])
|
|
if (src.uniblock < 13)
|
|
src.uniblock++
|
|
dopage(src,"unimenu")
|
|
if (href_list["unimenuminus"])
|
|
if (src.uniblock > 1)
|
|
src.uniblock--
|
|
dopage(src,"unimenu")
|
|
if (href_list["unimenusubplus"])
|
|
if (src.subblock < 3)
|
|
src.subblock++
|
|
dopage(src,"unimenu")
|
|
if (href_list["unimenusubminus"])
|
|
if (src.subblock > 1)
|
|
src.subblock--
|
|
dopage(src,"unimenu")
|
|
if (href_list["uimenuset"] && href_list["uimenusubset"]) // This chunk of code updates selected block / sub-block based on click
|
|
var/menuset = text2num(href_list["uimenuset"])
|
|
var/menusubset = text2num(href_list["uimenusubset"])
|
|
if ((menuset <= 13) && (menuset >= 1))
|
|
src.uniblock = menuset
|
|
if ((menusubset <= 3) && (menusubset >= 1))
|
|
src.subblock = menusubset
|
|
dopage(src, "unimenu")
|
|
if (href_list["unipulse"])
|
|
if(src.connected.occupant)
|
|
var/block
|
|
var/newblock
|
|
var/tstructure2
|
|
block = getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),src.subblock,1)
|
|
src.delete = 1
|
|
src.temphtml = text("Working ... Please wait ([] Seconds)", src.radduration)
|
|
usr << browse(temphtml, "window=scannernew;size=550x650")
|
|
onclose(usr, "scannernew")
|
|
var/lock_state = src.connected.locked
|
|
src.connected.locked = 1//lock it
|
|
sleep(10*src.radduration)
|
|
if (!src.connected.occupant)
|
|
temphtml = null
|
|
delete = 0
|
|
return null
|
|
///
|
|
if (prob((80 + (src.radduration / 2))))
|
|
block = miniscramble(block, src.radstrength, src.radduration)
|
|
newblock = null
|
|
if (src.subblock == 1) newblock = block + getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),2,1) + getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),3,1)
|
|
if (src.subblock == 2) newblock = getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),1,1) + block + getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),3,1)
|
|
if (src.subblock == 3) newblock = getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),1,1) + getblock(getblock(src.connected.occupant.dna.uni_identity,src.uniblock,3),2,1) + block
|
|
tstructure2 = setblock(src.connected.occupant.dna.uni_identity, src.uniblock, newblock,3)
|
|
src.connected.occupant.dna.uni_identity = tstructure2
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
src.connected.occupant.radiation += (src.radstrength+src.radduration)
|
|
else
|
|
if (prob(20+src.radstrength))
|
|
randmutb(src.connected.occupant)
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
else
|
|
randmuti(src.connected.occupant)
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
src.connected.occupant.radiation += ((src.radstrength*2)+src.radduration)
|
|
src.connected.locked = lock_state
|
|
dopage(src,"unimenu")
|
|
src.delete = 0
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["rejuv"])
|
|
var/mob/living/carbon/human/H = src.connected.occupant
|
|
if(H)
|
|
if (H.reagents.get_reagent_amount("inaprovaline") < 60)
|
|
H.reagents.add_reagent("inaprovaline", 30)
|
|
usr << text("Occupant now has [] units of rejuvenation in his/her bloodstream.", H.reagents.get_reagent_amount("inaprovaline"))
|
|
src.delete = 0
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["strucmenu"])
|
|
if(src.connected.occupant)
|
|
var/temp_string1 = getleftblocks(src.connected.occupant.dna.struc_enzymes,strucblock,3)
|
|
var/temp1 = ""
|
|
for(var/i = 3, i <= length(temp_string1), i += 3)
|
|
temp1 += copytext(temp_string1, i-2, i+1) + " "
|
|
var/temp_string2 = getrightblocks(src.connected.occupant.dna.struc_enzymes,strucblock,3)
|
|
var/temp2 = ""
|
|
for(var/i = 3, i <= length(temp_string2), i += 3)
|
|
temp2 += copytext(temp_string2, i-2, i+1) + " "
|
|
//src.temphtml = text("Structural Enzymes: <font color='blue'>[temp1] [src.subblock == 1 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1)+"</U></B>" : getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1)][src.subblock == 2 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1)+"</U></B>":getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1)][src.subblock == 3 ? "<U><B>"+getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)+"</U></B>":getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)] [temp2]</FONT><BR><BR>")
|
|
//src.temphtml = text("Structural Enzymes: <font color='blue'>[]</FONT><BR><BR>", src.connected.occupant.dna.struc_enzymes)
|
|
|
|
// New shit, it doesn't suck (as much)
|
|
src.temphtml = text("Structural Enzymes: <font color='blue'>[getblockstring(src.connected.occupant.dna.struc_enzymes,strucblock,subblock,3,src,0)]</FONT><br><br>")
|
|
// SE of occupant, selected block, selected subblock, block size (3 subblocks)
|
|
|
|
src.temphtml += text("Selected Block: <font color='blue'><B>[]</B></FONT><BR>", src.strucblock)
|
|
src.temphtml += text("<A href='?src=\ref[];strucmenuminus=1'><-</A> <A href='?src=\ref[];strucmenuchoose=1'>Block</A> <A href='?src=\ref[];strucmenuplus=1'>-></A><BR><BR>", src, src, src)
|
|
src.temphtml += text("Selected Sub-Block: <font color='blue'><B>[]</B></FONT><BR>", src.subblock)
|
|
src.temphtml += text("<A href='?src=\ref[];strucmenusubminus=1'><-</A> Sub-Block <A href='?src=\ref[];strucmenusubplus=1'>-></A><BR><BR>", src, src)
|
|
src.temphtml += "<B>Modify Block:</B><BR>"
|
|
src.temphtml += text("<A href='?src=\ref[];strucpulse=1'>Irradiate</A><BR>", src)
|
|
src.delete = 0
|
|
if (href_list["strucmenuplus"])
|
|
if (src.strucblock < 27)
|
|
src.strucblock++
|
|
dopage(src,"strucmenu")
|
|
if (href_list["strucmenuminus"])
|
|
if (src.strucblock > 1)
|
|
src.strucblock--
|
|
dopage(src,"strucmenu")
|
|
if (href_list["strucmenuchoose"])
|
|
var/temp = input("What block?", "Block", src.strucblock) as num
|
|
if (temp > 27)
|
|
temp = 27
|
|
if (temp < 1)
|
|
temp = 1
|
|
src.strucblock = temp
|
|
dopage(src,"strucmenu")
|
|
if (href_list["strucmenusubplus"])
|
|
if (src.subblock < 3)
|
|
src.subblock++
|
|
dopage(src,"strucmenu")
|
|
if (href_list["strucmenusubminus"])
|
|
if (src.subblock > 1)
|
|
src.subblock--
|
|
dopage(src,"strucmenu")
|
|
if (href_list["semenuset"] && href_list["semenusubset"]) // This chunk of code updates selected block / sub-block based on click (se stands for strutural enzymes)
|
|
var/menuset = text2num(href_list["semenuset"])
|
|
var/menusubset = text2num(href_list["semenusubset"])
|
|
if ((menuset <= 14) && (menuset >= 1))
|
|
src.strucblock = menuset
|
|
if ((menusubset <= 3) && (menusubset >= 1))
|
|
src.subblock = menusubset
|
|
dopage(src, "strucmenu")
|
|
if (href_list["strucpulse"])
|
|
var/block
|
|
var/newblock
|
|
var/tstructure2
|
|
var/oldblock
|
|
var/lock_state = src.connected.locked
|
|
src.connected.locked = 1//lock it
|
|
if (src.connected.occupant)
|
|
block = getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),src.subblock,1)
|
|
src.delete = 1
|
|
src.temphtml = text("Working ... Please wait ([] Seconds)", src.radduration)
|
|
usr << browse(temphtml, "window=scannernew;size=550x650")
|
|
onclose(usr, "scannernew")
|
|
sleep(10*src.radduration)
|
|
else
|
|
temphtml = null
|
|
delete = 0
|
|
return null
|
|
///
|
|
if(src.connected.occupant)
|
|
if (prob((80 + (src.radduration / 2))))
|
|
if (prob (20))
|
|
oldblock = src.strucblock
|
|
block = miniscramble(block, src.radstrength, src.radduration)
|
|
newblock = null
|
|
if (src.strucblock > 1 && src.strucblock < STRUCDNASIZE/2)
|
|
src.strucblock++
|
|
else if (src.strucblock > STRUCDNASIZE/2 && src.strucblock < STRUCDNASIZE)
|
|
src.strucblock--
|
|
if (src.subblock == 1) newblock = block + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1) + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)
|
|
if (src.subblock == 2) newblock = getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1) + block + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)
|
|
if (src.subblock == 3) newblock = getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1) + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1) + block
|
|
tstructure2 = setblock(src.connected.occupant.dna.struc_enzymes, src.strucblock, newblock,3)
|
|
src.connected.occupant.dna.struc_enzymes = tstructure2
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
src.connected.occupant.radiation += (src.radstrength+src.radduration)
|
|
src.strucblock = oldblock
|
|
else
|
|
block = miniscramble(block, src.radstrength, src.radduration)
|
|
newblock = null
|
|
if (src.subblock == 1) newblock = block + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1) + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)
|
|
if (src.subblock == 2) newblock = getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1) + block + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),3,1)
|
|
if (src.subblock == 3) newblock = getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),1,1) + getblock(getblock(src.connected.occupant.dna.struc_enzymes,src.strucblock,3),2,1) + block
|
|
tstructure2 = setblock(src.connected.occupant.dna.struc_enzymes, src.strucblock, newblock,3)
|
|
src.connected.occupant.dna.struc_enzymes = tstructure2
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
src.connected.occupant.radiation += (src.radstrength+src.radduration)
|
|
else
|
|
if (prob(80-src.radduration))
|
|
randmutb(src.connected.occupant)
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
else
|
|
randmuti(src.connected.occupant)
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
src.connected.occupant.radiation += ((src.radstrength*2)+src.radduration)
|
|
src.connected.locked = lock_state
|
|
///
|
|
dopage(src,"strucmenu")
|
|
src.delete = 0
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["buffermenu"])
|
|
src.temphtml = "<B>Buffer 1:</B><BR>"
|
|
if (!(src.buffer1))
|
|
src.temphtml += "Buffer Empty<BR>"
|
|
else
|
|
src.temphtml += text("Data: <font color='blue'>[]</FONT><BR>", src.buffer1)
|
|
src.temphtml += text("By: <font color='blue'>[]</FONT><BR>", src.buffer1owner)
|
|
src.temphtml += text("Label: <font color='blue'>[]</FONT><BR>", src.buffer1label)
|
|
if (src.connected.occupant && !(NOCLONE in src.connected.occupant.mutations)) src.temphtml += text("Save : <A href='?src=\ref[];b1addui=1'>UI</A> - <A href='?src=\ref[];b1adduiue=1'>UI+UE</A> - <A href='?src=\ref[];b1addse=1'>SE</A><BR>", src, src, src)
|
|
if (src.buffer1) src.temphtml += text("Transfer to: <A href='?src=\ref[];b1transfer=1'>Occupant</A> - <A href='?src=\ref[];b1injector=1'>Injector</A><BR>", src, src)
|
|
//if (src.buffer1) src.temphtml += text("<A href='?src=\ref[];b1iso=1'>Isolate Block</A><BR>", src)
|
|
if (src.buffer1) src.temphtml += "Disk: <A href='?src=\ref[src];save_disk=1'>Save To</a> | <A href='?src=\ref[src];load_disk=1'>Load From</a><br>"
|
|
if (src.buffer1) src.temphtml += text("<A href='?src=\ref[];b1label=1'>Edit Label</A><BR>", src)
|
|
if (src.buffer1) src.temphtml += text("<A href='?src=\ref[];b1clear=1'>Clear Buffer</A><BR><BR>", src)
|
|
if (!src.buffer1) src.temphtml += "<BR>"
|
|
src.temphtml += "<B>Buffer 2:</B><BR>"
|
|
if (!(src.buffer2))
|
|
src.temphtml += "Buffer Empty<BR>"
|
|
else
|
|
src.temphtml += text("Data: <font color='blue'>[]</FONT><BR>", src.buffer2)
|
|
src.temphtml += text("By: <font color='blue'>[]</FONT><BR>", src.buffer2owner)
|
|
src.temphtml += text("Label: <font color='blue'>[]</FONT><BR>", src.buffer2label)
|
|
if (src.connected.occupant && !(NOCLONE in src.connected.occupant.mutations)) src.temphtml += text("Save : <A href='?src=\ref[];b2addui=1'>UI</A> - <A href='?src=\ref[];b2adduiue=1'>UI+UE</A> - <A href='?src=\ref[];b2addse=1'>SE</A><BR>", src, src, src)
|
|
if (src.buffer2) src.temphtml += text("Transfer to: <A href='?src=\ref[];b2transfer=1'>Occupant</A> - <A href='?src=\ref[];b2injector=1'>Injector</A><BR>", src, src)
|
|
//if (src.buffer2) src.temphtml += text("<A href='?src=\ref[];b2iso=1'>Isolate Block</A><BR>", src)
|
|
if (src.buffer2) src.temphtml += "Disk: <A href='?src=\ref[src];save_disk=2'>Save To</a> | <A href='?src=\ref[src];load_disk=2'>Load From</a><br>"
|
|
if (src.buffer2) src.temphtml += text("<A href='?src=\ref[];b2label=1'>Edit Label</A><BR>", src)
|
|
if (src.buffer2) src.temphtml += text("<A href='?src=\ref[];b2clear=1'>Clear Buffer</A><BR><BR>", src)
|
|
if (!src.buffer2) src.temphtml += "<BR>"
|
|
src.temphtml += "<B>Buffer 3:</B><BR>"
|
|
if (!(src.buffer3))
|
|
src.temphtml += "Buffer Empty<BR>"
|
|
else
|
|
src.temphtml += text("Data: <font color='blue'>[]</FONT><BR>", src.buffer3)
|
|
src.temphtml += text("By: <font color='blue'>[]</FONT><BR>", src.buffer3owner)
|
|
src.temphtml += text("Label: <font color='blue'>[]</FONT><BR>", src.buffer3label)
|
|
if (src.connected.occupant && !(NOCLONE in src.connected.occupant.mutations)) src.temphtml += text("Save : <A href='?src=\ref[];b3addui=1'>UI</A> - <A href='?src=\ref[];b3adduiue=1'>UI+UE</A> - <A href='?src=\ref[];b3addse=1'>SE</A><BR>", src, src, src)
|
|
if (src.buffer3) src.temphtml += text("Transfer to: <A href='?src=\ref[];b3transfer=1'>Occupant</A> - <A href='?src=\ref[];b3injector=1'>Injector</A><BR>", src, src)
|
|
//if (src.buffer3) src.temphtml += text("<A href='?src=\ref[];b3iso=1'>Isolate Block</A><BR>", src)
|
|
if (src.buffer3) src.temphtml += "Disk: <A href='?src=\ref[src];save_disk=3'>Save To</a> | <A href='?src=\ref[src];load_disk=3'>Load From</a><br>"
|
|
if (src.buffer3) src.temphtml += text("<A href='?src=\ref[];b3label=1'>Edit Label</A><BR>", src)
|
|
if (src.buffer3) src.temphtml += text("<A href='?src=\ref[];b3clear=1'>Clear Buffer</A><BR><BR>", src)
|
|
if (!src.buffer3) src.temphtml += "<BR>"
|
|
if (href_list["b1addui"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer1iue = 0
|
|
src.buffer1 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer1owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer1owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer1owner = src.connected.occupant.real_name
|
|
src.buffer1label = "Unique Identifier"
|
|
src.buffer1type = "ui"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b1adduiue"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer1 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer1owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer1owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer1owner = src.connected.occupant.real_name
|
|
src.buffer1label = "Unique Identifier & Unique Enzymes"
|
|
src.buffer1type = "ui"
|
|
src.buffer1iue = 1
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b2adduiue"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer2 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer2owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer2owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer2owner = src.connected.occupant.real_name
|
|
src.buffer2label = "Unique Identifier & Unique Enzymes"
|
|
src.buffer2type = "ui"
|
|
src.buffer2iue = 1
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b3adduiue"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer3 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer3owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer3owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer3owner = src.connected.occupant.real_name
|
|
src.buffer3label = "Unique Identifier & Unique Enzymes"
|
|
src.buffer3type = "ui"
|
|
src.buffer3iue = 1
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b2addui"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer2iue = 0
|
|
src.buffer2 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer2owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer2owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer2owner = src.connected.occupant.real_name
|
|
src.buffer2label = "Unique Identifier"
|
|
src.buffer2type = "ui"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b3addui"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer3iue = 0
|
|
src.buffer3 = src.connected.occupant.dna.uni_identity
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer3owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer3owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer3owner = src.connected.occupant.real_name
|
|
src.buffer3label = "Unique Identifier"
|
|
src.buffer3type = "ui"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b1addse"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer1iue = 0
|
|
src.buffer1 = src.connected.occupant.dna.struc_enzymes
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer1owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer1owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer1owner = src.connected.occupant.real_name
|
|
src.buffer1label = "Structural Enzymes"
|
|
src.buffer1type = "se"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b2addse"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer2iue = 0
|
|
src.buffer2 = src.connected.occupant.dna.struc_enzymes
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer2owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer2owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer2owner = src.connected.occupant.real_name
|
|
src.buffer2label = "Structural Enzymes"
|
|
src.buffer2type = "se"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b3addse"])
|
|
if(src.connected.occupant && src.connected.occupant.dna)
|
|
src.buffer3iue = 0
|
|
src.buffer3 = src.connected.occupant.dna.struc_enzymes
|
|
if (!istype(src.connected.occupant,/mob/living/carbon/human))
|
|
src.buffer3owner = src.connected.occupant.name
|
|
else
|
|
if(src.connected.occupant.real_name == "Unknown" && src.connected.occupant.dna.original_name != "Unknown")
|
|
src.buffer3owner = src.connected.occupant.dna.original_name //Good god, is that unweildy
|
|
else
|
|
src.buffer3owner = src.connected.occupant.real_name
|
|
src.buffer3label = "Structural Enzymes"
|
|
src.buffer3type = "se"
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b1clear"])
|
|
src.buffer1 = null
|
|
src.buffer1owner = null
|
|
src.buffer1label = null
|
|
src.buffer1iue = null
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b2clear"])
|
|
src.buffer2 = null
|
|
src.buffer2owner = null
|
|
src.buffer2label = null
|
|
src.buffer2iue = null
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b3clear"])
|
|
src.buffer3 = null
|
|
src.buffer3owner = null
|
|
src.buffer3label = null
|
|
src.buffer3iue = null
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b1label"])
|
|
src.buffer1label = sanitize(input("New Label:","Edit Label","Infos here"))
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b2label"])
|
|
src.buffer2label = sanitize(input("New Label:","Edit Label","Infos here"))
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b3label"])
|
|
src.buffer3label = sanitize(input("New Label:","Edit Label","Infos here"))
|
|
dopage(src,"buffermenu")
|
|
if (href_list["b1transfer"])
|
|
if (!src.connected.occupant || (NOCLONE in src.connected.occupant.mutations) || !src.connected.occupant.dna)
|
|
return
|
|
if (src.buffer1type == "ui")
|
|
if (src.buffer1iue)
|
|
src.connected.occupant.real_name = src.buffer1owner
|
|
src.connected.occupant.name = src.buffer1owner
|
|
src.connected.occupant.dna.original_name = src.buffer1owner
|
|
src.connected.occupant.dna.uni_identity = src.buffer1
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
else if (src.buffer1type == "se")
|
|
src.connected.occupant.dna.struc_enzymes = src.buffer1
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
src.temphtml = "Transfered."
|
|
src.connected.occupant.radiation += rand(20,50)
|
|
src.delete = 0
|
|
if (href_list["b2transfer"])
|
|
if (!src.connected.occupant || (NOCLONE in src.connected.occupant.mutations) || !src.connected.occupant.dna)
|
|
return
|
|
if (src.buffer2type == "ui")
|
|
if (src.buffer2iue)
|
|
src.connected.occupant.real_name = src.buffer2owner
|
|
src.connected.occupant.name = src.buffer2owner
|
|
src.connected.occupant.dna.original_name = src.buffer2owner
|
|
src.connected.occupant.dna.uni_identity = src.buffer2
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
else if (src.buffer2type == "se")
|
|
src.connected.occupant.dna.struc_enzymes = src.buffer2
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
src.temphtml = "Transfered."
|
|
src.connected.occupant.radiation += rand(20,50)
|
|
src.delete = 0
|
|
if (href_list["b3transfer"])
|
|
if (!src.connected.occupant || (NOCLONE in src.connected.occupant.mutations) || !src.connected.occupant.dna)
|
|
return
|
|
if (src.buffer3type == "ui")
|
|
if (src.buffer3iue)
|
|
src.connected.occupant.real_name = src.buffer3owner
|
|
src.connected.occupant.name = src.buffer3owner
|
|
src.connected.occupant.dna.original_name = src.buffer3owner
|
|
src.connected.occupant.dna.uni_identity = src.buffer3
|
|
updateappearance(src.connected.occupant,src.connected.occupant.dna.uni_identity)
|
|
else if (src.buffer3type == "se")
|
|
src.connected.occupant.dna.struc_enzymes = src.buffer3
|
|
domutcheck(src.connected.occupant,src.connected)
|
|
src.temphtml = "Transfered."
|
|
src.connected.occupant.radiation += rand(20,50)
|
|
src.delete = 0
|
|
if (href_list["b1injector"])
|
|
if (src.injectorready)
|
|
var/obj/item/weapon/dnainjector/I = new /obj/item/weapon/dnainjector
|
|
I.dna = src.buffer1
|
|
I.dnatype = src.buffer1type
|
|
I.loc = src.loc
|
|
I.name += " ([src.buffer1label])"
|
|
if (src.buffer1iue) I.ue = src.buffer1owner //lazy haw haw
|
|
src.temphtml = "Injector created."
|
|
src.delete = 0
|
|
src.injectorready = 0
|
|
spawn(300)
|
|
src.injectorready = 1
|
|
else
|
|
src.temphtml = "Replicator not ready yet."
|
|
src.delete = 0
|
|
if (href_list["b2injector"])
|
|
if (src.injectorready)
|
|
var/obj/item/weapon/dnainjector/I = new /obj/item/weapon/dnainjector
|
|
I.dna = src.buffer2
|
|
I.dnatype = src.buffer2type
|
|
I.loc = src.loc
|
|
I.name += " ([src.buffer2label])"
|
|
if (src.buffer2iue) I.ue = src.buffer2owner //lazy haw haw
|
|
src.temphtml = "Injector created."
|
|
src.delete = 0
|
|
src.injectorready = 0
|
|
spawn(300)
|
|
src.injectorready = 1
|
|
else
|
|
src.temphtml = "Replicator not ready yet."
|
|
src.delete = 0
|
|
if (href_list["b3injector"])
|
|
if (src.injectorready)
|
|
var/obj/item/weapon/dnainjector/I = new /obj/item/weapon/dnainjector
|
|
I.dna = src.buffer3
|
|
I.dnatype = src.buffer3type
|
|
I.loc = src.loc
|
|
I.name += " ([src.buffer3label])"
|
|
if (src.buffer3iue) I.ue = src.buffer3owner //lazy haw haw
|
|
src.temphtml = "Injector created."
|
|
src.delete = 0
|
|
src.injectorready = 0
|
|
spawn(300)
|
|
src.injectorready = 1
|
|
else
|
|
src.temphtml = "Replicator not ready yet."
|
|
src.delete = 0
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["load_disk"])
|
|
var/buffernum = text2num(href_list["load_disk"])
|
|
if ((buffernum > 3) || (buffernum < 1))
|
|
return
|
|
if ((isnull(src.diskette)) || (!src.diskette.data) || (src.diskette.data == ""))
|
|
return
|
|
switch(buffernum)
|
|
if(1)
|
|
src.buffer1 = src.diskette.data
|
|
src.buffer1type = src.diskette.data_type
|
|
src.buffer1iue = src.diskette.ue
|
|
src.buffer1owner = src.diskette.owner
|
|
if(2)
|
|
src.buffer2 = src.diskette.data
|
|
src.buffer2type = src.diskette.data_type
|
|
src.buffer2iue = src.diskette.ue
|
|
src.buffer2owner = src.diskette.owner
|
|
if(3)
|
|
src.buffer3 = src.diskette.data
|
|
src.buffer3type = src.diskette.data_type
|
|
src.buffer3iue = src.diskette.ue
|
|
src.buffer3owner = src.diskette.owner
|
|
src.temphtml = "Data loaded."
|
|
|
|
if (href_list["save_disk"])
|
|
var/buffernum = text2num(href_list["save_disk"])
|
|
if ((buffernum > 3) || (buffernum < 1))
|
|
return
|
|
if ((isnull(src.diskette)) || (src.diskette.read_only))
|
|
return
|
|
switch(buffernum)
|
|
if(1)
|
|
src.diskette.data = buffer1
|
|
src.diskette.data_type = src.buffer1type
|
|
src.diskette.ue = src.buffer1iue
|
|
src.diskette.owner = src.buffer1owner
|
|
src.diskette.name = "data disk - '[src.buffer1owner]'"
|
|
if(2)
|
|
src.diskette.data = buffer2
|
|
src.diskette.data_type = src.buffer2type
|
|
src.diskette.ue = src.buffer2iue
|
|
src.diskette.owner = src.buffer2owner
|
|
src.diskette.name = "data disk - '[src.buffer2owner]'"
|
|
if(3)
|
|
src.diskette.data = buffer3
|
|
src.diskette.data_type = src.buffer3type
|
|
src.diskette.ue = src.buffer3iue
|
|
src.diskette.owner = src.buffer3owner
|
|
src.diskette.name = "data disk - '[src.buffer3owner]'"
|
|
src.temphtml = "Data saved."
|
|
if (href_list["eject_disk"])
|
|
if (!src.diskette)
|
|
return
|
|
src.diskette.loc = get_turf(src)
|
|
src.diskette = null
|
|
////////////////////////////////////////////////////////
|
|
if (href_list["clear"])
|
|
src.temphtml = null
|
|
src.delete = 0
|
|
if (href_list["update"]) //ignore
|
|
src.temphtml = src.temphtml
|
|
src.add_fingerprint(usr)
|
|
src.updateUsrDialog()
|
|
return
|
|
/////////////////////////// DNA MACHINES |