Welcome to TiddlyWiki created by Jeremy Ruston; Copyright © 2004-2007 Jeremy Ruston, Copyright © 2007-2011 UnaMesa Association
Accuracy is in quarter-degrees, and measures the maximum this ammo will//   contribute to the angle of difference.  HIGH ACC IS BAD.
Ingame stat is 100-Accuracy(stat) = hit chance ingame 
 
[[Damage]] is damage done, in an average hit.  
Note that the average human has 80 health.  
Headshots do 8x damage; vital hits do 2x-4x; glances do 0x-1x.
Weight and price is per 100 rounds.
AP is a reduction in the armor of the target.
Accuracy is in quarter-degrees, and measures the maximum this ammo will contribute to the angle of difference.  HIGH ACC IS BAD.
Recoil is cumulitive between shots.  4 recoil = 1 accuracy.
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 17 | Ammonia | 2 | 1 | 0 | 0 | 0 | 60 | -96 | 0 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 24 | 30 | yellow | [[Plastic Bottle]] | 0 | -2 | 0 | 1 | -30 | bleach | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Don't drink it.  Mixing it with [[bleach|Bleach]] produces toxic gas. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 226 | BB | 1 | 6 | 1 | 0 | 0 | 56 |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 8 | 50 | [[BB|AT_BB]] | pink | [[STEEL|Material_Steel]] | 2 | 0 | 12 | 20 | 0 | 200 |
|!Description|>|>|>|>|>|>|>|>|>|>| A box of nails, mainly useful with a hammer. |
 
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 223 | batteries | 1 | 8 | 1 | 0 | 0 | 54 |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 50 | 120 | [[Batteries|AT_BATT]] | Magenta | [[IRON|Material_Iron]] | 0 | 0 | 0 | 100 | 0 | 100 |
|!Description|>|>|>|>|>|>|>|>|>|>| . |
(name,rarity,price,ammo_type,color,mat,volume,wgt,dmg,AP,range,\accuracy,recoil,count,des) 
 
mi_bedroom],	itm_
[[Inhaler]]
 [[cig]]
 [[Weed]]
 [[Cocaine]]
 [[Meth]]
 [[Heroin]]
 [[Sneakers]]
 [[Mocassins]]
 [[Bandana]]
 [[Eye Glasses]]
 [[Reading Glasses]]
 [[Baseball Hat]]
 [[Backpack]]
 [[Purse]]
 [[Messanger Bag]]
 [[fanny]]
 [[Battery]], itm_bb, itm_bbgun, itm_mag_porn, itm_mag_tv,	itm_mag_news, itm_novel_romance, itm_novel_drama, itm_manual_mechanics,	itm_manual_speech, itm_manual_business, itm_manual_computers,	itm_lighter, itm_sewing_kit, itm_scissors, itm_soldering_iron,	itm_radio, itm_syringe, itm_mp3, NULL);
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 15 | beer | 2 | 1 | 0 | 0 | 0 | 60 | 16 | 4 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 60 | 35 | brown | [[Glass Bottle]] | -4 | -1 | 2 | 1 | 20 | alcohol | [[ADD_ALCOHOL|Alcohol]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Best served cold, in a glass, and with a lime - but you're not that lucky. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 16 | Bleach | 2 | 1 | 0 | 0 | 0 | 60 | -96 | 0 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 20 | 18 | white | [[Plastic Bottle]] | 0 | -8 | 0 | 1 | -30 | bleach | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Don't drink it.  Mixing it with [[ammonia|Ammonia]] produces toxic gas. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|!|h
| 20 | Chunk of Meat | 1 | 2 | 0 | 0 | 0 | 58 | 0 | 20 | 24 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Material]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 50 | 50 | red | [[FLESH|Material_Flesh]] | - | 0 | -1 | 0 | 1 | -10 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Freshly butchered meat.  You could eat it raw, but cooking it is better. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|!|h
| 21 | Chunk of Veggy | 2 | 1 | 0 | 0 | 0 | 58 | 0 | 20 | 80 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Material]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 30 | 60 | Green | [[VEGGY|Material_Veggy]] | - | 0 | 2 | 0 | 1 | 0 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| A raw chunk of vegetable.  Fine for eating raw, tastier when cooked. |
 
/***
|Name:|CloseOnCancelPlugin|
|Description:|Closes the tiddler if you click new tiddler then cancel. Default behaviour is to leave it open|
|Version:|3.0.1a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#CloseOnCancelPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.commands.cancelTiddler,{
  handler_mptw_orig_closeUnsaved: config.commands.cancelTiddler.handler,
  handler: function(event,src,title) {
    this.handler_mptw_orig_closeUnsaved(event,src,title);
    if (!story.isDirty(title) && !store.tiddlerExists(title) && !store.isShadowTiddler(title))
      story.closeTiddler(title,true);
    return false;
  }
});
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 7 | Cola | 2 | 1 | 0 | 0 | 0 | 75 | 18 | 3 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 70 | 35 | brown | [[Drinks Can]] | 6 | -1 | 2 | 1 | 5 | caff | [[ADD_CAFFEINE|Caffeine]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Things go better with cola.  Sugar water with caffeine added. |
 
Movement 
Vikeys or numpad to move or attack 
o - Open a door 
s - Smash a Terrain 
e - Examine 
$ - Sleep 
 ! - Toggle run mode 
. or 5 - Wait for one turn 
C - Close a door 
, or g - Pick up a item 
< or > - Go up or down a stairs 
^ - Long wait 
[edit] Items 
i - View Inventory 
w - Wield item 
W - Wear item 
a - Activate tool 
r - Reload gun or tool 
f - Fire a gun 
p - Power up a bionic / list bionics 
& - Craft Items 
d - drop items 
t - throw items 
T - Take off items 
E - Eat item 
U - Unload a gun or a tool 
F - Burst Fire a gun 
R - read a book 
B - Butcher a corpse 
[edit] Infomation 
@ - View Character stats 
# - List Factions 
C - Chat with a npc 
 % - View moral 
 : or m - View world map 
 ; or x - Look around 
 ? - Help 
[edit] Meta 
S - Save and quit 
Q - Suicide and quit without saving, 
 
| !Recipe  | [[Cooked Spagetti]] |
| !Difficulty | 0 |
| !Primary Skill | [[Cooking]] |
| !Secondary Skill | N/A |
| !Time | 10,000 |
|>| !Tools required |
|>| [[Hotplate]] (4 charges) |
|>| [[Pot]] |
|>| !Components Required |
|>| [[Raw Spagetti]] |
|>|1x [[Water]]  ^^or^^  1x [[Water|Water Dirty]] |
 
|Number|!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
| 20 | Cooked Veggy | 1 | 2 | 0 | 0 | 0 | 58 | 40 | 0 | 0 |
|!Note|>|>|>|>|>|>|>|>|>|>| Freshly cooked Vegatables. Very Nutritious. |f
 
[[Equipment List]]
[[Intro]]
 
4 [[Water]]
5 [[Sewage Sample]]
6 [[Salt Water]]
7 [[OJ]]
8 [[Apple Juice]]
9 [[Energy Drink]]
10 [[Cola]]
11 [[Root Beer]]
12 [[Milk]]
13 [[V8]]
14 [[Broth]]
15 [[Soup]]
15 [[Whiskey]]
16 [[Vodka]]
17 [[Rum]]
18 [[Tequila]]
19 [[Beer]]
20 [[Bleach]]
21 [[Ammonia]]
22 [[Mutagen]]
24 [[Purifier]]
25 [[Tea]]
26 [[Coffee]]
27 [[Human Blood]]
[[Quench]] MAY be less than zero
[[Salt Water]] and [[liquor|Alcohol]] make you thirstier.
 Thirst goes up by 1 every 5 minutes; so a quench of 12 lasts for 1 hour
gone
3 [[Water Dirty]]
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 6 | Energy Drink | 2 | 1 | 0 | 0 | 0 | 60 | 15 | 1 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 50 | 45 | magenta | [[Drinks Can]] | 8 | -2 | 2 | 1 | 5 | caff | [[ADD_CAFFEINE|Caffeine]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Popular among those who need to stay up late working. |
 
[[Drink]] complete
[[Food]]
[[Medication]]
[[Weapons, Melee]]
[[Footwear]]
[[Legwear]]
[[Full-body clothing]]
[[Torso Clothing]]
[[Gloves]]
[[Masks]]
[[Eyewear]]
[[Headwear]]
[[Ammo]]
[[High-Storage]]
[[Fuel]]
[[Guns]]
[[Gun Modifications]]
[[Books]]
[[Containers]]
[[Tools]]
[[Bionics containers]]
[[Traps]]
[[]]
[[]]
[[]]
 
/***
|Name:|ExtentTagButtonPlugin|
|Description:|Adds a New tiddler button in the tag drop down|
|Version:|3.2a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#ExtendTagButtonPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
window.onClickTag_mptw_orig = window.onClickTag;
window.onClickTag = function(e) {
  window.onClickTag_mptw_orig.apply(this,arguments);
  var tag = this.getAttribute("tag");
  var title = this.getAttribute("tiddler");
  // Thanks Saq, you're a genius :)
  var popup = Popup.stack[Popup.stack.length-1].popup;
  createTiddlyElement(createTiddlyElement(popup,"li",null,"listBreak"),"div");
  wikify("<<newTiddler label:'New tiddler' tag:'"+tag+"'>>",createTiddlyElement(popup,"li"));
  return false;
}
//}}}
 
[[Rock]]
[[Strawberries]]
 
28 [[Chunk of Meat]]
29 [[Chunk of Veggy]]
30 [[Tainted Meat]]
31 [[Tainted Vegatables]]
32 [[Cooked Meat]]
33 [[Cooked Vegatables]]
34 [[apple]]
35 [[orange]]
36 [[lemon]]
37 [[potato chips]]
38 [[pretzels]]
39 [[Chocolate Bar]]
40 [[beef jerky]]
41 [[meat sandwich]]
42 [[candy]]
43 [[Edible mushroom]]
44 [[Poison mushroom]]
45 [[Magic mushroom]]
46 [[blueberries]]
47 [[strawberries]]
48 [[tomato]]
49 [[broccoli]]
50 [[zucchini]]
51 [[frozen dinner]]
52 [[cooked TV dinner]]
53 [[spaghetti_raw]]
54 [[cooked spaghetti ]]
55 [[macaroni_raw]]
56 [[Mac & Cheese]]
57 [[ravioli]]
58 [[Red sauce]]
59 [[pesto sauce]]
60 [[can of beans]]
61 [[can of corn]]
62 [[can of spam]]
63 [[can of pineapple]]
64 [[can of coconut milk]]
65 [[can of sardine]]
66 [[can of tuna fish]]
67 [[can of cat food]]
68 [[honey comb]]
69 [[royal jelly]]
70 [[misshapen fetus]]
71 [[arm]]
72 [[leg]]
73 [[ant_egg]]
74 [[Marloss Berry]]
75 [[flour]]
76 [[sugar]]
77 [[salt]]
78 [[potato]]
79 [[potato]]
80 [[bread]]
81 [[fruit pie]]
82 [[pizza]]
83 [[MRE - beef]]
84 [[MRE - vegetable]]
85 [[tea leaves]]
86 [[coffee powder]]
 
[[Rock]]
[[Heavy Stick]]
[[Mushroom]]
[[Mushroom|Mushroom Poison]]
[[Mushroom|Mushroom Magic]]
[[Blueberries]]
 
Fuel is just a special type of ammo; liquid
define FUEL(name,rarity,price,ammo_type,color,dmg,AP,range,accuracy,recoil, count,des) 
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|!|!|h
| 258 | Gasoline | 1 | 0 | 1 | 0 | 0 | 54 |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 0 | 400 | [[Gasoline|~AT_GAS]] | ltred | 0 | 0 | 0 | 0 | 0 | 1 |
|!Description|>|>|>|>|>|>|>|>| Gasoline is a highly flammable liquid.  When under pressure, it has the potential for violent explosion. |
 
 
/***
|Name:|HideWhenPlugin|
|Description:|Allows conditional inclusion/exclusion in templates|
|Version:|3.2a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#HideWhenPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
For use in ViewTemplate and EditTemplate. Example usage:
{{{<div macro="showWhenTagged Task">[[TaskToolbar]]</div>}}}
{{{<div macro="showWhen tiddler.modifier == 'BartSimpson'"><img src="bart.gif"/></div>}}}
Warning: the showWhen and hideWhen macros will blindly eval paramString.
This could be used to execute harmful javascript from a tiddler.
(TODO: Make some effort to sanitize paramString. Perhaps disallow the equals sign?)
***/
//{{{
window.hideWhenLastTest = false;
window.removeElementWhen = function(test,place) {
  window.hideWhenLastTest = test;
  if (test) {
    jQuery(place).empty()
    place.parentNode.removeChild(place);
  }
};
merge(config.macros,{
  hideWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( eval(paramString), place );
  }},
  showWhen: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !eval(paramString), place );
  }},
  hideWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( tiddler.tags.containsAll(params), place );
  }},
  showWhenTagged: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !tiddler.tags.containsAll(params), place );
  }},
  hideWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( tiddler.tags.containsAny(params), place );
  }},
  showWhenTaggedAny: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !tiddler.tags.containsAny(params), place );
  }},
  hideWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( tiddler.tags.containsAll(params), place );
  }},
  showWhenTaggedAll: { handler: function (place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !tiddler.tags.containsAll(params), place );
  }},
  hideWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0]), place );
  }},
  showWhenExists: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !(store.tiddlerExists(params[0]) || store.isShadowTiddler(params[0])), place );
  }},
  hideWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( tiddler.title == params[0], place );
  }},
  showWhenTitleIs: { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( tiddler.title != params[0], place );
  }},
  'else': { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
    removeElementWhen( !window.hideWhenLastTest, place );
  }}
});
//}}}
 
[[Honeycomb]]
[[Royal Jelly]]
 
/***
|Name:|InstantTimestampPlugin|
|Description:|A handy way to insert timestamps in your tiddler content|
|Version:|1.0.10a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#InstantTimestampPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
If you enter {ts} in your tiddler content (without the spaces) it will be replaced with a timestamp when you save the tiddler. Full list of formats:
* {ts} or {t} -> timestamp
* {ds} or {d} -> datestamp
* !ts or !t at start of line -> !!timestamp
* !ds or !d at start of line -> !!datestamp
(I added the extra ! since that's how I like it. Remove it from translations below if required)
!!Notes
* Change the timeFormat and dateFormat below to suit your preference.
* See also http://mptw2.tiddlyspot.com/#AutoCorrectPlugin
* You could invent other translations and add them to the translations array below.
***/
//{{{
config.InstantTimestamp = {
  // adjust to suit
  timeFormat: 'DD/0MM/YY 0hh:0mm',
  dateFormat: 'DD/0MM/YY',
  translations: [
    [/^!ts?$/img,  "'!!{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
    [/^!ds?$/img,  "'!!{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"],
    // thanks Adapted Cat
    [/\{ts?\}(?!\}\})/ig,"'{{ts{'+now.formatString(config.InstantTimestamp.timeFormat)+'}}}'"],
    [/\{ds?\}(?!\}\})/ig,"'{{ds{'+now.formatString(config.InstantTimestamp.dateFormat)+'}}}'"]
  ],
  excludeTags: [
    "noAutoCorrect",
    "noTimestamp",
    "html",
    "CSS",
    "css",
    "systemConfig",
    "systemConfigDisabled",
    "zsystemConfig",
    "Plugins",
    "Plugin",
    "plugins",
    "plugin",
    "javascript",
    "code",
    "systemTheme",
    "systemPalette"
  ],
  excludeTiddlers: [
    "StyleSheet",
    "StyleSheetLayout",
    "StyleSheetColors",
    "StyleSheetPrint"
    // more?
  ]
};
TiddlyWiki.prototype.saveTiddler_mptw_instanttimestamp = TiddlyWiki.prototype.saveTiddler;
TiddlyWiki.prototype.saveTiddler = function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created) {
  tags = tags ? tags : []; // just in case tags is null
  tags = (typeof(tags) == "string") ? tags.readBracketedList() : tags;
  var conf = config.InstantTimestamp;
  if ( !tags.containsAny(conf.excludeTags) && !conf.excludeTiddlers.contains(newTitle) ) {
    var now = new Date();
    var trans = conf.translations;
    for (var i=0;i<trans.length;i++) {
      newBody = newBody.replace(trans[i][0], eval(trans[i][1]));
    }
  }
  // TODO: use apply() instead of naming all args?
  return this.saveTiddler_mptw_instanttimestamp(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created);
}
// you can override these in StyleSheet
setStylesheet(".ts,.ds { font-style:italic; }","instantTimestampStyles");
//}}}
 
Cataclysm is a post-apocalyptic roguelike, set in the countryside of New Englandafter a devastating plague of monsters and zombies.
At present time, Cataclysm is still in early alpha, and is being developed very rapidly.  As such, there are no formal version numbers, as a new version isreleased every day, often several a day.
Source is available at the github repository, http://github.com/Whales/CataclysmThere is also a tarball available at http://squidnet.ath.cx/cataclysm.tar.gz Squidnet maintains a public SSH server.  If you cannot play Cataclysm locally,or if you prefer to play it in a world shared with others, connect tocataclysm@squidnet.ath.cx (there is no password).
Compiling Cataclysm under linux is straightforward, and only requires then curses development libraries.  Under Ubuntu, these libraries can be found inthe libncurses5-dev package ("sudo apt-get install libncurses5-dev" will installthis package).
Cataclysm is very different from most roguelikes in many ways.  Rather than being set in a vertical, linear dungeon, it is set in an unbounded, 3D world.This means that exploration plays a much bigger role than in most roguelikes,and the game is much less linear.
Because the map is so huge, it is actually completely persistant between games.If you die, and start a new character, your new game will be set in the samegame world as your last.  Like in many roguelikes, you will be able to loot thedead bodies of previous characters; unlike most roguelikes, you will also be able to retrace their steps completely, and any dramatic changes made to theworld will persist into your next game.
While this makes for interesting depth of play, and the ability to "save" gameprogress even after death, some prefer to start each game with a freshlygenerated world.  This can be achieved by erasing the contents of the savedirectory, found in the same folder as the executable.  "rm save/*" will erasethese files for you.
Cataclysm's gameplay also includes many unique quirks, and the learning curve is somewhat steep, even for those experienced with roguelikes.  Included with thegame is a tutorial which runs the player through most of the key features.  The game also has extensive documentation via the ? command.  Pressing ?1 will listall the key commands, which is a good place to start.
To submit a bug, complaint, feature request, or praise, please send them viaemail to fivedozenwhales@gmail.com.  You can also submit problem reports andpatches at the github repository at http://github.com/Whales/Cataclysm .
I strive to include as many feature requests as possible, and if you submit onethere is a good chance that it will appear in the game within a few days.  Ofcourse, it is inevitable that I will reject some feature requests, eitherbecause they do not fit my conception of the game, or because they require morecode than I think they're worth.  Feature requests supplied in the form of apatch stand a better chance of inclusion, of course ;)  For instructions onmaking changes to item types, monster types, etc., please see the EDITING file.Most changes of this variety require no training in C++, or programming ingeneral.
If you want to take Cataclysm in a new direction, please feel free to create abranch project -just let me know about it!
Above taken from https://github.com/Whales/Cataclysm/blob/master/README and may be inaccurate at time of viewing here. Cataclysm belongs to Whales (author), not me.
 
 [[Pot]]
 [[Frying Pan]] 
 [[Butter Knife]]
 [[Steak Knife]]
 [[Butcher Knife]] 
 [[Cookbook]]
 [[Rag]]
 [[Hotplate]]
 [[Flashlight]]
 [[Fire Extinguisher]]
 [[Whiskey]]
 [[Bleach]]
 [[Ammonia]]
 
/***
|Name:|LessBackupsPlugin|
|Description:|Intelligently limit the number of backup files you create|
|Version:|3.0.1a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#LessBackupsPlugin|
|Author:|Simon Baird|
|Email:|simon.baird@gmail.com|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Description
You end up with just backup one per year, per month, per weekday, per hour, minute, and second.  So total number won't exceed about 200 or so. Can be reduced by commenting out the seconds/minutes/hours line from modes array
!!Notes
Works in IE and Firefox only.  Algorithm by Daniel Baird. IE specific code by by Saq Imtiaz.
***/
//{{{
var MINS  = 60 * 1000;
var HOURS = 60 * MINS;
var DAYS  = 24 * HOURS;
if (!config.lessBackups) {
  config.lessBackups = {
    // comment out the ones you don't want or set config.lessBackups.modes in your 'tweaks' plugin
    modes: [
      ["YYYY",  365*DAYS], // one per year for ever
      ["MMM",   31*DAYS],  // one per month
      ["ddd",   7*DAYS],   // one per weekday
      //["d0DD",  1*DAYS],   // one per day of month
      ["h0hh",  24*HOURS], // one per hour
      ["m0mm",  1*HOURS],  // one per minute
      ["s0ss",  1*MINS],   // one per second
      ["latest",0]         // always keep last version. (leave this).
    ]
  };
}
window.getSpecialBackupPath = function(backupPath) {
  var now = new Date();
  var modes = config.lessBackups.modes;
  for (var i=0;i<modes.length;i++) {
    // the filename we will try
    var specialBackupPath = backupPath.replace(/(\.)([0-9]+\.[0-9]+)(\.html)$/,
        '$1'+now.formatString(modes[i][0]).toLowerCase()+'$3')
    // open the file
    try {
      if (config.browser.isIE) {
        var fsobject = new ActiveXObject("Scripting.FileSystemObject")
        var fileExists  = fsobject.FileExists(specialBackupPath);
        if (fileExists) {
          var fileObject = fsobject.GetFile(specialBackupPath);
          var modDate = new Date(fileObject.DateLastModified).valueOf();
        }
      }
      else {
        netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
        var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
        file.initWithPath(specialBackupPath);
        var fileExists = file.exists();
        if (fileExists) {
          var modDate = file.lastModifiedTime;
        }
      }
    }
    catch(e) {
      // give up
      return backupPath;
    }
    // expiry is used to tell if it's an 'old' one. Eg, if the month is June and there is a
    // June file on disk that's more than an month old then it must be stale so overwrite
    // note that "latest" should be always written because the expiration period is zero (see above)
    var expiry = new Date(modDate + modes[i][1]);
    if (!fileExists || now > expiry)
      return specialBackupPath;
  }
}
// hijack the core function
window.getBackupPath_mptw_orig = window.getBackupPath;
window.getBackupPath = function(localPath) {
  return getSpecialBackupPath(getBackupPath_mptw_orig(localPath));
}
//}}}
 
[[Rootbeer]]
 [[Cola]]
 [[Ciggarette]] 
 [[Weed]] 
 [[Coke]] 
 [[Meth]]
 [[Sneakers]]
 [[Boots]]
 [[Winter Boots]]
 [[Flip Flops]]
 [[Dress Shoes]] 
 [[Heels]]
 [[Rain Coat]]
 [[Poncho]]
 [[Light Gloves]]
 [[Mittens]]
 [[Wool Gloves]]
 [[Winter Gloves]]
 [[Leather Gloves]]
 [[Fingerless Gloves]]
 [[Bandana]]
 [[Scarf]]
 [[Cotton Hat]]
 [[Knited Hat]]
 [[Fur Hat]]	
 [[Bike Helmet]]
 [[Motorcycle Helmet]]
 [[mag_tv]]
 [[mag_news]]
 [[Lighter]]
 [[Extinguisher]]
 [[MP3 Player]]
 
/***
|''Name:''|LoadRemoteFileThroughProxy (previous LoadRemoteFileHijack)|
|''Description:''|When the TiddlyWiki file is located on the web (view over http) the content of [[SiteProxy]] tiddler is added in front of the file url. If [[SiteProxy]] does not exist "/proxy/" is added. |
|''Version:''|1.1.0|
|''Date:''|mar 17, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#LoadRemoteFileHijack|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
***/
//{{{
version.extensions.LoadRemoteFileThroughProxy = {
 major: 1, minor: 1, revision: 0, 
 date: new Date("mar 17, 2007"), 
 source: "http://tiddlywiki.bidix.info/#LoadRemoteFileThroughProxy"};
if (!window.bidix) window.bidix = {}; // bidix namespace
if (!bidix.core) bidix.core = {};
bidix.core.loadRemoteFile = loadRemoteFile;
loadRemoteFile = function(url,callback,params)
{
 if ((document.location.toString().substr(0,4) == "http") && (url.substr(0,4) == "http")){ 
 url = store.getTiddlerText("SiteProxy", "/proxy/") + url;
 }
 return bidix.core.loadRemoteFile(url,callback,params);
}
//}}}
 
<<newTiddler label:"New FoodDrink" tag:"Food""Drink" text:{{store.getTiddlerText('New FoodDrink Template')}}>>
<<newTiddler label:"New Ammo" tag:"Ammo""AT_""Material_" text:{{store.getTiddlerText('New Ammo Template')}}>>
 
[[Equipment List]] <<newTiddler label:"New Drink" tag:"Food""Drink" text:{{store.getTiddlerText('New Drink Template')}}>>  <<newTiddler label:"New Food" tag:"Food""Food" text:{{store.getTiddlerText('New Food Template')}}>>
<<newTiddler label:"New Ammo" tag:"Ammo""AT_""Material_" text:{{store.getTiddlerText('New Ammo Template')}}>>
 [[New Tools]]
 
|Number|!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
| 65 | Marloss Berry | 1 | 1 | 0 | 0 | 0 | 56  | 40 | 20 | 30 |
|!Note|>|>|>|>|>|>|>|>|>|>| This looks like a blueberry the size of your fist, but pinkish in color.  It has a strong but delicious aroma, but is clearly either mutated or of alien origin. |f
 
87 [[bandages]]
88 [[1st_aid]]
89 [[Vitamins]]
90 [[Aspirin]]
 [[Caffeine]]
 [[pills_sleep]]
 [[Iodine]]
 [[Dayquil]]
 [[Nyquil]]
 [[Inhaler]]
 [[Codeine]]
 [[oxycodone]]
 [[tramadol]]
 [[xanax]]
 [[adderall]]
 [[thorazine]]
 [[prozac]]
 [[cig]]
 [[weed]]
 [[coke]]
 [[meth]]
 [[heroin]]
 [[cigar]]
 [[antibiotics]]
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 9 | Milk | 2 | 1 | 0 | 0 | 0 | 60 | 25 | 8 | 8 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 50 | 35 | white | [[Glass Bottle]] | 0 | 1 | 0 | 1 | 0 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Baby cow food, appropriated for adult humans.  Spoils rapidly. |
 
when I can't decide or not obvious.
 
Name: MptwBlack
Background: #000
Foreground: #fff
PrimaryPale: #333
PrimaryLight: #555
PrimaryMid: #888
PrimaryDark: #aaa
SecondaryPale: #111
SecondaryLight: #222
SecondaryMid: #555
SecondaryDark: #888
TertiaryPale: #222
TertiaryLight: #666
TertiaryMid: #888
TertiaryDark: #aaa
Error: #300
 
Name: MptwBlue
Background: #fff
Foreground: #000
PrimaryPale: #cdf
PrimaryLight: #57c
PrimaryMid: #114
PrimaryDark: #012
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
 
//{{{
// Pretty sure this is incomplete and experimental
// TODO: Fix it or remove it.
(function($){
merge(config.macros,{
  mptwCollapse: {
    handler: function(place,macroName,params) {
      createTiddlyButton(place, params[0] == '+' ? '\u25AD' : '\u25AC', 'collapse/uncollapse', function(){
        $(story.findContainingTiddler(place)).toggleClass('collapsed');
      });
    }
  }
});
/* this doesn't work unless you have a modified ViewTempate */
config.shadowTiddlers["MptwCollapsePluginStyles"] = ""
  +".collapsed .uncollapsedView { display:none;       }"
  +".collapsedView              { display:none;       }"
  +".collapsed .collapsedView   { display:block;      }"
  +".tiddler.collapsed          { padding-bottom:1em; }"
  +".tiddler.collapsed .title   { font-size:100%;     }"
;
store.addNotification("MptwCollapsePluginStyles",refreshStyles);
})(jQuery);
//}}}
 
/***
|Name:|MptwConfigPlugin|
|Description:|Miscellaneous tweaks used by MPTW|
|Version:|1.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#MptwConfigPlugin|
!!Note: instead of editing this you should put overrides in MptwUserConfigPlugin
***/
//{{{
var originalReadOnly = readOnly;
var originalShowBackstage = showBackstage;
config.options.chkHttpReadOnly = false;  // means web visitors can experiment with your site by clicking edit
readOnly = false;                        // needed because the above doesn't work any more post 2.1 (??)
showBackstage = true;                    // show backstage for same reason
config.options.chkInsertTabs = true;     // tab inserts a tab when editing a tiddler
config.views.wikified.defaultText = "";  // don't need message when a tiddler doesn't exist
config.views.editor.defaultText = "";    // don't need message when creating a new tiddler
config.options.chkSaveBackups = true;         // do save backups
config.options.txtBackupFolder = 'twbackup';  // put backups in a backups folder
config.options.chkAutoSave = (window.location.protocol == "file:"); // do autosave if we're in local file
config.mptwVersion = "2.5.3";
config.macros.mptwVersion={handler:function(place){wikify(config.mptwVersion,place);}};
if (config.options.txtTheme == '')
  config.options.txtTheme = 'MptwTheme';
// add to default GettingStarted
config.shadowTiddlers.GettingStarted += "\n\nSee also [[MPTW]].";
// add select theme and palette controls in default OptionsPanel
config.shadowTiddlers.OptionsPanel = config.shadowTiddlers.OptionsPanel.replace(/(\n\-\-\-\-\nAlso see \[\[AdvancedOptions\]\])/, "{{select{<<selectTheme>>\n<<selectPalette>>}}}$1");
// these are used by ViewTemplate
config.mptwDateFormat = 'DD/MM/YY';
config.mptwJournalFormat = 'Journal DD/MM/YY';
//}}}
 
Name: MptwGreen
Background: #fff
Foreground: #000
PrimaryPale: #9b9
PrimaryLight: #385
PrimaryMid: #031
PrimaryDark: #020
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
 
Name: MptwRed
Background: #fff
Foreground: #000
PrimaryPale: #eaa
PrimaryLight: #c55
PrimaryMid: #711
PrimaryDark: #500
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
 
|Name|MptwRounded|
|Description|Mptw Theme with some rounded corners (Firefox only)|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|PageTemplate|MptwTheme##PageTemplate|
|StyleSheet|##StyleSheet|
!StyleSheet
/*{{{*/
[[MptwTheme##StyleSheet]]
.tiddler,
.sliderPanel,
.button,
.tiddlyLink,
.tabContents
{ -moz-border-radius: 1em; }
.tab {
	-moz-border-radius-topleft: 0.5em;
	-moz-border-radius-topright: 0.5em;
}
#topMenu {
	-moz-border-radius-bottomleft: 2em;
	-moz-border-radius-bottomright: 2em;
}
/*}}}*/
 
Name: MptwSmoke
Background: #fff
Foreground: #000
PrimaryPale: #aaa
PrimaryLight: #777
PrimaryMid: #111
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
 
|Name|MptwStandard|
|Description|Mptw Theme with the default TiddlyWiki PageLayout and Styles|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
 
Name: MptwTeal
Background: #fff
Foreground: #000
PrimaryPale: #B5D1DF
PrimaryLight: #618FA9
PrimaryMid: #1a3844
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #f8f8f8
TertiaryLight: #bbb
TertiaryMid: #999
TertiaryDark: #888
Error: #f88
 
|Name|MptwTheme|
|Description|Mptw Theme including custom PageLayout|
|PageTemplate|##PageTemplate|
|ViewTemplate|##ViewTemplate|
|EditTemplate|##EditTemplate|
|StyleSheet|##StyleSheet|
http://mptw.tiddlyspot.com/#MptwTheme ($Rev: 1829 $)
!PageTemplate
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
	<div class='headerShadow'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span> 
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
	<div class='headerForeground'>
		<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span> 
		<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
	</div>
</div>
<!-- horizontal MainMenu -->
<div id='topMenu' refresh='content' tiddler='MainMenu'></div>
<!-- original MainMenu menu -->
<!-- <div id='mainMenu' refresh='content' tiddler='MainMenu'></div> -->
<div id='sidebar'>
	<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
	<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='displayArea'>
	<div id='messageArea'></div>
	<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
!ViewTemplate
<!--{{{-->
<div class="uncollapsedView">
[[MptwTheme##ViewTemplateToolbar]]
<div class="tagglyTagged" macro="tags"></div>
<div class='titleContainer'>
	<span class='title' macro='view title'></span>
	<span macro="miniTag"></span>
</div>
<div class='subtitle'>
	(updated <span macro='view modified date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>
	by <span macro='view modifier link'></span>)
	<!--
	(<span macro='message views.wikified.createdPrompt'></span>
	<span macro='view created date {{config.mptwDateFormat?config.mptwDateFormat:"MM/0DD/YY"}}'></span>)
	-->
</div>
<div macro="showWhen tiddler.tags.containsAny(['css','html','pre','systemConfig']) && !tiddler.text.match('{{'+'{')">
	<div class='viewer'><pre macro='view text'></pre></div>
</div>
<div macro="else">
	<div class='viewer' macro='view text wikified'></div>
</div>
<div class="tagglyTagging" macro="tagglyTagging"></div>
</div>
<div class="collapsedView">
	<span class='toolbar'>
		<span macro='toolbar closeTiddler'></span>
		<span macro='mptwCollapse +'></span>
	</span>
	<span class='title' macro='view title'></span>
</div>
<!--}}}-->
!ViewTemplateToolbar
<!--{{{-->
<div class='toolbar'>
	<span macro="showWhenTagged systemConfig">
		<span macro="toggleTag systemConfigDisable . '[[disable|systemConfigDisable]]'"></span>
	</span>
	<span macro="showWhenTagged systemTheme"><span macro="applyTheme"></span></span>
	<span macro="showWhenTagged systemPalette"><span macro="applyPalette"></span></span>
	<span macro="showWhen tiddler.tags.contains('css') || tiddler.title == 'StyleSheet'"><span macro="refreshAll"></span></span>
	<span style="padding:1em;"></span>
	<span macro='toolbar closeTiddler closeOthers +editTiddler deleteTiddler > fields syncing permalink references jump'></span> <span macro='newHere label:"new here"'></span>
	<span macro='newJournalHere {{config.mptwJournalFormat?config.mptwJournalFormat:"MM/0DD/YY"}}'></span>
	<!--span macro='mptwCollapse -'></span-->
</div>
<!--}}}-->
!EditTemplate
<!--{{{-->
<div class="toolbar" macro="toolbar +saveTiddler saveCloseTiddler closeOthers -cancelTiddler cancelCloseTiddler deleteTiddler"></div>
<div class="title" macro="view title"></div>
<div class="editLabel">Title</div><div class="editor" macro="edit title"></div>
<div macro='annotations'></div>
<div class="editLabel">Content</div><div class="editor" macro="edit text"></div>
<div class="editLabel">Tags</div><div class="editor" macro="edit tags"></div>
<div class="editorFooter"><span macro="message views.editor.tagPrompt"></span><span macro="tagChooser"></span></div>
<!--}}}-->
!StyleSheet
/*{{{*/
/* a contrasting background so I can see where one tiddler ends and the other begins */
body {
	background: [[ColorPalette::TertiaryLight]];
}
/* sexy colours and font for the header */
.headerForeground {
	color: [[ColorPalette::PrimaryPale]];
}
.headerShadow, .headerShadow a {
	color: [[ColorPalette::PrimaryMid]];
}
/* separate the top menu parts */
.headerForeground, .headerShadow {
	padding: 1em 1em 0;
}
.headerForeground, .headerShadow {
	font-family: 'Trebuchet MS', sans-serif;
	font-weight:bold;
}
.headerForeground .siteSubtitle {
	color: [[ColorPalette::PrimaryLight]];
}
.headerShadow .siteSubtitle {
	color: [[ColorPalette::PrimaryMid]];
}
/* make shadow go and down right instead of up and left */
.headerShadow {
	left: 1px;
	top: 1px;
}
/* prefer monospace for editing */
.editor textarea, .editor input {
	font-family: 'Consolas', monospace;
	background-color:[[ColorPalette::TertiaryPale]];
}
/* sexy tiddler titles */
.title {
	font-size: 250%;
	color: [[ColorPalette::PrimaryLight]];
	font-family: 'Trebuchet MS', sans-serif;
}
/* more subtle tiddler subtitle */
.subtitle {
	padding:0px;
	margin:0px;
	padding-left:1em;
	font-size: 90%;
	color: [[ColorPalette::TertiaryMid]];
}
.subtitle .tiddlyLink {
	color: [[ColorPalette::TertiaryMid]];
}
/* a little bit of extra whitespace */
.viewer {
	padding-bottom:3px;
}
/* don't want any background color for headings */
h1,h2,h3,h4,h5,h6 {
	background-color: transparent;
	color: [[ColorPalette::Foreground]];
}
/* give tiddlers 3d style border and explicit background */
.tiddler {
	background: [[ColorPalette::Background]];
	border-right: 2px [[ColorPalette::TertiaryMid]] solid;
	border-bottom: 2px [[ColorPalette::TertiaryMid]] solid;
	margin-bottom: 1em;
	padding:1em 2em 2em 1.5em;
}
/* make options slider look nicer */
#sidebarOptions .sliderPanel {
	border:solid 1px [[ColorPalette::PrimaryLight]];
}
/* the borders look wrong with the body background */
#sidebar .button {
	border-style: none;
}
/* this means you can put line breaks in SidebarOptions for readability */
#sidebarOptions br {
	display:none;
}
/* undo the above in OptionsPanel */
#sidebarOptions .sliderPanel br {
	display:inline;
}
/* horizontal main menu stuff */
#displayArea {
	margin: 1em 15.7em 0em 1em; /* use the freed up space */
}
#topMenu br {
	display: none;
}
#topMenu {
	background: [[ColorPalette::PrimaryMid]];
	color:[[ColorPalette::PrimaryPale]];
}
#topMenu {
	padding:2px;
}
#topMenu .button, #topMenu .tiddlyLink, #topMenu a {
	margin-left: 0.5em;
	margin-right: 0.5em;
	padding-left: 3px;
	padding-right: 3px;
	color: [[ColorPalette::PrimaryPale]];
	font-size: 115%;
}
#topMenu .button:hover, #topMenu .tiddlyLink:hover {
	background: [[ColorPalette::PrimaryDark]];
}
/* make 2.2 act like 2.1 with the invisible buttons */
.toolbar {
	visibility:hidden;
}
.selected .toolbar {
	visibility:visible;
}
/* experimental. this is a little borked in IE7 with the button 
 * borders but worth it I think for the extra screen realestate */
.toolbar { float:right; }
/* fix for TaggerPlugin. from sb56637. improved by FND */
.popup li .tagger a {
   display:inline;
}
/* makes theme selector look a little better */
#sidebarOptions .sliderPanel .select .button {
  padding:0.5em;
  display:block;
}
#sidebarOptions .sliderPanel .select br {
	display:none;
}
/* make it print a little cleaner */
@media print {
	#topMenu {
		display: none ! important;
	}
	/* not sure if we need all the importants */
	.tiddler {
		border-style: none ! important;
		margin:0px ! important;
		padding:0px ! important;
		padding-bottom:2em ! important;
	}
	.tagglyTagging .button, .tagglyTagging .hidebutton {
		display: none ! important;
	}
	.headerShadow {
		visibility: hidden ! important;
	}
	.tagglyTagged .quickopentag, .tagged .quickopentag {
		border-style: none ! important;
	}
	.quickopentag a.button, .miniTag {
		display: none ! important;
	}
}
/* get user styles specified in StyleSheet */
[[StyleSheet]]
/*}}}*/
 
|Name|MptwTrim|
|Description|Mptw Theme with a reduced header to increase useful space|
|ViewTemplate|MptwTheme##ViewTemplate|
|EditTemplate|MptwTheme##EditTemplate|
|StyleSheet|MptwTheme##StyleSheet|
|PageTemplate|##PageTemplate|
!PageTemplate
<!--{{{-->
<!-- horizontal MainMenu -->
<div id='topMenu' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<span refresh='content' tiddler='SiteTitle' style="padding-left:1em;font-weight:bold;"></span>:
<span refresh='content' tiddler='MainMenu'></span>
</div>
<div id='sidebar'>
	<div id='sidebarOptions'>
		<div refresh='content' tiddler='SideBarOptions'></div>
		<div style="margin-left:0.1em;"
			macro='slider chkTabSliderPanel SideBarTabs {{"tabs \u00bb"}} "Show Timeline, All, Tags, etc"'></div>
	</div>
</div>
<div id='displayArea'>
	<div id='messageArea'></div>
	<div id='tiddlerDisplay'></div>
</div>
 
/***
|Description:|A place to put your config tweaks so they aren't overwritten when you upgrade MPTW|
See http://www.tiddlywiki.org/wiki/Configuration_Options for other options you can set. In some cases where there are clashes with other plugins it might help to rename this to zzMptwUserConfigPlugin so it gets executed last.
***/
//{{{
// example: set your preferred date format
//config.mptwDateFormat = 'MM/0DD/YY';
//config.mptwJournalFormat = 'Journal MM/0DD/YY';
// example: set the theme you want to start with
//config.options.txtTheme = 'MptwRoundTheme';
// example: switch off autosave, switch on backups and set a backup folder
//config.options.chkSaveBackups = true;
//config.options.chkAutoSave = false;
//config.options.txtBackupFolder = 'backups';
// uncomment to disable 'new means new' functionality for the new journal macro
//config.newMeansNewForJournalsToo = false;
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 18 | mutagen | 2 | 1 | 0 | 0 | 0 | 60 | 0 | 0 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 8 | 8000 | magenta | [[Glass Bottle]] | 0 | -2 | 0 | 1 | 0 | mutagen | - |
|!Description|>|>|>|>|>|>|>|>|>|>| A rare substance of uncertain origins.  Causes you to mutate. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 225 | nails | 1 | 8 | 1 | 0 | 0 | 56 |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 20 | 60 | [[Nails|AT_NAIL]] | cyan | [[IRON|Material_Iron]] | 4 | 3 | 4 | 40 | 4 | 100 |
|!Description|>|>|>|>|>|>|>|>|>|>| A box of nails, mainly useful with a hammer. |
 
 
[[]]
[[NULL]]
[[Near Sighted]]
[[Heavy Sleeper]]
[[Asthmatic]]
[[Bad Baxk]]
[[Illiterate]]
[[Poor Hearing]]
[[Insomniac]]
[[Vegetarian]]
[[Glass Jaw]]
[[Forgetful]]
[[Lightweight]]
[[Addictive Personality]]
[[Trigger Happy]]
[[Smelly]]
[[Chemical Imbalance]]
[[Schizophrenic]]
[[Jittery]]
[[Hoarder]]
[[Savant]]
[[Mood Swings]]
[[Weak Stomach]]
[[Wool Allergy]]
[[Truth Teller]]
[[Ugly]]
[[Bug - PF_MAX]]
[[]]
[[]]
[[]]
[[]]
[[]]
[[]]
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
|  |  |  |  |  |  |  |  |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
|  |  |  | [[AT_]] | [[|Material_]] |  |  |  |  | 0 |  |
|!Description|>|>|>|>|>|>|>|>|>|>| . |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
|  |  | 2 | 1 | 0 | 0 | 0 | 60 |  |  |  |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
|  |  |  | [[]] |  |  |  |  |  | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| . |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|!|h
|  |  |  |  |  |  |  |  |  |  |  |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Material]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
|  |  |  |  [[|Material_]] | [[]] |  |  |  |  |  | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| . |
 
|Number|!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
|  |  |  |  |  |  |  |  |  |  |  |
|!Note|>|>|>|>|>|>|>|>|>|>|  |f
 
/***
|Name:|NewHerePlugin|
|Description:|Creates the new here and new journal macros|
|Version:|3.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#NewHerePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
merge(config.macros, {
  newHere: {
    handler: function(place,macroName,params,wikifier,paramString,tiddler) {
      wikify("<<newTiddler "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
    }
  },
  newJournalHere: {
    handler: function(place,macroName,params,wikifier,paramString,tiddler) {
      wikify("<<newJournal "+paramString+" tag:[["+tiddler.title+"]]>>",place,null,tiddler);
    }
  }
});
//}}}
 
/***
|Name:|NewMeansNewPlugin|
|Description:|If 'New Tiddler' already exists then create 'New Tiddler (1)' and so on|
|Version:|1.1.1a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/empty.html#NewMeansNewPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Note: I think this should be in the core
***/
//{{{
// change this or set config.newMeansNewForJournalsToo it in MptwUuserConfigPlugin
if (config.newMeansNewForJournalsToo == undefined) config.newMeansNewForJournalsToo = true;
String.prototype.getNextFreeName = function() {
  numberRegExp = / \(([0-9]+)\)$/;
  var match = numberRegExp.exec(this);
  if (match) {
  var num = parseInt(match[1]) + 1;
    return this.replace(numberRegExp," ("+num+")");
  }
  else {
    return this + " (1)";
  }
}
config.macros.newTiddler.checkForUnsaved = function(newName) {
  var r = false;
  story.forEachTiddler(function(title,element) {
    if (title == newName)
      r = true;
  });
  return r;
}
config.macros.newTiddler.getName = function(newName) {
  while (store.getTiddler(newName) || config.macros.newTiddler.checkForUnsaved(newName))
    newName = newName.getNextFreeName();
  return newName;
}
config.macros.newTiddler.onClickNewTiddler = function()
{
  var title = this.getAttribute("newTitle");
  if(this.getAttribute("isJournal") == "true") {
    title = new Date().formatString(title.trim());
  }
  // ---- these three lines should be the only difference between this and the core onClickNewTiddler
  if (config.newMeansNewForJournalsToo || this.getAttribute("isJournal") != "true")
    title = config.macros.newTiddler.getName(title);
  var params = this.getAttribute("params");
  var tags = params ? params.split("|") : [];
  var focus = this.getAttribute("newFocus");
  var template = this.getAttribute("newTemplate");
  var customFields = this.getAttribute("customFields");
  if(!customFields && !store.isShadowTiddler(title))
    customFields = String.encodeHashMap(config.defaultCustomFields);
  story.displayTiddler(null,title,template,false,null,null);
  var tiddlerElem = story.getTiddler(title);
  if(customFields)
    story.addCustomFields(tiddlerElem,customFields);
  var text = this.getAttribute("newText");
  if(typeof text == "string")
    story.getTiddlerField(title,"text").value = text.format([title]);
  for(var t=0;t<tags.length;t++)
    story.setTiddlerTag(title,tags[t],+1);
  story.focusTiddler(title,focus);
  return false;
};
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 5 | Water | 2 | 1 | 0 | 0 | 0 | 60 | 35 | 0 | 120 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 50 | 38 | Yellow | [[Plastic Bottle]] | 0 | 2 | 0 | 1 | 0 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Fresh squeezed from real oranges!  Tasty and nutritious. |
 
/***
|''Name:''|PasswordOptionPlugin|
|''Description:''|Extends TiddlyWiki options with non encrypted password option.|
|''Version:''|1.0.2|
|''Date:''|Apr 19, 2007|
|''Source:''|http://tiddlywiki.bidix.info/#PasswordOptionPlugin|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0 (Beta 5)|
***/
//{{{
version.extensions.PasswordOptionPlugin = {
	major: 1, minor: 0, revision: 2, 
	date: new Date("Apr 19, 2007"),
	source: 'http://tiddlywiki.bidix.info/#PasswordOptionPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	license: '[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D]]',
	coreVersion: '2.2.0 (Beta 5)'
};
config.macros.option.passwordCheckboxLabel = "Save this password on this computer";
config.macros.option.passwordInputType = "password"; // password | text
setStylesheet(".pasOptionInput {width: 11em;}\n","passwordInputTypeStyle");
merge(config.macros.option.types, {
	'pas': {
		elementType: "input",
		valueField: "value",
		eventName: "onkeyup",
		className: "pasOptionInput",
		typeValue: config.macros.option.passwordInputType,
		create: function(place,type,opt,className,desc) {
			// password field
			config.macros.option.genericCreate(place,'pas',opt,className,desc);
			// checkbox linked with this password "save this password on this computer"
			config.macros.option.genericCreate(place,'chk','chk'+opt,className,desc);			
			// text savePasswordCheckboxLabel
			place.appendChild(document.createTextNode(config.macros.option.passwordCheckboxLabel));
		},
		onChange: config.macros.option.genericOnChange
	}
});
merge(config.optionHandlers['chk'], {
	get: function(name) {
		// is there an option linked with this chk ?
		var opt = name.substr(3);
		if (config.options[opt]) 
			saveOptionCookie(opt);
		return config.options[name] ? "true" : "false";
	}
});
merge(config.optionHandlers, {
	'pas': {
 		get: function(name) {
			if (config.options["chk"+name]) {
				return encodeCookie(config.options[name].toString());
			} else {
				return "";
			}
		},
		set: function(name,value) {config.options[name] = decodeCookie(value);}
	}
});
// need to reload options to load passwordOptions
loadOptionsCookie();
/*
if (!config.options['pasPassword'])
	config.options['pasPassword'] = '';
merge(config.optionsDesc,{
		pasPassword: "Test password"
	});
*/
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 224 | plutonium cell | 1 | 0 | 1 | 0 | 0 | 54 |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 10 | 3000 | [[Plutonium|AT_PLUT]] | ltgreen | [[Steel|Material_Steel]] | 0 | 0 | 0 | 0 | 0 | 5 |
|!Description|>|>|>|>|>|>|>|>|>|>| A nuclear-powered battery.  Used to charge advanced and rare electronics. |
 
 
[[]]
[[NULL Trait]]
[[Fleet Footed]]
[[Parkour Expert]]
[[Quick]]
[[Optimist]]
[[Fast Healer]]
[[Light Eater]]
[[Pain Resistant]]
[[Night Vision]]
[[Poison Resistant]]
[[Fast Reader]]
[[Tough]]
[[Thick-Skinned]]
[[Packmule]]
[[Fast Learner]]
[[Deft]]
[[Drunken Master]]
[[Gourmand]]
[[Animal Empathy]]
[[Terrifying]]
[[Disease Resistant]]
[[High Adrenaline]]
[[Inconspicuous]]
[[Masochist]]
[[Light Step]]
[[Heartless]]
[[Android]]
[[Robust Genetics]]
[[Martial Arts Training]]
 
/***
|Name:|PrettyDatesPlugin|
|Description:|Provides a new date format ('pppp') that displays times such as '2 days ago'|
|Version:|1.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#PrettyDatesPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Notes
* If you want to you can rename this plugin. :) Some suggestions: LastUpdatedPlugin, RelativeDatesPlugin, SmartDatesPlugin, SexyDatesPlugin.
* Inspired by http://ejohn.org/files/pretty.js
***/
//{{{
Date.prototype.prettyDate = function() {
  var diff = (((new Date()).getTime() - this.getTime()) / 1000);
  var day_diff = Math.floor(diff / 86400);
  if (isNaN(day_diff))      return "";
  else if (diff < 0)        return "in the future";
  else if (diff < 60)       return "just now";
  else if (diff < 120)      return "1 minute ago";
  else if (diff < 3600)     return Math.floor(diff/60) + " minutes ago";
  else if (diff < 7200)     return "1 hour ago";
  else if (diff < 86400)    return Math.floor(diff/3600) + " hours ago";
  else if (day_diff == 1)   return "Yesterday";
  else if (day_diff < 7)    return day_diff + " days ago";
  else if (day_diff < 14)   return  "a week ago";
  else if (day_diff < 31)   return Math.ceil(day_diff/7) + " weeks ago";
  else if (day_diff < 62)   return "a month ago";
  else if (day_diff < 365)  return "about " + Math.ceil(day_diff/31) + " months ago";
  else if (day_diff < 730)  return "a year ago";
  else                      return Math.ceil(day_diff/365) + " years ago";
}
Date.prototype.formatString_orig_mptw = Date.prototype.formatString;
Date.prototype.formatString = function(template) {
  return this.formatString_orig_mptw(template).replace(/pppp/,this.prettyDate());
}
// for MPTW. otherwise edit your ViewTemplate as required.
// config.mptwDateFormat = 'pppp (DD/MM/YY)';
config.mptwDateFormat = 'pppp';
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 19 | purifier | 2 | 1 | 0 | 0 | 0 | 60 | 0 | 0 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 12 | 16000 | pink | [[Glass Bottle]] | 0 | 1 | 0 | 1 | 0 | purifier | - |
|!Description|>|>|>|>|>|>|>|>|>|>| A rare stem-cell treatment, which causes mutations and other genetic defects to fade away. |
 
/***
|Name:|QuickOpenTagPlugin|
|Description:|Changes tag links to make it easier to open tags as tiddlers|
|Version:|3.0.1a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#QuickOpenTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
***/
//{{{
config.quickOpenTag = {
  dropdownChar: (document.all ? "\u25bc" : "\u25be"), // the little one doesn't work in IE?
  createTagButton: function(place,tag,excludeTiddler) {
    // little hack so we can do this: <<tag PrettyTagName|RealTagName>>
    var splitTag = tag.split("|");
    var pretty = tag;
    if (splitTag.length == 2) {
      tag = splitTag[1];
      pretty = splitTag[0];
    }
    var sp = createTiddlyElement(place,"span",null,"quickopentag");
    createTiddlyText(createTiddlyLink(sp,tag,false),pretty);
    var theTag = createTiddlyButton(sp,config.quickOpenTag.dropdownChar,
                        config.views.wikified.tag.tooltip.format([tag]),onClickTag);
    theTag.setAttribute("tag",tag);
    if (excludeTiddler)
      theTag.setAttribute("tiddler",excludeTiddler);
        return(theTag);
  },
  miniTagHandler: function(place,macroName,params,wikifier,paramString,tiddler) {
    var tagged = store.getTaggedTiddlers(tiddler.title);
    if (tagged.length > 0) {
      var theTag = createTiddlyButton(place,config.quickOpenTag.dropdownChar,
                          config.views.wikified.tag.tooltip.format([tiddler.title]),onClickTag);
      theTag.setAttribute("tag",tiddler.title);
      theTag.className = "miniTag";
    }
  },
  allTagsHandler: function(place,macroName,params) {
    var tags = store.getTags(params[0]);
    var filter = params[1]; // new feature
    var ul = createTiddlyElement(place,"ul");
    if(tags.length == 0)
      createTiddlyElement(ul,"li",null,"listTitle",this.noTags);
    for(var t=0; t<tags.length; t++) {
      var title = tags[t][0];
      if (!filter || (title.match(new RegExp('^'+filter)))) {
        var info = getTiddlyLinkInfo(title);
        var theListItem =createTiddlyElement(ul,"li");
        var theLink = createTiddlyLink(theListItem,tags[t][0],true);
        var theCount = " (" + tags[t][1] + ")";
        theLink.appendChild(document.createTextNode(theCount));
        var theDropDownBtn = createTiddlyButton(theListItem," " +
          config.quickOpenTag.dropdownChar,this.tooltip.format([tags[t][0]]),onClickTag);
        theDropDownBtn.setAttribute("tag",tags[t][0]);
      }
    }
  },
  // todo fix these up a bit
  styles: [
"/*{{{*/",
"/* created by QuickOpenTagPlugin */",
".tagglyTagged .quickopentag, .tagged .quickopentag ",
" { margin-right:1.2em; border:1px solid #eee; padding:2px; padding-right:0px; padding-left:1px; }",
".quickopentag .tiddlyLink { padding:2px; padding-left:3px; }",
".quickopentag a.button { padding:1px; padding-left:2px; padding-right:2px;}",
"/* extra specificity to make it work right */",
"#displayArea .viewer .quickopentag a.button, ",
"#displayArea .viewer .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink, ",
"#mainMenu .quickopentag a.tiddyLink ",
" { border:0px solid black; }",
"#displayArea .viewer .quickopentag a.button, ",
"#mainMenu .quickopentag a.button ",
" { margin-left:0px; padding-left:2px; }",
"#displayArea .viewer .quickopentag a.tiddlyLink, ",
"#mainMenu .quickopentag a.tiddlyLink ",
" { margin-right:0px; padding-right:0px; padding-left:0px; margin-left:0px; }",
"a.miniTag {font-size:150%;} ",
"#mainMenu .quickopentag a.button ",
" /* looks better in right justified main menus */",
" { margin-left:0px; padding-left:2px; margin-right:0px; padding-right:0px; }",
"#topMenu .quickopentag { padding:0px; margin:0px; border:0px; }",
"#topMenu .quickopentag .tiddlyLink { padding-right:1px; margin-right:0px; }",
"#topMenu .quickopentag .button { padding-left:1px; margin-left:0px; border:0px; }",
"/*}}}*/",
    ""].join("\n"),
  init: function() {
    // we fully replace these builtins. can't hijack them easily
    window.createTagButton = this.createTagButton;
    config.macros.allTags.handler = this.allTagsHandler;
    config.macros.miniTag = { handler: this.miniTagHandler };
    config.shadowTiddlers["QuickOpenTagStyles"] = this.styles;
    store.addNotification("QuickOpenTagStyles",refreshStyles);
  }
}
config.quickOpenTag.init();
//}}}
 
A recipe will not appear in your menu until your level in the primary skill * is at least equal to the difficulty.  At that point, your chance of success * is still not great; a good 25% improvement over the difficulty is important
 
/***
|Name:|RenameTagsPlugin|
|Description:|Allows you to easily rename or delete tags across multiple tiddlers|
|Version:|3.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#RenameTagsPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License|http://mptw.tiddlyspot.com/#TheBSDLicense|
Rename a tag and you will be prompted to rename it in all its tagged tiddlers.
***/
//{{{
config.renameTags = {
  prompts: {
    rename: "Rename the tag '%0' to '%1' in %2 tidder%3?",
    remove: "Remove the tag '%0' from %1 tidder%2?"
  },
  removeTag: function(tag,tiddlers) {
    store.suspendNotifications();
    for (var i=0;i<tiddlers.length;i++) {
      store.setTiddlerTag(tiddlers[i].title,false,tag);
    }
    store.resumeNotifications();
    store.notifyAll();
  },
  renameTag: function(oldTag,newTag,tiddlers) {
    store.suspendNotifications();
    for (var i=0;i<tiddlers.length;i++) {
      store.setTiddlerTag(tiddlers[i].title,false,oldTag); // remove old
      store.setTiddlerTag(tiddlers[i].title,true,newTag);  // add new
    }
    store.resumeNotifications();
    store.notifyAll();
  },
  storeMethods: {
    saveTiddler_orig_renameTags: TiddlyWiki.prototype.saveTiddler,
    saveTiddler: function(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created,creator) {
      if (title != newTitle) {
        var tagged = this.getTaggedTiddlers(title);
        if (tagged.length > 0) {
          // then we are renaming a tag
          if (confirm(config.renameTags.prompts.rename.format([title,newTitle,tagged.length,tagged.length>1?"s":""])))
            config.renameTags.renameTag(title,newTitle,tagged);
          if (!this.tiddlerExists(title) && newBody == "")
            // dont create unwanted tiddler
            return null;
        }
      }
      return this.saveTiddler_orig_renameTags(title,newTitle,newBody,modifier,modified,tags,fields,clearChangeCount,created,creator);
    },
    removeTiddler_orig_renameTags: TiddlyWiki.prototype.removeTiddler,
    removeTiddler: function(title) {
      var tagged = this.getTaggedTiddlers(title);
      if (tagged.length > 0)
        if (confirm(config.renameTags.prompts.remove.format([title,tagged.length,tagged.length>1?"s":""])))
          config.renameTags.removeTag(title,tagged);
      return this.removeTiddler_orig_renameTags(title);
    }
  },
  init: function() {
    merge(TiddlyWiki.prototype,this.storeMethods);
  }
}
config.renameTags.init();
//}}}
 
[[Muffler]]
[[Pipe]]
[[Motor]]
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 8 | Root Beer | 2 | 1 | 0 | 0 | 0 | 60 | 18 | 3 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 65 | 30 | brown | [[Drinks Can]] | 1 | -1 | 0 | 1 | 3 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Like cola, but without caffeine.  Still not that healthy. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 13 | Rum | 2 | 1 | 0 | 0 | 0 | 60 | -12 | 2 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 14 | 85 | ltcyan | [[Glass Bottle]] | -10 | -2 | 5 | 20 | 30 | alcohol | [[ADD_ALCOHOL|Alcohol]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Drinking this might make you feel like a pirate.  Or not. |
 
| Number |!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
| 4 | Water | 2 | 1 | 0 | 0 | 0 | 60 | 0 | -30 | 0 |
|!Rarity|!Price|!Color|!Container|!Spoil Speed| !Stimulation |!Healthy|!Addiction Level|!Charges|!Use|!Addiction Type|
| 0 | 50 | Cyan | [[Plastic Bottle]] | 0 | 0 | -4 | 0 | 1 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Water, the Stuff of Life, the best thirst-quencher available. |
 
/***
|Name:|SaveCloseTiddlerPlugin|
|Description:|Provides two extra toolbar commands, saveCloseTiddler and cancelCloseTiddler|
|Version:|3.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#SaveCloseTiddlerPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
To use these add them to the commands in ToolbarCommands under EditToolbar,
or in the MptwTheme tiddler under EditTemplate.
***/
//{{{
merge(config.commands,{
  saveCloseTiddler: {
    text: 'done/close',
    tooltip: 'Save changes to this tiddler and close it',
    handler: function(ev,src,title) {
      var closeTitle = title;
      var newTitle = story.saveTiddler(title,ev.shiftKey);
      if (newTitle)
        closeTitle = newTitle;
      return config.commands.closeTiddler.handler(ev,src,closeTitle);
    }
  },
  cancelCloseTiddler: {
    text: 'cancel/close',
    tooltip: 'Undo changes to this tiddler and close it',
    handler: function(ev,src,title) {
      // the same as closeTiddler now actually
      return config.commands.closeTiddler.handler(ev,src,title);
    }
  }
});
//}}}
 
/***
|Name:|SelectThemePlugin|
|Description:|Lets you easily switch theme and palette|
|Version:|1.0.1a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#SelectThemePlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
* Borrows largely from ThemeSwitcherPlugin by Martin Budden http://www.martinswiki.com/#ThemeSwitcherPlugin
* Theme is cookie based. But set a default by setting config.options.txtTheme in MptwConfigPlugin (for example)
* Palette is not cookie based. It actually overwrites your ColorPalette tiddler when you select a palette, so beware.
!Usage
* {{{<<selectTheme>>}}} makes a dropdown selector
* {{{<<selectPalette>>}}} makes a dropdown selector
* {{{<<applyTheme>>}}} applies the current tiddler as a theme
* {{{<<applyPalette>>}}} applies the current tiddler as a palette
* {{{<<applyTheme TiddlerName>>}}} applies TiddlerName as a theme
* {{{<<applyPalette TiddlerName>>}}} applies TiddlerName as a palette
***/
//{{{
config.macros.selectTheme = {
  label: {
    selectTheme:"select theme",
    selectPalette:"select palette"
  },
  prompt: {
    selectTheme:"Select the current theme",
    selectPalette:"Select the current palette"
  },
  tags: {
    selectTheme:'systemTheme',
    selectPalette:'systemPalette'
  }
};
config.macros.selectTheme.handler = function(place,macroName)
{
  var btn = createTiddlyButton(place,this.label[macroName],this.prompt[macroName],this.onClick);
  // want to handle palettes and themes with same code. use mode attribute to distinguish
  btn.setAttribute('mode',macroName);
};
config.macros.selectTheme.onClick = function(ev)
{
  var e = ev ? ev : window.event;
  var popup = Popup.create(this);
  var mode = this.getAttribute('mode');
  var tiddlers = store.getTaggedTiddlers(config.macros.selectTheme.tags[mode]);
  // for default
  if (mode == "selectPalette") {
    var btn = createTiddlyButton(createTiddlyElement(popup,'li'),"(default)","default color palette",config.macros.selectTheme.onClickTheme);
    btn.setAttribute('theme',"(default)");
    btn.setAttribute('mode',mode);
  }
  for(var i=0; i<tiddlers.length; i++) {
    var t = tiddlers[i].title;
    var name = store.getTiddlerSlice(t,'Name');
    var desc = store.getTiddlerSlice(t,'Description');
    var btn = createTiddlyButton(createTiddlyElement(popup,'li'), name?name:t, desc?desc:config.macros.selectTheme.label['mode'], config.macros.selectTheme.onClickTheme);
    btn.setAttribute('theme',t);
    btn.setAttribute('mode',mode);
  }
  Popup.show();
  return stopEvent(e);
};
config.macros.selectTheme.onClickTheme = function(ev)
{
  var mode = this.getAttribute('mode');
  var theme = this.getAttribute('theme');
  if (mode == 'selectTheme')
    story.switchTheme(theme);
  else // selectPalette
    config.macros.selectTheme.updatePalette(theme);
  return false;
};
config.macros.selectTheme.updatePalette = function(title)
{
  if (title != "") {
    store.deleteTiddler("ColorPalette");
    if (title != "(default)")
      store.saveTiddler("ColorPalette","ColorPalette",store.getTiddlerText(title),
          config.options.txtUserName,undefined,"");
    refreshAll();
    if(config.options.chkAutoSave)
      saveChanges(true);
  }
};
config.macros.applyTheme = {
  label: "apply",
  prompt: "apply this theme or palette" // i'm lazy
};
config.macros.applyTheme.handler = function(place,macroName,params,wikifier,paramString,tiddler) {
  var useTiddler = params[0] ? params[0] : tiddler.title;
  var btn = createTiddlyButton(place,this.label,this.prompt,config.macros.selectTheme.onClickTheme);
  btn.setAttribute('theme',useTiddler);
  btn.setAttribute('mode',macroName=="applyTheme"?"selectTheme":"selectPalette"); // a bit untidy here
}
config.macros.selectPalette = config.macros.selectTheme;
config.macros.applyPalette = config.macros.applyTheme;
config.macros.refreshAll = { handler: function(place,macroName,params,wikifier,paramString,tiddler) {
  createTiddlyButton(place,"refresh","refresh layout and styles",function() { refreshAll(); });
}};
//}}}
 
A ~Zombie-Survival Roguelike  
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 298 | Steel Crossbow Bolt  | 1 | 0.9 | 1 | 0 | 0 | 69 |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 8 | 500 | [[Bolts|AT_BOLT]] | green | [[WOOD|Material_Wood]] | 20 | 3 | 10 | 88 | 0 | 15 |
|!Description|>|>|>|>|>|>|>|>|>|>| A sharp bolt made from steel.  Deadly in skilled hands. Stands a good chance of remaining intact once fired. |
 
/***
|Name:|TagglyTaggingPlugin|
|Description:|tagglyTagging macro is a replacement for the builtin tagging macro in your ViewTemplate|
|Version:|3.3.2a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#TagglyTaggingPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!Notes
See http://mptw.tiddlyspot.com/#TagglyTagging
***/
//{{{
merge(String.prototype,{
  parseTagExpr: function(debug) {
    if (this.trim() == "")
      return "(true)";
    var anyLogicOp = /(!|&&|\|\||\(|\))/g;
    var singleLogicOp = /^(!|&&|\|\||\(|\))$/;
    var spaced = this.
      // because square brackets in templates are no good
      // this means you can use [(With Spaces)] instead of [[With Spaces]]
      replace(/\[\(/g," [[").
      replace(/\)\]/g,"]] ").
      // space things out so we can use readBracketedList. tricky eh?
      replace(anyLogicOp," $1 ");
    var expr = "";
    var tokens = spaced.readBracketedList(false); // false means don't uniq the list. nice one JR!
    for (var i=0;i<tokens.length;i++)
      if (tokens[i].match(singleLogicOp))
        expr += tokens[i];
      else
        expr += "tiddler.tags.contains('%0')".format([tokens[i].replace(/'/,"\\'")]); // fix single quote bug. still have round bracket bug i think
    if (debug)
      alert(expr);
    return '('+expr+')';
  }
});
merge(TiddlyWiki.prototype,{
  getTiddlersByTagExpr: function(tagExpr,sortField) {
    var result = [];
    var expr = tagExpr.parseTagExpr();
    store.forEachTiddler(function(title,tiddler) {
      if (eval(expr))
        result.push(tiddler);
    });
    if(!sortField)
      sortField = "title";
    result.sort(function(a,b) {return a[sortField] < b[sortField] ? -1 : (a[sortField] == b[sortField] ? 0 : +1);});
    return result;
  }
});
config.taggly = {
  // for translations
  lingo: {
    labels: {
      asc:        "\u2191", // down arrow
      desc:       "\u2193", // up arrow
      title:      "title",
      modified:   "modified",
      created:    "created",
      show:       "+",
      hide:       "-",
      normal:     "normal",
      group:      "group",
      commas:     "commas",
      sitemap:    "sitemap",
      numCols:    "cols\u00b1", // plus minus sign
      label:      "Tagged as '%0':",
      exprLabel:  "Matching tag expression '%0':",
      excerpts:   "excerpts",
      descr:      "descr",
      slices:     "slices",
      contents:   "contents",
      sliders:    "sliders",
      noexcerpts: "title only",
      noneFound:  "(none)"
    },
    tooltips: {
      title:      "Click to sort by title",
      modified:   "Click to sort by modified date",
      created:    "Click to sort by created date",
      show:       "Click to show tagging list",
      hide:       "Click to hide tagging list",
      normal:     "Click to show a normal ungrouped list",
      group:      "Click to show list grouped by tag",
      sitemap:    "Click to show a sitemap style list",
      commas:     "Click to show a comma separated list",
      numCols:    "Click to change number of columns",
      excerpts:   "Click to show excerpts",
      descr:      "Click to show the description slice",
      slices:     "Click to show all slices",
      contents:   "Click to show entire tiddler contents",
      sliders:    "Click to show tiddler contents in sliders",
      noexcerpts: "Click to show entire title only"
    },
    tooDeepMessage: "* //sitemap too deep...//"
  },
  config: {
    showTaggingCounts: true,
    listOpts: {
      // the first one will be the default
      sortBy:     ["title","modified","created"],
      sortOrder:  ["asc","desc"],
      hideState:  ["show","hide"],
      listMode:   ["normal","group","sitemap","commas"],
      numCols:    ["1","2","3","4","5","6"],
      excerpts:   ["noexcerpts","excerpts","descr","slices","contents","sliders"]
    },
    valuePrefix: "taggly.",
    excludeTags: ["excludeLists","excludeTagging"],
    excerptSize: 50,
    excerptMarker: "/%"+"%/",
    siteMapDepthLimit: 25
  },
  getTagglyOpt: function(title,opt) {
    var val = store.getValue(title,this.config.valuePrefix+opt);
    return val ? val : this.config.listOpts[opt][0];
  },
  setTagglyOpt: function(title,opt,value) {
    // create it silently if it doesn't exist
    if (!store.tiddlerExists(title)) {
      store.saveTiddler(title,title,config.views.editor.defaultText.format([title]),config.options.txtUserName,new Date(),"");
      // <<tagglyTagging expr:"...">> creates a tiddler to store its display settings
      // Make those tiddlers less noticeable by tagging as excludeSearch and excludeLists
      // Because we don't want to hide real tags, check that they aren't actually tags before doing so
      // Also tag them as tagglyExpression for manageability
      // (contributed by RA)
      if (!store.getTaggedTiddlers(title).length) {
        store.setTiddlerTag(title,true,"excludeSearch");
        store.setTiddlerTag(title,true,"excludeLists");
        store.setTiddlerTag(title,true,"tagglyExpression");
      }
    }
    // if value is default then remove it to save space
    return store.setValue(title, this.config.valuePrefix+opt, value == this.config.listOpts[opt][0] ? null : value);
  },
  getNextValue: function(title,opt) {
    var current = this.getTagglyOpt(title,opt);
    var pos = this.config.listOpts[opt].indexOf(current);
    // supposed to automagically don't let cols cycle up past the number of items
    // currently broken in some situations, eg when using an expression
    // lets fix it later when we rewrite for jquery
    // the columns thing should be jquery table manipulation probably
    var limit = (opt == "numCols" ? store.getTaggedTiddlers(title).length : this.config.listOpts[opt].length);
    var newPos = (pos + 1) % limit;
    return this.config.listOpts[opt][newPos];
  },
  toggleTagglyOpt: function(title,opt) {
    var newVal = this.getNextValue(title,opt);
    this.setTagglyOpt(title,opt,newVal);
  },
  createListControl: function(place,title,type) {
    var lingo = config.taggly.lingo;
    var label;
    var tooltip;
    var onclick;
    if ((type == "title" || type == "modified" || type == "created")) {
      // "special" controls. a little tricky. derived from sortOrder and sortBy
      label = lingo.labels[type];
      tooltip = lingo.tooltips[type];
      if (this.getTagglyOpt(title,"sortBy") == type) {
        label += lingo.labels[this.getTagglyOpt(title,"sortOrder")];
        onclick = function() {
          config.taggly.toggleTagglyOpt(title,"sortOrder");
          return false;
        }
      }
      else {
        onclick = function() {
          config.taggly.setTagglyOpt(title,"sortBy",type);
          config.taggly.setTagglyOpt(title,"sortOrder",config.taggly.config.listOpts.sortOrder[0]);
          return false;
        }
      }
    }
    else {
      // "regular" controls, nice and simple
      label = lingo.labels[type == "numCols" ? type : this.getNextValue(title,type)];
      tooltip = lingo.tooltips[type == "numCols" ? type : this.getNextValue(title,type)];
      onclick = function() {
        config.taggly.toggleTagglyOpt(title,type);
        return false;
      }
    }
    // hide button because commas don't have columns
    if (!(this.getTagglyOpt(title,"listMode") == "commas" && type == "numCols"))
      createTiddlyButton(place,label,tooltip,onclick,type == "hideState" ? "hidebutton" : "button");
  },
  makeColumns: function(orig,numCols) {
    var listSize = orig.length;
    var colSize = listSize/numCols;
    var remainder = listSize % numCols;
    var upperColsize = colSize;
    var lowerColsize = colSize;
    if (colSize != Math.floor(colSize)) {
      // it's not an exact fit so..
      upperColsize = Math.floor(colSize) + 1;
      lowerColsize = Math.floor(colSize);
    }
    var output = [];
    var c = 0;
    for (var j=0;j<numCols;j++) {
      var singleCol = [];
      var thisSize = j < remainder ? upperColsize : lowerColsize;
      for (var i=0;i<thisSize;i++)
        singleCol.push(orig[c++]);
      output.push(singleCol);
    }
    return output;
  },
  drawTable: function(place,columns,theClass) {
    var newTable = createTiddlyElement(place,"table",null,theClass);
    var newTbody = createTiddlyElement(newTable,"tbody");
    var newTr = createTiddlyElement(newTbody,"tr");
    for (var j=0;j<columns.length;j++) {
      var colOutput = "";
      for (var i=0;i<columns[j].length;i++)
        colOutput += columns[j][i];
      var newTd = createTiddlyElement(newTr,"td",null,"tagglyTagging"); // todo should not need this class
      wikify(colOutput,newTd);
    }
    return newTable;
  },
  createTagglyList: function(place,title,isTagExpr) {
    switch(this.getTagglyOpt(title,"listMode")) {
      case "group":  return this.createTagglyListGrouped(place,title,isTagExpr); break;
      case "normal": return this.createTagglyListNormal(place,title,false,isTagExpr); break;
      case "commas": return this.createTagglyListNormal(place,title,true,isTagExpr); break;
      case "sitemap":return this.createTagglyListSiteMap(place,title,isTagExpr); break;
    }
  },
  getTaggingCount: function(title,isTagExpr) {
    // thanks to Doug Edmunds
    if (this.config.showTaggingCounts) {
      var tagCount = config.taggly.getTiddlers(title,'title',isTagExpr).length;
      if (tagCount > 0)
        return " ("+tagCount+")";
    }
    return "";
  },
  getTiddlers: function(titleOrExpr,sortBy,isTagExpr) {
    return isTagExpr ? store.getTiddlersByTagExpr(titleOrExpr,sortBy) : store.getTaggedTiddlers(titleOrExpr,sortBy);
  },
  getExcerpt: function(inTiddlerTitle,title,indent) {
    if (!indent)
      indent = 1;
    var displayMode = this.getTagglyOpt(inTiddlerTitle,"excerpts");
    var t = store.getTiddler(title);
    if (t && displayMode == "excerpts") {
      var text = t.text.replace(/\n/," ");
      var marker = text.indexOf(this.config.excerptMarker);
      if (marker != -1) {
        return " {{excerpt{<nowiki>" + text.substr(0,marker) + "</nowiki>}}}";
      }
      else if (text.length < this.config.excerptSize) {
        return " {{excerpt{<nowiki>" + t.text + "</nowiki>}}}";
      }
      else {
        return " {{excerpt{<nowiki>" + t.text.substr(0,this.config.excerptSize) + "..." + "</nowiki>}}}";
      }
    }
    else if (t && displayMode == "contents") {
      return "\n{{contents indent"+indent+"{\n" + t.text + "\n}}}";
    }
    else if (t && displayMode == "sliders") {
      return "<slider slide>\n{{contents{\n" + t.text + "\n}}}\n</slider>";
    }
    else if (t && displayMode == "descr") {
      var descr = store.getTiddlerSlice(title,'Description');
      return descr ? " {{excerpt{" + descr  + "}}}" : "";
    }
    else if (t && displayMode == "slices") {
      var result = "";
      var slices = store.calcAllSlices(title);
      for (var s in slices)
        result += "|%0|<nowiki>%1</nowiki>|\n".format([s,slices[s]]);
      return result ? "\n{{excerpt excerptIndent{\n" + result  + "}}}" : "";
    }
    return "";
  },
  notHidden: function(t,inTiddler) {
    if (typeof t == "string")
      t = store.getTiddler(t);
    return (!t || !t.tags.containsAny(this.config.excludeTags) ||
        (inTiddler && this.config.excludeTags.contains(inTiddler)));
  },
  // this is for normal and commas mode
  createTagglyListNormal: function(place,title,useCommas,isTagExpr) {
    var list = config.taggly.getTiddlers(title,this.getTagglyOpt(title,"sortBy"),isTagExpr);
    if (this.getTagglyOpt(title,"sortOrder") == "desc")
      list = list.reverse();
    var output = [];
    var first = true;
    for (var i=0;i<list.length;i++) {
      if (this.notHidden(list[i],title)) {
        var countString = this.getTaggingCount(list[i].title);
        var excerpt = this.getExcerpt(title,list[i].title);
        if (useCommas)
          output.push((first ? "" : ", ") + "[[" + list[i].title + "]]" + countString + excerpt);
        else
          output.push("*[[" + list[i].title + "]]" + countString + excerpt + "\n");
        first = false;
      }
    }
    return this.drawTable(place,
      this.makeColumns(output,useCommas ? 1 : parseInt(this.getTagglyOpt(title,"numCols"))),
      useCommas ? "commas" : "normal");
  },
  // this is for the "grouped" mode
  createTagglyListGrouped: function(place,title,isTagExpr) {
    var sortBy = this.getTagglyOpt(title,"sortBy");
    var sortOrder = this.getTagglyOpt(title,"sortOrder");
    var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);
    if (sortOrder == "desc")
      list = list.reverse();
    var leftOvers = []
    for (var i=0;i<list.length;i++)
      leftOvers.push(list[i].title);
    var allTagsHolder = {};
    for (var i=0;i<list.length;i++) {
      for (var j=0;j<list[i].tags.length;j++) {
        if (list[i].tags[j] != title) { // not this tiddler
          if (this.notHidden(list[i].tags[j],title)) {
            if (!allTagsHolder[list[i].tags[j]])
              allTagsHolder[list[i].tags[j]] = "";
            if (this.notHidden(list[i],title)) {
              allTagsHolder[list[i].tags[j]] += "**[["+list[i].title+"]]"
                    + this.getTaggingCount(list[i].title) + this.getExcerpt(title,list[i].title) + "\n";
              leftOvers.setItem(list[i].title,-1); // remove from leftovers. at the end it will contain the leftovers
            }
          }
        }
      }
    }
    var allTags = [];
    for (var t in allTagsHolder)
      allTags.push(t);
    var sortHelper = function(a,b) {
      if (a == b) return 0;
      if (a < b) return -1;
      return 1;
    };
    allTags.sort(function(a,b) {
      var tidA = store.getTiddler(a);
      var tidB = store.getTiddler(b);
      if (sortBy == "title") return sortHelper(a,b);
      else if (!tidA && !tidB) return 0;
      else if (!tidA) return -1;
      else if (!tidB) return +1;
      else return sortHelper(tidA[sortBy],tidB[sortBy]);
    });
    var leftOverOutput = "";
    for (var i=0;i<leftOvers.length;i++)
      if (this.notHidden(leftOvers[i],title))
        leftOverOutput += "*[["+leftOvers[i]+"]]" + this.getTaggingCount(leftOvers[i]) + this.getExcerpt(title,leftOvers[i]) + "\n";
    var output = [];
    if (sortOrder == "desc")
      allTags.reverse();
    else if (leftOverOutput != "")
      // leftovers first...
      output.push(leftOverOutput);
    for (var i=0;i<allTags.length;i++)
      if (allTagsHolder[allTags[i]] != "")
        output.push("*[["+allTags[i]+"]]" + this.getTaggingCount(allTags[i]) + this.getExcerpt(title,allTags[i]) + "\n" + allTagsHolder[allTags[i]]);
    if (sortOrder == "desc" && leftOverOutput != "")
      // leftovers last...
      output.push(leftOverOutput);
    return this.drawTable(place,
        this.makeColumns(output,parseInt(this.getTagglyOpt(title,"numCols"))),
        "grouped");
  },
  // used to build site map
  treeTraverse: function(title,depth,sortBy,sortOrder,isTagExpr) {
    var list = config.taggly.getTiddlers(title,sortBy,isTagExpr);
    if (sortOrder == "desc")
      list.reverse();
    var indent = "";
    for (var j=0;j<depth;j++)
      indent += "*"
    var childOutput = "";
    if (depth > this.config.siteMapDepthLimit)
      childOutput += indent + this.lingo.tooDeepMessage + "\n";
    else
      for (var i=0;i<list.length;i++)
        if (list[i].title != title)
          if (this.notHidden(list[i].title,this.config.inTiddler))
            childOutput += this.treeTraverse(list[i].title,depth+1,sortBy,sortOrder,false);
    if (depth == 0)
      return childOutput;
    else
      return indent + "[["+title+"]]" + this.getTaggingCount(title) + this.getExcerpt(this.config.inTiddler,title,depth) + "\n" + childOutput;
  },
  // this if for the site map mode
  createTagglyListSiteMap: function(place,title,isTagExpr) {
    this.config.inTiddler = title; // nasty. should pass it in to traverse probably
    var output = this.treeTraverse(title,0,this.getTagglyOpt(title,"sortBy"),this.getTagglyOpt(title,"sortOrder"),isTagExpr);
    return this.drawTable(place,
        this.makeColumns(output.split(/(?=^\*\[)/m),parseInt(this.getTagglyOpt(title,"numCols"))), // regexp magic
        "sitemap"
        );
  },
  macros: {
    tagglyTagging: {
      handler: function (place,macroName,params,wikifier,paramString,tiddler) {
        var parsedParams = paramString.parseParams("tag",null,true);
        var refreshContainer = createTiddlyElement(place,"div");
        // do some refresh magic to make it keep the list fresh - thanks Saq
        refreshContainer.setAttribute("refresh","macro");
        refreshContainer.setAttribute("macroName",macroName);
        var tag = getParam(parsedParams,"tag");
        var expr = getParam(parsedParams,"expr");
        if (expr) {
          refreshContainer.setAttribute("isTagExpr","true");
          refreshContainer.setAttribute("title",expr);
          refreshContainer.setAttribute("showEmpty","true");
        }
        else {
          refreshContainer.setAttribute("isTagExpr","false");
          if (tag) {
                refreshContainer.setAttribute("title",tag);
            refreshContainer.setAttribute("showEmpty","true");
          }
          else {
                refreshContainer.setAttribute("title",tiddler.title);
            refreshContainer.setAttribute("showEmpty","false");
          }
        }
        this.refresh(refreshContainer);
      },
      refresh: function(place) {
        var title = place.getAttribute("title");
        var isTagExpr = place.getAttribute("isTagExpr") == "true";
        var showEmpty = place.getAttribute("showEmpty") == "true";
        jQuery(place).empty()
        addClass(place,"tagglyTagging");
        var countFound = config.taggly.getTiddlers(title,'title',isTagExpr).length
        if (countFound > 0 || showEmpty) {
          var lingo = config.taggly.lingo;
          config.taggly.createListControl(place,title,"hideState");
          if (config.taggly.getTagglyOpt(title,"hideState") == "show") {
            createTiddlyElement(place,"span",null,"tagglyLabel",
                isTagExpr ? lingo.labels.exprLabel.format([title]) : lingo.labels.label.format([title]));
            config.taggly.createListControl(place,title,"title");
            config.taggly.createListControl(place,title,"modified");
            config.taggly.createListControl(place,title,"created");
            config.taggly.createListControl(place,title,"listMode");
            config.taggly.createListControl(place,title,"excerpts");
            config.taggly.createListControl(place,title,"numCols");
            config.taggly.createTagglyList(place,title,isTagExpr);
            if (countFound == 0 && showEmpty)
              createTiddlyElement(place,"div",null,"tagglyNoneFound",lingo.labels.noneFound);
          }
        }
      }
    }
  },
  // todo fix these up a bit
  styles: [
"/*{{{*/",
"/* created by TagglyTaggingPlugin */",
".tagglyTagging { padding-top:0.5em; }",
".tagglyTagging li.listTitle { display:none; }",
".tagglyTagging ul {",
" margin-top:0px; padding-top:0.5em; padding-left:2em;",
" margin-bottom:0px; padding-bottom:0px;",
"}",
".tagglyTagging { vertical-align: top; margin:0px; padding:0px; }",
".tagglyTagging table { margin:0px; padding:0px; }",
".tagglyTagging .button { visibility:hidden; margin-left:3px; margin-right:3px; }",
".tagglyTagging .button, .tagglyTagging .hidebutton {",
" color:[[ColorPalette::TertiaryLight]]; font-size:90%;",
" border:0px; padding-left:0.3em;padding-right:0.3em;",
"}",
".tagglyTagging .button:hover, .hidebutton:hover, ",
".tagglyTagging .button:active, .hidebutton:active  {",
" border:0px; background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]];",
"}",
".selected .tagglyTagging .button { visibility:visible; }",
".tagglyTagging .hidebutton { color:[[ColorPalette::Background]]; }",
".selected .tagglyTagging .hidebutton { color:[[ColorPalette::TertiaryLight]] }",
".tagglyLabel { color:[[ColorPalette::TertiaryMid]]; font-size:90%; }",
".tagglyTagging ul {padding-top:0px; padding-bottom:0.5em; margin-left:1em; }",
".tagglyTagging ul ul {list-style-type:disc; margin-left:-1em;}",
".tagglyTagging ul ul li {margin-left:0.5em; }",
".editLabel { font-size:90%; padding-top:0.5em; }",
".tagglyTagging .commas { padding-left:1.8em; }",
"/* not technically tagglytagging but will put them here anyway */",
".tagglyTagged li.listTitle { display:none; }",
".tagglyTagged li { display: inline; font-size:90%; }",
".tagglyTagged ul { margin:0px; padding:0px; }",
".excerpt { color:[[ColorPalette::TertiaryDark]]; }",
".excerptIndent { margin-left:4em; }",
"div.tagglyTagging table,",
"div.tagglyTagging table tr,",
"td.tagglyTagging",
" {border-style:none!important; }",
".tagglyTagging .contents { border-bottom:2px solid [[ColorPalette::TertiaryPale]]; padding:0 1em 1em 0.5em;",
"  margin-bottom:0.5em; }",
".tagglyTagging .indent1  { margin-left:3em;  }",
".tagglyTagging .indent2  { margin-left:4em;  }",
".tagglyTagging .indent3  { margin-left:5em;  }",
".tagglyTagging .indent4  { margin-left:6em;  }",
".tagglyTagging .indent5  { margin-left:7em;  }",
".tagglyTagging .indent6  { margin-left:8em;  }",
".tagglyTagging .indent7  { margin-left:9em;  }",
".tagglyTagging .indent8  { margin-left:10em; }",
".tagglyTagging .indent9  { margin-left:11em; }",
".tagglyTagging .indent10 { margin-left:12em; }",
".tagglyNoneFound { margin-left:2em; color:[[ColorPalette::TertiaryMid]]; font-size:90%; font-style:italic; }",
"/*}}}*/",
    ""].join("\n"),
  init: function() {
    merge(config.macros,this.macros);
    config.shadowTiddlers["TagglyTaggingStyles"] = this.styles;
    store.addNotification("TagglyTaggingStyles",refreshStyles);
  }
};
config.taggly.init();
//}}}
/***
InlineSlidersPlugin
By Saq Imtiaz
http://tw.lewcid.org/sandbox/#InlineSlidersPlugin
// syntax adjusted to not clash with NestedSlidersPlugin
// added + syntax to start open instead of closed
***/
//{{{
config.formatters.unshift( {
  name: "inlinesliders",
  // match: "\\+\\+\\+\\+|\\<slider",
  match: "\\<slider",
  // lookaheadRegExp: /(?:\+\+\+\+|<slider) (.*?)(?:>?)\n((?:.|\n)*?)\n(?:====|<\/slider>)/mg,
  lookaheadRegExp: /(?:<slider)(\+?) (.*?)(?:>)\n((?:.|\n)*?)\n(?:<\/slider>)/mg,
  handler: function(w) {
    this.lookaheadRegExp.lastIndex = w.matchStart;
    var lookaheadMatch = this.lookaheadRegExp.exec(w.source)
    if(lookaheadMatch && lookaheadMatch.index == w.matchStart ) {
      var btn = createTiddlyButton(w.output,lookaheadMatch[2] + " "+"\u00BB",lookaheadMatch[2],this.onClickSlider,"button sliderButton");
      var panel = createTiddlyElement(w.output,"div",null,"sliderPanel");
      panel.style.display = (lookaheadMatch[1] == '+' ? "block" : "none");
      wikify(lookaheadMatch[3],panel);
      w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
    }
   },
   onClickSlider : function(e) {
    if(!e) var e = window.event;
    var n = this.nextSibling;
    n.style.display = (n.style.display=="none") ? "block" : "none";
    return false;
  }
});
//}}}
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|!|h
| 22 | tainted Meat | 1 | 2 | 0 | 0 | 0 | 58 | 0 | 20 | 4 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Material]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 60 | 4 | red | [[FLESH|Material_Flesh]] | - | 0 | 0 | 0 | 1 | -10 | poison | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Meat that's obviously unhealthy.  You could eat it, but it will poison you. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|!|h
| 23 | tainted veggy | 1 | 2 | 0 | 0 | 0 | 58 | 0 | 20 | 10 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Material]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 35 | 5 | green | [[VEGGY|Material_Veggy]] | - | 0 | 0 | 0 | 1 | 0 | poison | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Vegetable that looks poisonous.  You could eat it, but it will poison you. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 14 | Tequila | 2 | 1 | 0 | 0 | 0 | 60 | -12 | 2 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 12 | 88 | brown | [[Glass Bottle]] | -12 | -2 | 6 | 20 | 35 | alcohol | [[ADD_ALCOHOL|Alcohol]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Don't eat the worm!  Wait, there's no worm in this bottle. |
 
/***
|Name:|ToggleTagPlugin|
|Description:|Makes a checkbox which toggles a tag in a tiddler|
|Version:|3.1.0a|
|Date:|27-Jun-2011|
|Source:|http://mptw.tiddlyspot.com/#ToggleTagPlugin|
|Author:|Simon Baird <simon.baird@gmail.com>|
|License:|http://mptw.tiddlyspot.com/#TheBSDLicense|
!!Usage
{{{<<toggleTag }}}//{{{TagName TiddlerName LabelText}}}//{{{>>}}}
* TagName - the tag to be toggled, default value "checked"
* TiddlerName - the tiddler to toggle the tag in, default value the current tiddler
* LabelText - the text (gets wikified) to put next to the check box, default value is '{{{[[TagName]]}}}' or '{{{[[TagName]] [[TiddlerName]]}}}'
(If a parameter is '.' then the default will be used)
* TouchMod flag - if non empty then touch the tiddlers mod date. Note, can set config.toggleTagAlwaysTouchModDate to always touch mod date
!!Examples
|Code|Description|Example|h
|{{{<<toggleTag>>}}}|Toggles the default tag (checked) in this tiddler|<<toggleTag>>|
|{{{<<toggleTag TagName>>}}}|Toggles the TagName tag in this tiddler|<<toggleTag TagName>>|
|{{{<<toggleTag TagName TiddlerName>>}}}|Toggles the TagName tag in the TiddlerName tiddler|<<toggleTag TagName TiddlerName>>|
|{{{<<toggleTag TagName TiddlerName 'click me'>>}}}|Same but with custom label|<<toggleTag TagName TiddlerName 'click me'>>|
|{{{<<toggleTag . . 'click me'>>}}}|dot means use default value|<<toggleTag . . 'click me'>>|
!!Notes
* If TiddlerName doesn't exist it will be silently created
* Set label to '-' to specify no label
* See also http://mgtd-alpha.tiddlyspot.com/#ToggleTag2
!!Known issues
* Doesn't smoothly handle the case where you toggle a tag in a tiddler that is current open for editing
* Should convert to use named params
***/
//{{{
if (config.toggleTagAlwaysTouchModDate == undefined) config.toggleTagAlwaysTouchModDate = false;
merge(config.macros,{
  toggleTag: {
    createIfRequired: true,
    shortLabel: "[[%0]]",
    longLabel: "[[%0]] [[%1]]",
    handler: function(place,macroName,params,wikifier,paramString,tiddler) {
      var tiddlerTitle = tiddler ? tiddler.title : '';
      var tag   = (params[0] && params[0] != '.') ? params[0] : "checked";
      var title = (params[1] && params[1] != '.') ? params[1] : tiddlerTitle;
      var defaultLabel = (title == tiddlerTitle ? this.shortLabel : this.longLabel);
      var label = (params[2] && params[2] != '.') ? params[2] : defaultLabel;
      var touchMod = (params[3] && params[3] != '.') ? params[3] : "";
      label = (label == '-' ? '' : label); // dash means no label
      var theTiddler = (title == tiddlerTitle ? tiddler : store.getTiddler(title));
      var cb = createTiddlyCheckbox(place, label.format([tag,title]), theTiddler && theTiddler.isTagged(tag), function(e) {
        if (!store.tiddlerExists(title)) {
          if (config.macros.toggleTag.createIfRequired) {
            var content = store.getTiddlerText(title); // just in case it's a shadow
            store.saveTiddler(title,title,content?content:"",config.options.txtUserName,new Date(),null);
          }
          else
            return false;
        }
        if ((touchMod != "" || config.toggleTagAlwaysTouchModDate) && theTiddler)
            theTiddler.modified = new Date();
        store.setTiddlerTag(title,this.checked,tag);
        return true;
      });
    }
  }
});
//}}}
 
[[Positive Traits]]
[[Negative Traits]]
[[]]
[[NULL Trait]]
[[Fleet Footed]]
[[Parkour Expert]]
[[Quick]]
[[Optimist]]
[[Fast Healer]]
[[Light Eater]]
[[Pain Resistant]]
[[Night Vision]]
[[Poison Resistant]]
[[Fast Reader]]
[[Tough]]
[[Thick-Skinned]]
[[Packmule]]
[[Fast Learner]]
[[Deft]]
[[Drunken Master]]
[[Gourmand]]
[[Animal Empathy]]
[[Terrifying]]
[[Disease Resistant]]
[[High Adrenaline]]
[[Inconspicuous]]
[[Masochist]]
[[Light Step]]
[[Heartless]]
[[Android]]
[[Robust Genetics]]
[[Martial Arts Training]]
[[]]
[[NULL]]
[[Near Sighted]]
[[Heavy Sleeper]]
[[Asthmatic]]
[[Bad Baxk]]
[[Illiterate]]
[[Poor Hearing]]
[[Insomniac]]
[[Vegetarian]]
[[Glass Jaw]]
[[Forgetful]]
[[Lightweight]]
[[Addictive Personality]]
[[Trigger Happy]]
[[Smelly]]
[[Chemical Imbalance]]
[[Schizophrenic]]
[[Jittery]]
[[Hoarder]]
[[Savant]]
[[Mood Swings]]
[[Weak Stomach]]
[[Wool Allergy]]
[[HP Ignorant]]
[[Truth Teller]]
[[Ugly]]
[[Bug - PF_MAX]]
-[[Rough Skin]]
[[High Night Vision]]
[[Full Night Vision]]
[[Infared Vision]]
[[Very Fast Healer]]
[[Regeneration]]
[[Fangs]]
[[Nictitating Membrane]]
[[Gills]]
[[Scales]]
[[Thick Scales]]
[[Sleek Scales]]
[[Light Bones]]
[[Feathers]]
[[Lightly Furred]]
[[Furry]]
[[Chitinous Skin]]
[[Chitinous Armour]]
[[Chitinous Plate]]
[[Spines]]
[[Quills]]
[[Phelloderm]]
[[Bark]]
[[Thorns]]
[[Leaves]]
[[Long Fingernails]]
[[Claws]]
[[Large Talons]]
[[Radiogenic]]
[[Marloss Carrier]]
[[Insect Pheromones]]
[[Mammal Pheromones]]
[[Disease Immune]]
[[Poisonous]]
[[Slime Hands]]
[[Compound Eyes]]
[[Padded Feet]]
-[[Hooves]]
[[Saprovore]]
[[Ruminant]]
[[Horns]]
[[Curled Horns]]
[[Pointed Horns]]
[[Antennae]]
[[Road-Runner]]
-[[Stubby Tail]]
[[Tail Fin]]
[[Long Tail]]
[[Fluffy Tail]]
[[Spiked Tail]]
[[Club Tail]]
[[Pain Recovery]]
[[Quick Pain Recovery]]
[[Very Quick Pain Recovery]]
[[Bird Wings]]
[[Insect Wings]]
[[Mouth Tentacles]]
[[Mandibles]]
[[Canine Ears]]
[[Web Walker]]
[[Web Weaver]]
[[Whiskers]]
-[[Head Bumps]]
-[[Antlers]]
-[[Slit Nostrils]]
-[[Forked Tongue]]
-[[Bulging Eyes]]
-[[Mouth Flaps]]
-[[Wing Stubs]]
-[[Bat Wings]]
-[[Pale Skin]]
-[[Spots]]
-[[Very Smelly]]
-[[Deformed]]
-[[Badly Deformed]]
-[[Grotesque]]
-[[Hollow Bones]]
-[[Nausea]]
-[[Vomitous]]
-[[Fast Metabolism]]
-[[High Thirst]]
-[[Weakening]]
-[[Deterioration]]
-[[Disintegration]]
-[[Albino]]
-[[Sores]]
-[[Light Sensitive]]
-[[Very Light Sensitive]]
-[[Troglobite]]
-[[Webbed Hands]]
-[[Beak]]
-[[Genetically Unstable]]
-[[Minor Radioactivity]]
-[[Radioactivity]]
-[[Severe Radioactivity]]
-[[Slimy]]
-[[Herbivore]]
-[[Carnivore]]
-[[Ponderous]]
-[[Very Ponderous]]
-[[Extremely Ponderous]]
-[[Sunlight Dependant]]
-[[Heat Dependant]]
-[[Very Heat Dependant]]
-[[Cold Blooded]]
-[[Growling Voice]]
-[[Snarling Voice]]
-[[Shouter]]
-[[Screamer]]
-[[Howler]]
-[[Tentacle Arms]]
-[[4 Tentacles]]
-[[7 Tentacles]]
-[[Shell]]
-[[Leg Tentacles]]
-[[]]
-[[]]
-[[]]
-[[]]
-[[]]
 
/***
Description: Contains the stuff you need to use Tiddlyspot
Note, you also need UploadPlugin, PasswordOptionPlugin and LoadRemoteFileThroughProxy
from http://tiddlywiki.bidix.info for a complete working Tiddlyspot site.
***/
//{{{
// edit this if you are migrating sites or retrofitting an existing TW
config.tiddlyspotSiteId = 'cataclysm';
// make it so you can by default see edit controls via http
config.options.chkHttpReadOnly = false;
window.readOnly = false; // make sure of it (for tw 2.2)
window.showBackstage = true; // show backstage too
// disable autosave in d3
if (window.location.protocol != "file:")
	config.options.chkGTDLazyAutoSave = false;
// tweak shadow tiddlers to add upload button, password entry box etc
with (config.shadowTiddlers) {
	SiteUrl = 'http://'+config.tiddlyspotSiteId+'.tiddlyspot.com';
	SideBarOptions = SideBarOptions.replace(/(<<saveChanges>>)/,"$1<<tiddler TspotSidebar>>");
	OptionsPanel = OptionsPanel.replace(/^/,"<<tiddler TspotOptions>>");
	DefaultTiddlers = DefaultTiddlers.replace(/^/,"[[WelcomeToTiddlyspot]] ");
	MainMenu = MainMenu.replace(/^/,"[[WelcomeToTiddlyspot]] ");
}
// create some shadow tiddler content
merge(config.shadowTiddlers,{
'TspotOptions':[
 "tiddlyspot password:",
 "<<option pasUploadPassword>>",
 ""
].join("\n"),
'TspotControls':[
 "| tiddlyspot password:|<<option pasUploadPassword>>|",
 "| site management:|<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . .  " + config.tiddlyspotSiteId + ">>//(requires tiddlyspot password)//<br>[[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]], [[download (go offline)|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download]]|",
 "| links:|[[tiddlyspot.com|http://tiddlyspot.com/]], [[FAQs|http://faq.tiddlyspot.com/]], [[blog|http://tiddlyspot.blogspot.com/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].join("\n"),
'WelcomeToTiddlyspot':[
 "This document is a ~TiddlyWiki from tiddlyspot.com.  A ~TiddlyWiki is an electronic notebook that is great for managing todo lists, personal information, and all sorts of things.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //What now?//   @@ Before you can save any changes, you need to enter your password in the form below.  Then configure privacy and other site settings at your [[control panel|http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/controlpanel]] (your control panel username is //" + config.tiddlyspotSiteId + "//).",
 "<<tiddler TspotControls>>",
 "See also GettingStarted.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Working online//   @@ You can edit this ~TiddlyWiki right now, and save your changes using the \"save to web\" button in the column on the right.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Working offline//   @@ A fully functioning copy of this ~TiddlyWiki can be saved onto your hard drive or USB stick.  You can make changes and save them locally without being connected to the Internet.  When you're ready to sync up again, just click \"upload\" and your ~TiddlyWiki will be saved back to tiddlyspot.com.",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Help!//   @@ Find out more about ~TiddlyWiki at [[TiddlyWiki.com|http://tiddlywiki.com]].  Also visit [[TiddlyWiki.org|http://tiddlywiki.org]] for documentation on learning and using ~TiddlyWiki. New users are especially welcome on the [[TiddlyWiki mailing list|http://groups.google.com/group/TiddlyWiki]], which is an excellent place to ask questions and get help.  If you have a tiddlyspot related problem email [[tiddlyspot support|mailto:support@tiddlyspot.com]].",
 "",
 "@@font-weight:bold;font-size:1.3em;color:#444; //Enjoy :)//   @@ We hope you like using your tiddlyspot.com site.  Please email [[feedback@tiddlyspot.com|mailto:feedback@tiddlyspot.com]] with any comments or suggestions."
].join("\n"),
'TspotSidebar':[
 "<<upload http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/store.cgi index.html . .  " + config.tiddlyspotSiteId + ">><html><a href='http://" + config.tiddlyspotSiteId + ".tiddlyspot.com/download' class='button'>download</a></html>"
].join("\n")
});
//}}}
 
| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |
| 17/07/2012 05:05:40 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 05:21:56 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 05:22:00 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 05:27:56 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 05:31:27 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 06:10:05 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 17/07/2012 06:18:46 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . | failed |
| 17/07/2012 06:19:59 | Lord Inquisitor | [[index.html|http://cataclysm.tiddlyspot.com/index.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
| 03/08/2012 19:03:38 | Lord Inquisitor | [[cataclysm.html|file:///J:/Downloads/Games/PC%20games/Rogue%20Likes/Cataclysm/Tiddlywiki/cataclysm.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . | ok |
| 05/08/2012 21:15:52 | Lord Inquisitor | [[cataclysm.html|file:///J:/Downloads/Games/PC%20games/Rogue%20Likes/Cataclysm/Tiddlywiki/cataclysm.html]] | [[store.cgi|http://cataclysm.tiddlyspot.com/store.cgi]] | . | [[index.html | http://cataclysm.tiddlyspot.com/index.html]] | . |
 
/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.3|
|''Date:''|Feb 24, 2008|
|''Source:''|http://tiddlywiki.bidix.info/#UploadPlugin|
|''Documentation:''|http://tiddlywiki.bidix.info/#UploadPluginDoc|
|''Author:''|BidiX (BidiX (at) bidix (dot) info)|
|''License:''|[[BSD open source license|http://tiddlywiki.bidix.info/#%5B%5BBSD%20open%20source%20license%5D%5D ]]|
|''~CoreVersion:''|2.2.0|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
	major: 4, minor: 1, revision: 3,
	date: new Date("Feb 24, 2008"),
	source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	coreVersion: '2.2.0'
};
//
// Environment
//
if (!window.bidix) window.bidix = {}; // bidix namespace
bidix.debugMode = false;	// true to activate both in Plugin and UploadService
	
//
// Upload Macro
//
config.macros.upload = {
// default values
	defaultBackupDir: '',	//no backup
	defaultStoreScript: "store.php",
	defaultToFilename: "index.html",
	defaultUploadDir: ".",
	authenticateUser: true	// UploadService Authenticate User
};
	
config.macros.upload.label = {
	promptOption: "Save and Upload this TiddlyWiki with UploadOptions",
	promptParamMacro: "Save and Upload this TiddlyWiki in %0",
	saveLabel: "save to web", 
	saveToDisk: "save to disk",
	uploadLabel: "upload"	
};
config.macros.upload.messages = {
	noStoreUrl: "No store URL in parmeters or options",
	usernameOrPasswordMissing: "Username or password missing"
};
config.macros.upload.handler = function(place,macroName,params) {
	if (readOnly)
		return;
	var label;
	if (document.location.toString().substr(0,4) == "http") 
		label = this.label.saveLabel;
	else
		label = this.label.uploadLabel;
	var prompt;
	if (params[0]) {
		prompt = this.label.promptParamMacro.toString().format([this.destFile(params[0], 
			(params[1] ? params[1]:bidix.basename(window.location.toString())), params[3])]);
	} else {
		prompt = this.label.promptOption;
	}
	createTiddlyButton(place, label, prompt, function() {config.macros.upload.action(params);}, null, null, this.accessKey);
};
config.macros.upload.action = function(params)
{
		// for missing macro parameter set value from options
		if (!params) params = {};
		var storeUrl = params[0] ? params[0] : config.options.txtUploadStoreUrl;
		var toFilename = params[1] ? params[1] : config.options.txtUploadFilename;
		var backupDir = params[2] ? params[2] : config.options.txtUploadBackupDir;
		var uploadDir = params[3] ? params[3] : config.options.txtUploadDir;
		var username = params[4] ? params[4] : config.options.txtUploadUserName;
		var password = config.options.pasUploadPassword; // for security reason no password as macro parameter	
		// for still missing parameter set default value
		if ((!storeUrl) && (document.location.toString().substr(0,4) == "http")) 
			storeUrl = bidix.dirname(document.location.toString())+'/'+config.macros.upload.defaultStoreScript;
		if (storeUrl.substr(0,4) != "http")
			storeUrl = bidix.dirname(document.location.toString()) +'/'+ storeUrl;
		if (!toFilename)
			toFilename = bidix.basename(window.location.toString());
		if (!toFilename)
			toFilename = config.macros.upload.defaultToFilename;
		if (!uploadDir)
			uploadDir = config.macros.upload.defaultUploadDir;
		if (!backupDir)
			backupDir = config.macros.upload.defaultBackupDir;
		// report error if still missing
		if (!storeUrl) {
			alert(config.macros.upload.messages.noStoreUrl);
			clearMessage();
			return false;
		}
		if (config.macros.upload.authenticateUser && (!username || !password)) {
			alert(config.macros.upload.messages.usernameOrPasswordMissing);
			clearMessage();
			return false;
		}
		bidix.upload.uploadChanges(false,null,storeUrl, toFilename, uploadDir, backupDir, username, password); 
		return false; 
};
config.macros.upload.destFile = function(storeUrl, toFilename, uploadDir) 
{
	if (!storeUrl)
		return null;
		var dest = bidix.dirname(storeUrl);
		if (uploadDir && uploadDir != '.')
			dest = dest + '/' + uploadDir;
		dest = dest + '/' + toFilename;
	return dest;
};
//
// uploadOptions Macro
//
config.macros.uploadOptions = {
	handler: function(place,macroName,params) {
		var wizard = new Wizard();
		wizard.createWizard(place,this.wizardTitle);
		wizard.addStep(this.step1Title,this.step1Html);
		var markList = wizard.getElement("markList");
		var listWrapper = document.createElement("div");
		markList.parentNode.insertBefore(listWrapper,markList);
		wizard.setValue("listWrapper",listWrapper);
		this.refreshOptions(listWrapper,false);
		var uploadCaption;
		if (document.location.toString().substr(0,4) == "http") 
			uploadCaption = config.macros.upload.label.saveLabel;
		else
			uploadCaption = config.macros.upload.label.uploadLabel;
		
		wizard.setButtons([
				{caption: uploadCaption, tooltip: config.macros.upload.label.promptOption, 
					onClick: config.macros.upload.action},
				{caption: this.cancelButton, tooltip: this.cancelButtonPrompt, onClick: this.onCancel}
				
			]);
	},
	options: [
		"txtUploadUserName",
		"pasUploadPassword",
		"txtUploadStoreUrl",
		"txtUploadDir",
		"txtUploadFilename",
		"txtUploadBackupDir",
		"chkUploadLog",
		"txtUploadLogMaxLine"		
	],
	refreshOptions: function(listWrapper) {
		var opts = [];
		for(i=0; i<this.options.length; i++) {
			var opt = {};
			opts.push();
			opt.option = "";
			n = this.options[i];
			opt.name = n;
			opt.lowlight = !config.optionsDesc[n];
			opt.description = opt.lowlight ? this.unknownDescription : config.optionsDesc[n];
			opts.push(opt);
		}
		var listview = ListView.create(listWrapper,opts,this.listViewTemplate);
		for(n=0; n<opts.length; n++) {
			var type = opts[n].name.substr(0,3);
			var h = config.macros.option.types[type];
			if (h && h.create) {
				h.create(opts[n].colElements['option'],type,opts[n].name,opts[n].name,"no");
			}
		}
		
	},
	onCancel: function(e)
	{
		backstage.switchTab(null);
		return false;
	},
	
	wizardTitle: "Upload with options",
	step1Title: "These options are saved in cookies in your browser",
	step1Html: "<input type='hidden' name='markList'></input><br>",
	cancelButton: "Cancel",
	cancelButtonPrompt: "Cancel prompt",
	listViewTemplate: {
		columns: [
			{name: 'Description', field: 'description', title: "Description", type: 'WikiText'},
			{name: 'Option', field: 'option', title: "Option", type: 'String'},
			{name: 'Name', field: 'name', title: "Name", type: 'String'}
			],
		rowClasses: [
			{className: 'lowlight', field: 'lowlight'} 
			]}
};
//
// upload functions
//
if (!bidix.upload) bidix.upload = {};
if (!bidix.upload.messages) bidix.upload.messages = {
	//from saving
	invalidFileError: "The original file '%0' does not appear to be a valid TiddlyWiki",
	backupSaved: "Backup saved",
	backupFailed: "Failed to upload backup file",
	rssSaved: "RSS feed uploaded",
	rssFailed: "Failed to upload RSS feed file",
	emptySaved: "Empty template uploaded",
	emptyFailed: "Failed to upload empty template file",
	mainSaved: "Main TiddlyWiki file uploaded",
	mainFailed: "Failed to upload main TiddlyWiki file. Your changes have not been saved",
	//specific upload
	loadOriginalHttpPostError: "Can't get original file",
	aboutToSaveOnHttpPost: 'About to upload on %0 ...',
	storePhpNotFound: "The store script '%0' was not found."
};
bidix.upload.uploadChanges = function(onlyIfDirty,tiddlers,storeUrl,toFilename,uploadDir,backupDir,username,password)
{
	var callback = function(status,uploadParams,original,url,xhr) {
		if (!status) {
			displayMessage(bidix.upload.messages.loadOriginalHttpPostError);
			return;
		}
		if (bidix.debugMode) 
			alert(original.substr(0,500)+"\n...");
		// Locate the storeArea div's 
		var posDiv = locateStoreArea(original);
		if((posDiv[0] == -1) || (posDiv[1] == -1)) {
			alert(config.messages.invalidFileError.format([localPath]));
			return;
		}
		bidix.upload.uploadRss(uploadParams,original,posDiv);
	};
	
	if(onlyIfDirty && !store.isDirty())
		return;
	clearMessage();
	// save on localdisk ?
	if (document.location.toString().substr(0,4) == "file") {
		var path = document.location.toString();
		var localPath = getLocalPath(path);
		saveChanges();
	}
	// get original
	var uploadParams = new Array(storeUrl,toFilename,uploadDir,backupDir,username,password);
	var originalPath = document.location.toString();
	// If url is a directory : add index.html
	if (originalPath.charAt(originalPath.length-1) == "/")
		originalPath = originalPath + "index.html";
	var dest = config.macros.upload.destFile(storeUrl,toFilename,uploadDir);
	var log = new bidix.UploadLog();
	log.startUpload(storeUrl, dest, uploadDir,  backupDir);
	displayMessage(bidix.upload.messages.aboutToSaveOnHttpPost.format([dest]));
	if (bidix.debugMode) 
		alert("about to execute Http - GET on "+originalPath);
	var r = doHttp("GET",originalPath,null,null,username,password,callback,uploadParams,null);
	if (typeof r == "string")
		displayMessage(r);
	return r;
};
bidix.upload.uploadRss = function(uploadParams,original,posDiv) 
{
	var callback = function(status,params,responseText,url,xhr) {
		if(status) {
			var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
			displayMessage(bidix.upload.messages.rssSaved,bidix.dirname(url)+'/'+destfile);
			bidix.upload.uploadMain(params[0],params[1],params[2]);
		} else {
			displayMessage(bidix.upload.messages.rssFailed);			
		}
	};
	// do uploadRss
	if(config.options.chkGenerateAnRssFeed) {
		var rssPath = uploadParams[1].substr(0,uploadParams[1].lastIndexOf(".")) + ".xml";
		var rssUploadParams = new Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
		var rssString = generateRss();
		// no UnicodeToUTF8 conversion needed when location is "file" !!!
		if (document.location.toString().substr(0,4) != "file")
			rssString = convertUnicodeToUTF8(rssString);	
		bidix.upload.httpUpload(rssUploadParams,rssString,callback,Array(uploadParams,original,posDiv));
	} else {
		bidix.upload.uploadMain(uploadParams,original,posDiv);
	}
};
bidix.upload.uploadMain = function(uploadParams,original,posDiv) 
{
	var callback = function(status,params,responseText,url,xhr) {
		var log = new bidix.UploadLog();
		if(status) {
			// if backupDir specified
			if ((params[3]) && (responseText.indexOf("backupfile:") > -1))  {
				var backupfile = responseText.substring(responseText.indexOf("backupfile:")+11,responseText.indexOf("\n", responseText.indexOf("backupfile:")));
				displayMessage(bidix.upload.messages.backupSaved,bidix.dirname(url)+'/'+backupfile);
			}
			var destfile = responseText.substring(responseText.indexOf("destfile:")+9,responseText.indexOf("\n", responseText.indexOf("destfile:")));
			displayMessage(bidix.upload.messages.mainSaved,bidix.dirname(url)+'/'+destfile);
			store.setDirty(false);
			log.endUpload("ok");
		} else {
			alert(bidix.upload.messages.mainFailed);
			displayMessage(bidix.upload.messages.mainFailed);
			log.endUpload("failed");			
		}
	};
	// do uploadMain
	var revised = bidix.upload.updateOriginal(original,posDiv);
	bidix.upload.httpUpload(uploadParams,revised,callback,uploadParams);
};
bidix.upload.httpUpload = function(uploadParams,data,callback,params)
{
	var localCallback = function(status,params,responseText,url,xhr) {
		url = (url.indexOf("nocache=") < 0 ? url : url.substring(0,url.indexOf("nocache=")-1));
		if (xhr.status == 404)
			alert(bidix.upload.messages.storePhpNotFound.format([url]));
		if ((bidix.debugMode) || (responseText.indexOf("Debug mode") >= 0 )) {
			alert(responseText);
			if (responseText.indexOf("Debug mode") >= 0 )
				responseText = responseText.substring(responseText.indexOf("\n\n")+2);
		} else if (responseText.charAt(0) != '0') 
			alert(responseText);
		if (responseText.charAt(0) != '0')
			status = null;
		callback(status,params,responseText,url,xhr);
	};
	// do httpUpload
	var boundary = "---------------------------"+"AaB03x";	
	var uploadFormName = "UploadPlugin";
	// compose headers data
	var sheader = "";
	sheader += "--" + boundary + "\r\nContent-disposition: form-data; name=\"";
	sheader += uploadFormName +"\"\r\n\r\n";
	sheader += "backupDir="+uploadParams[3] +
				";user=" + uploadParams[4] +
				";password=" + uploadParams[5] +
				";uploaddir=" + uploadParams[2];
	if (bidix.debugMode)
		sheader += ";debug=1";
	sheader += ";;\r\n"; 
	sheader += "\r\n" + "--" + boundary + "\r\n";
	sheader += "Content-disposition: form-data; name=\"userfile\"; filename=\""+uploadParams[1]+"\"\r\n";
	sheader += "Content-Type: text/html;charset=UTF-8" + "\r\n";
	sheader += "Content-Length: " + data.length + "\r\n\r\n";
	// compose trailer data
	var strailer = new String();
	strailer = "\r\n--" + boundary + "--\r\n";
	data = sheader + data + strailer;
	if (bidix.debugMode) alert("about to execute Http - POST on "+uploadParams[0]+"\n with \n"+data.substr(0,500)+ " ... ");
	var r = doHttp("POST",uploadParams[0],data,"multipart/form-data; ;charset=UTF-8; boundary="+boundary,uploadParams[4],uploadParams[5],localCallback,params,null);
	if (typeof r == "string")
		displayMessage(r);
	return r;
};
// same as Saving's updateOriginal but without convertUnicodeToUTF8 calls
bidix.upload.updateOriginal = function(original, posDiv)
{
	if (!posDiv)
		posDiv = locateStoreArea(original);
	if((posDiv[0] == -1) || (posDiv[1] == -1)) {
		alert(config.messages.invalidFileError.format([localPath]));
		return;
	}
	var revised = original.substr(0,posDiv[0] + startSaveArea.length) + "\n" +
				store.allTiddlersAsHtml() + "\n" +
				original.substr(posDiv[1]);
	var newSiteTitle = getPageTitle().htmlEncode();
	revised = revised.replaceChunk("<title"+">","</title"+">"," " + newSiteTitle + " ");
	revised = updateMarkupBlock(revised,"PRE-HEAD","MarkupPreHead");
	revised = updateMarkupBlock(revised,"POST-HEAD","MarkupPostHead");
	revised = updateMarkupBlock(revised,"PRE-BODY","MarkupPreBody");
	revised = updateMarkupBlock(revised,"POST-SCRIPT","MarkupPostBody");
	return revised;
};
//
// UploadLog
// 
// config.options.chkUploadLog :
//		false : no logging
//		true : logging
// config.options.txtUploadLogMaxLine :
//		-1 : no limit
//      0 :  no Log lines but UploadLog is still in place
//		n :  the last n lines are only kept
//		NaN : no limit (-1)
bidix.UploadLog = function() {
	if (!config.options.chkUploadLog) 
		return; // this.tiddler = null
	this.tiddler = store.getTiddler("UploadLog");
	if (!this.tiddler) {
		this.tiddler = new Tiddler();
		this.tiddler.title = "UploadLog";
		this.tiddler.text = "| !date | !user | !location | !storeUrl | !uploadDir | !toFilename | !backupdir | !origin |";
		this.tiddler.created = new Date();
		this.tiddler.modifier = config.options.txtUserName;
		this.tiddler.modified = new Date();
		store.addTiddler(this.tiddler);
	}
	return this;
};
bidix.UploadLog.prototype.addText = function(text) {
	if (!this.tiddler)
		return;
	// retrieve maxLine when we need it
	var maxLine = parseInt(config.options.txtUploadLogMaxLine,10);
	if (isNaN(maxLine))
		maxLine = -1;
	// add text
	if (maxLine != 0) 
		this.tiddler.text = this.tiddler.text + text;
	// Trunck to maxLine
	if (maxLine >= 0) {
		var textArray = this.tiddler.text.split('\n');
		if (textArray.length > maxLine + 1)
			textArray.splice(1,textArray.length-1-maxLine);
			this.tiddler.text = textArray.join('\n');		
	}
	// update tiddler fields
	this.tiddler.modifier = config.options.txtUserName;
	this.tiddler.modified = new Date();
	store.addTiddler(this.tiddler);
	// refresh and notifiy for immediate update
	story.refreshTiddler(this.tiddler.title);
	store.notify(this.tiddler.title, true);
};
bidix.UploadLog.prototype.startUpload = function(storeUrl, toFilename, uploadDir,  backupDir) {
	if (!this.tiddler)
		return;
	var now = new Date();
	var text = "\n| ";
	var filename = bidix.basename(document.location.toString());
	if (!filename) filename = '/';
	text += now.formatString("0DD/0MM/YYYY 0hh:0mm:0ss") +" | ";
	text += config.options.txtUserName + " | ";
	text += "[["+filename+"|"+location + "]] |";
	text += " [[" + bidix.basename(storeUrl) + "|" + storeUrl + "]] | ";
	text += uploadDir + " | ";
	text += "[[" + bidix.basename(toFilename) + " | " +toFilename + "]] | ";
	text += backupDir + " |";
	this.addText(text);
};
bidix.UploadLog.prototype.endUpload = function(status) {
	if (!this.tiddler)
		return;
	this.addText(" "+status+" |");
};
//
// Utilities
// 
bidix.checkPlugin = function(plugin, major, minor, revision) {
	var ext = version.extensions[plugin];
	if (!
		(ext  && 
			((ext.major > major) || 
			((ext.major == major) && (ext.minor > minor))  ||
			((ext.major == major) && (ext.minor == minor) && (ext.revision >= revision))))) {
			// write error in PluginManager
			if (pluginInfo)
				pluginInfo.log.push("Requires " + plugin + " " + major + "." + minor + "." + revision);
			eval(plugin); // generate an error : "Error: ReferenceError: xxxx is not defined"
	}
};
bidix.dirname = function(filePath) {
	if (!filePath) 
		return;
	var lastpos;
	if ((lastpos = filePath.lastIndexOf("/")) != -1) {
		return filePath.substring(0, lastpos);
	} else {
		return filePath.substring(0, filePath.lastIndexOf("\\"));
	}
};
bidix.basename = function(filePath) {
	if (!filePath) 
		return;
	var lastpos;
	if ((lastpos = filePath.lastIndexOf("#")) != -1) 
		filePath = filePath.substring(0, lastpos);
	if ((lastpos = filePath.lastIndexOf("/")) != -1) {
		return filePath.substring(lastpos + 1);
	} else
		return filePath.substring(filePath.lastIndexOf("\\")+1);
};
bidix.initOption = function(name,value) {
	if (!config.options[name])
		config.options[name] = value;
};
//
// Initializations
//
// require PasswordOptionPlugin 1.0.1 or better
bidix.checkPlugin("PasswordOptionPlugin", 1, 0, 1);
// styleSheet
setStylesheet('.txtUploadStoreUrl, .txtUploadBackupDir, .txtUploadDir {width: 22em;}',"uploadPluginStyles");
//optionsDesc
merge(config.optionsDesc,{
	txtUploadStoreUrl: "Url of the UploadService script (default: store.php)",
	txtUploadFilename: "Filename of the uploaded file (default: in index.html)",
	txtUploadDir: "Relative Directory where to store the file (default: . (downloadService directory))",
	txtUploadBackupDir: "Relative Directory where to backup the file. If empty no backup. (default: ''(empty))",
	txtUploadUserName: "Upload Username",
	pasUploadPassword: "Upload Password",
	chkUploadLog: "do Logging in UploadLog (default: true)",
	txtUploadLogMaxLine: "Maximum of lines in UploadLog (default: 10)"
});
// Options Initializations
bidix.initOption('txtUploadStoreUrl','');
bidix.initOption('txtUploadFilename','');
bidix.initOption('txtUploadDir','');
bidix.initOption('txtUploadBackupDir','');
bidix.initOption('txtUploadUserName','');
bidix.initOption('pasUploadPassword','');
bidix.initOption('chkUploadLog',true);
bidix.initOption('txtUploadLogMaxLine','10');
// Backstage
merge(config.tasks,{
	uploadOptions: {text: "upload", tooltip: "Change UploadOptions and Upload", content: '<<uploadOptions>>'}
});
config.backstageTasks.push("uploadOptions");
//}}}
 
config.options.txtUserName = "Lord Inquisitor"; 
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 10 | V8 | 2 | 1 | 0 | 0 | 0 | 60 | 6 | 28 | 240 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 15 | 35 | red | [[Drinks Can]] | 0 | 1 | 0 | 1 | 0 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Contains up to 8 vegetables!  Nutritious and tasty. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 12 | vodka | 2 | 1 | 0 | 0 | 0 | 60 | -10 | 2 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 20 | 78 | ltcyan | [[Glass Bottle]] | -12 | -2 | 5 | 20 | 30 | alcohol | [[ADD_ALCOHOL|Alcohol]] |
|!Description|>|>|>|>|>|>|>|>|>|>| In Soviet Russia, vodka drinks you! |
 
| Number |!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
| 2 | Water | 2 | 1 | 0 | 0 | 0 | 60 | 0 | 50 | 0 |
|!Rarity|!Price|!Color|!Container|!Spoil Speed| !Stimulation |!Healthy|!Addiction Level|!Charges|!Use|!Addiction Type|
| 90 | 50 | Cyan | [[Plastic Bottle]] | 0 | 0 | 0 | 0 | 1 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Water, the Stuff of Life, the best thirst-quencher available. |
 
| Number |!Name|!Volume|!Weight|!Bash|!Cut|!To hit Bonus|!Moves per attack|!Nutrition|!Quench|!Enjoyability|h
| 3 | Water | 2 | 1 | 0 | 0 | 0 | 60 | 0 | 30 | 0 |
|!Rarity|!Price|!Color|!Container|!Spoil Speed| !Stimulation |!Healthy|!Addiction Level|!Charges|!Use|!Addiction Type|
| 0 | 50 | Cyan | [[Plastic Bottle]] | 0 | 0 | -4 | 0 | 1 | none | - |
|!Description|>|>|>|>|>|>|>|>|>|>| Water, the Stuff of Life, the best thirst-quencher available. |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[Quench]]|![[Nutrition]]|![[Spoil Speed]]|h
| 11 | whiskey | 2 | 1 | 0 | 0 | 0 | 60 | -12 | 4 | 0 |
|![[Rarity]]|![[Price]]|![[Color|Item Color]]|![[Container]]| ![[Stimulation]] |![[Healthy]]|![[Addiction Level]]|![[Charges]]|![[Enjoyability]]|![[Use]]|![[Addiction Type]]|
| 16 | 85 | brown | [[Glass Bottle]] | -12 | -2 | 5 | 20 | 30 | alcohol | [[ADD_ALCOHOL|Alcohol]] |
|!Description|>|>|>|>|>|>|>|>|>|>| Made from, by, and for real Southern colonels! |
 
| [[Number]] |![[Name]]|![[Volume]]|![[Weight]]|![[Bash]]|![[Cut]]|![[To hit Bonus]]|![[Moves per attack]]|![[]]|![[]]|![[]]|h
| 228 | Wood Crossbow Bolt  | 1 | 40 |  |  |  |  |  |  |  |
|![[Rarity]]|![[Price]]| ![[Ammo type]] |![[Color|Item Color]]|![[Material]]|![[Damage]]|![[Armor Pierce]]|![[Range]]|![[Accuracy]]|![[Recoil]]|![[Count]]|
| 8 | 500 | [[Bolts|AT_BOLT]] | green | [[WOOD|Material_Wood]] | 16 | 4 | 10 | 16 | 0 | 15 |
|!Description|>|>|>|>|>|>|>|>|>|>| A sharpened bolt carved from wood.  It's lighter than steel bolts, and does\n\less damage and is less accurate.  Stands a good chance of remaining intact\n\once fired. |
 
| !Recipe  | [[Wood Spear]] |
| !Difficulty | 0 |
| !Primary Skill | N/A |
| !Secondary Skill | N/A |
| !Time | 800 |
|>| !Tools required |
|>| [[Hatchet]] ^^or^^ [[Steak Knife]] ^^or^^ [[Butcher Knife]] ^^or^^ [[Combat Knife]]|
|>| !Components Required |
|>|1x [[Heavy Stick]]  ^^or^^ 1x [[Broom]] ^^or^^ 1x [[Mop]] ^^or^^ 1x [[Two by Four]] |