Template:LBS/FormatSugar: Difference between revisions
mNo edit summary |
mNo edit summary |
||
Line 23: | Line 23: | ||
elseif (q == "b") then ret = ret .. "<sub>β" | elseif (q == "b") then ret = ret .. "<sub>β" | ||
elseif (q == "-") then ret = ret .. "<sub>*" | elseif (q == "-") then ret = ret .. "<sub>*" | ||
end | |||
---Process bond position--- | ---Process bond position--- | ||
ret = ret .. r .. "-" .. s .. "</sub>" | if (r and s) then | ||
ret = ret .. r .. "-" .. s .. "</sub>" | |||
end | |||
if (t) then ret = ret .. t end | if (t) then ret = ret .. t end | ||
end | end |
Revision as of 07:00, 3 February 2012
{{#lua:
local seq = stdin:match("[%S()%[%]]+"); local ret = ""; for o,p,q,r,s,t in string.gmatch(seq, "([%[%(]?)([/%a%$]+)([?ab%-]?)([1-9]?)%-?([1-9]?/?[1-9]?)([%]%)]?)") do ---Process ( --- if (o) then ret = ret .. o end ---Process sugar name--- if (string.match(p, "^%$?Glc")) then ret = ret .. '' .. p .. "" elseif (string.match(p, "^%$?Gal")) then ret = ret .. '' .. p .. "" elseif (string.match(p, "^%$?Man")) then ret = ret .. '' .. p .. "" elseif (string.match(p, "^%$?Fuc")) then ret = ret .. '' .. p .. "" elseif (string.match(p, "^%$?Neu")) then ret = ret .. '' .. p .. "" else ret = ret .. '' .. p .. '' end ---Process alpha or beta--- if (q == "a") then ret = ret .. "α" elseif (q == "b") then ret = ret .. "β" elseif (q == "-") then ret = ret .. "*" end ---Process bond position--- if (r and s) then ret = ret .. r .. "-" .. s .. "" end if (t) then ret = ret .. t end end if (string.match(seq,"Cer$")) then ret = ret .. "Cer" end print(ret)
|GlcNAcb1-3Galb1-3GalNAca1-4GalNAcb1-4(EtnP-6)GlcNAcb1-3Manb1-4Glcb1-1Cer}}