# HG changeset patch # User sirebral # Date 1291110542 21600 # Node ID 712df3d5b54c8f2529733ad96ea85b61f0ab0360 # Parent 682032381be87df3851c14539e4e9780afdc9a18 Traipse Beta 'OpenRPG' {101130-01} Traipse is a distribution of OpenRPG that is designed to be easy to setup and go. Traipse also makes it easy for developers to work on code without fear of sacrifice. 'Ornery-Orc' continues the trend of 'Grumpy' and adds fixes to the code. 'Ornery-Orc's main goal is to offer more advanced features and enhance the productivity of the user. Update Summary (Closed) New Features: New to Map, can re-order Grid, Miniatures, and Whiteboard layer draw order New to Server GUI, can now clear log New Earthdawn Dieroller New IronClaw roller, sheet, and image New ShapeShifter PC Sheet Updates: Update to Warhammer PC Sheet. Rollers set as macros. Should work with little maintanence. Update to Browser Server window. Display rooms with ' " & cleaner Update to Server. Handles ' " & cleaner Update to Dieroller. Cleaner, more effecient expression system Update to Hidden Die plugin, allows for non standard dice rolls Update to location.py, allows for more portable references when starting Traipse Update to the Features node Fixes: Fix to InterParse that was causing an Infernal Loop with Namespace Internal Fix to XML data, removed old Minidom and switched to Element Tree Fix to Server that was causing eternal attempt to find a Server ID, in Register Rooms thread Fix to metaservers.xml file not being created Fix to Single and Double quotes in Whiteboard text Fix to Background images not showing when using the Image Server Fix to Duplicate chat names appearing Fix to Server GUI's logging output Fix to FNB.COLORFUL_TABS bug Fix to Gametree for XSLT Sheets Fix to Gametree for locating gametree files Fix to Send to Chat from Gametree Fix to Gametree, renaming and remapping operates correctly Fix to aliaslib, prevents error caused when SafeHTML is sent None diff -r 682032381be8 -r 712df3d5b54c orpg/orpg_version.py --- a/orpg/orpg_version.py Tue Nov 30 02:34:58 2010 -0600 +++ b/orpg/orpg_version.py Tue Nov 30 03:49:02 2010 -0600 @@ -4,7 +4,7 @@ #BUILD NUMBER FORMAT: "YYMMDD-##" where ## is the incremental daily build index (if needed) DISTRO = "Traipse Beta" DIS_VER = "Ornery Orc" -BUILD = "101130-00" +BUILD = "101130-01" # This version is for network capability. PROTOCOL_VERSION = "1.2" diff -r 682032381be8 -r 712df3d5b54c orpg/templates/feature.xml --- a/orpg/templates/feature.xml Tue Nov 30 02:34:58 2010 -0600 +++ b/orpg/templates/feature.xml Tue Nov 30 03:49:02 2010 -0600 @@ -1,4 +1,4 @@ - + Welcome to Traipse OpenRPG. @@ -533,6 +533,8 @@ + + diff -r 682032381be8 -r 712df3d5b54c orpg/templates/nodes/ShapeShifter.xml --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/orpg/templates/nodes/ShapeShifter.xml Tue Nov 30 03:49:02 2010 -0600 @@ -0,0 +1,229 @@ +What is the Shape Shifter + +The Shape Shifter node is a special node based off the 4e PC Sheet that comes with Traipse. The shape shifter uses a special feature in Traipse's Namespace 2.0 that allows it to reference nodes from inside another reference. + +How does this node work? + +The Abilities grid actually references the Shapes::Shape node to find the Shape your PC is currently in. The default is Human. Inside the Shapes container different grids for Abilities can be placed and the text inside the Shape can be changed to use a new Abilities grid. + +Using the Node: + +Using the node is simple. Just clone the 'Human' grid, modify the base ability scores, and then rename the grid to the desired shape. When you want your character to become that shape, change the text in the Shape node to the name of the desired shape. + +When making references always reference the Abilities grid as that is the one that will update with the current shape. + + + + + + + + + + + + + + + + + + + + + + + + + text + + text + + text + + text + + 1 + + 1 + + + + Weapon + Damage + + + Sword + d6 + + Maced8 + + + + + + + Armor + Bonus + + + Total + !=To Hit::3,2=! + !=To Hit::4,2=! + + BAB15Str Mod!=Abilities::(1,3)=! + + + + + + + Armor + Bonus + + + Total + !=AC Bonus::3,2=!+!=AC Bonus::4,2=! + + Armor!=Armor::2,2=!Misc0 + + + + + + + Armor + Bonus + + + Total + !=Armor::3,2=! + + Base10ArmorShield + + + + + + + Armor + Bonus + Descripton + + Total + !=Feats::3,2=! + + Feat0 + + + + + + + Str + !=!"Shape"!::1,2=! + (!=Abilities::(1,2)=!-10)/2 + + Dex + !=!"Shape"!::2,2=! + (!=Abilities::(2,2)=!-10)/2 + + Con + !=!"Shape"!::3,2=! + (!=Abilities::(3,2)=!-10)/2 + + Int + !=!"Shape"!::4,2=! + (!=Abilities::(4,2)=!-10)/2 + + Wis + !=!"Shape"!::5,2=! + (!=Abilities::(5,2)=!-10)/2 + + Cha + !=!"Shape"!::6,2=! + (!=Abilities::(6,2)=!-10)/2 + + + + + Human + + + Str + 24 + (!=!"Shape"!::(1,2)=!-10)/2 + + Dex + 24 + (!=!"Shape"!::(2,2)=!-10)/2 + + Con + 24 + (!=!"Shape"!::(3,2)=!-10)/2 + + Int + 24 + (!=!"Shape"!::(4,2)=!-10)/2 + + Wis + 24 + (!=!"Shape"!::(5,2)=!-10)/2 + + Cha + 24 + (!=!"Shape"!::(6,2)=!-10)/2 + + + + + + + + Str + 8 + (!=!"Shape"!::(1,2)=!-10)/2 + + Dex + 8 + (!=!"Shape"!::(2,2)=!-10)/2 + + Con + 8 + (!=!"Shape"!::(3,2)=!-10)/2 + + Int + 8 + (!=!"Shape"!::(4,2)=!-10)/2 + + Wis + 8 + (!=!"Shape"!::(5,2)=!-10)/2 + + Cha + 8 + (!=!"Shape"!::(6,2)=!-10)/2 + + + + + + /me uses an At Will +<b>Attack:</b> [1d20+2+!#Abilities::(2,3)#!] +<b>Damage:</b> [2!#Combat::Weapons::(2,2)#!] + + /me uses an Encounter +<b>Attack:</b> [1d20+2+!#Abilities::(2,3)#!] +<b>Damage:</b> [2!#Combat::Weapons::(2,2)#!] + + /me uses an Daily +<b>Attack:</b> [1d20+2+!#Abilities::(2,3)#!] +<b>Damage:</b> [2!#Combat::Weapons::(2,2)#!] + + Nothing + + Nothing + + Nothing + + Nothing + \ No newline at end of file diff -r 682032381be8 -r 712df3d5b54c upmana/updatemana.py --- a/upmana/updatemana.py Tue Nov 30 02:34:58 2010 -0600 +++ b/upmana/updatemana.py Tue Nov 30 03:49:02 2010 -0600 @@ -129,6 +129,21 @@ else: manifest.SetString("updatemana", "no_update", "off") def Update(self, evt=None): + with open(sys.path[2]+os.sep+'location.py', 'rb') as f: old_location = f.read() + ## This new location file update allows for a more portable way to start Traipse. It's aimed at Linux users. + new_location = """import sys +import os + +dyn_dir = 'System' +_home = sys.path[0] +_userbase_dir = _home + os.sep + dyn_dir +sys.path.append(_userbase_dir) +try: os.chdir(_userbase_dir) +except: print 'Failed to find ' + _userbase_dir + '\\nHopefuly you are running setup.py which would make this error normal.'""" + + if new_location != old_location: + with open(sys.path[2]+os.sep+'location.py', 'w') as f: f.write(new_location) + self.ui = ui.ui() self.repo = hg.repository(self.ui, ".") self.c = self.repo.changectx('tip')