Background: #fff
Foreground: #000
PrimaryPale: #8cf
PrimaryLight: #18f
PrimaryMid: #04b
PrimaryDark: #014
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}

a {color:[[ColorPalette::PrimaryMid]];}
a:hover {background-color:[[ColorPalette::PrimaryMid]]; color:[[ColorPalette::Background]];}
a img {border:0;}

h1,h2,h3,h4,h5,h6 {color:[[ColorPalette::SecondaryDark]]; background:transparent;}
h1 {border-bottom:2px solid [[ColorPalette::TertiaryLight]];}
h2,h3 {border-bottom:1px solid [[ColorPalette::TertiaryLight]];}

.button {color:[[ColorPalette::PrimaryDark]]; border:1px solid [[ColorPalette::Background]];}
.button:hover {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::SecondaryLight]]; border-color:[[ColorPalette::SecondaryMid]];}
.button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::SecondaryDark]];}

.header {background:[[ColorPalette::PrimaryMid]];}
.headerShadow {color:[[ColorPalette::Foreground]];}
.headerShadow a {font-weight:normal; color:[[ColorPalette::Foreground]];}
.headerForeground {color:[[ColorPalette::Background]];}
.headerForeground a {font-weight:normal; color:[[ColorPalette::PrimaryPale]];}

.tabSelected{color:[[ColorPalette::PrimaryDark]];
	background:[[ColorPalette::TertiaryPale]];
	border-left:1px solid [[ColorPalette::TertiaryLight]];
	border-top:1px solid [[ColorPalette::TertiaryLight]];
	border-right:1px solid [[ColorPalette::TertiaryLight]];
}
.tabUnselected {color:[[ColorPalette::Background]]; background:[[ColorPalette::TertiaryMid]];}
.tabContents {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::TertiaryPale]]; border:1px solid [[ColorPalette::TertiaryLight]];}
.tabContents .button {border:0;}

#sidebar {}
#sidebarOptions input {border:1px solid [[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel {background:[[ColorPalette::PrimaryPale]];}
#sidebarOptions .sliderPanel a {border:none;color:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:hover {color:[[ColorPalette::Background]]; background:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:active {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::Background]];}

.wizard {background:[[ColorPalette::PrimaryPale]]; border:1px solid [[ColorPalette::PrimaryMid]];}
.wizard h1 {color:[[ColorPalette::PrimaryDark]]; border:none;}
.wizard h2 {color:[[ColorPalette::Foreground]]; border:none;}
.wizardStep {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];
	border:1px solid [[ColorPalette::PrimaryMid]];}
.wizardStep.wizardStepDone {background:[[ColorPalette::TertiaryLight]];}
.wizardFooter {background:[[ColorPalette::PrimaryPale]];}
.wizardFooter .status {background:[[ColorPalette::PrimaryDark]]; color:[[ColorPalette::Background]];}
.wizard .button {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryLight]]; border: 1px solid;
	border-color:[[ColorPalette::SecondaryPale]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryPale]];}
.wizard .button:hover {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Background]];}
.wizard .button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::Foreground]]; border: 1px solid;
	border-color:[[ColorPalette::PrimaryDark]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryDark]];}

#messageArea {border:1px solid [[ColorPalette::SecondaryMid]]; background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]];}
#messageArea .button {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::SecondaryPale]]; border:none;}

.popupTiddler {background:[[ColorPalette::TertiaryPale]]; border:2px solid [[ColorPalette::TertiaryMid]];}

.popup {background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]]; border-left:1px solid [[ColorPalette::TertiaryMid]]; border-top:1px solid [[ColorPalette::TertiaryMid]]; border-right:2px solid [[ColorPalette::TertiaryDark]]; border-bottom:2px solid [[ColorPalette::TertiaryDark]];}
.popup hr {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::PrimaryDark]]; border-bottom:1px;}
.popup li.disabled {color:[[ColorPalette::TertiaryMid]];}
.popup li a, .popup li a:visited {color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:active {background:[[ColorPalette::SecondaryPale]]; color:[[ColorPalette::Foreground]]; border: none;}
.popupHighlight {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
.listBreak div {border-bottom:1px solid [[ColorPalette::TertiaryDark]];}

.tiddler .defaultCommand {font-weight:bold;}

.shadow .title {color:[[ColorPalette::TertiaryDark]];}

.title {color:[[ColorPalette::SecondaryDark]];}
.subtitle {color:[[ColorPalette::TertiaryDark]];}

.toolbar {color:[[ColorPalette::PrimaryMid]];}
.toolbar a {color:[[ColorPalette::TertiaryLight]];}
.selected .toolbar a {color:[[ColorPalette::TertiaryMid]];}
.selected .toolbar a:hover {color:[[ColorPalette::Foreground]];}

.tagging, .tagged {border:1px solid [[ColorPalette::TertiaryPale]]; background-color:[[ColorPalette::TertiaryPale]];}
.selected .tagging, .selected .tagged {background-color:[[ColorPalette::TertiaryLight]]; border:1px solid [[ColorPalette::TertiaryMid]];}
.tagging .listTitle, .tagged .listTitle {color:[[ColorPalette::PrimaryDark]];}
.tagging .button, .tagged .button {border:none;}

.footer {color:[[ColorPalette::TertiaryLight]];}
.selected .footer {color:[[ColorPalette::TertiaryMid]];}

.sparkline {background:[[ColorPalette::PrimaryPale]]; border:0;}
.sparktick {background:[[ColorPalette::PrimaryDark]];}

.error, .errorButton {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Error]];}
.warning {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryPale]];}
.lowlight {background:[[ColorPalette::TertiaryLight]];}

.zoomer {background:none; color:[[ColorPalette::TertiaryMid]]; border:3px solid [[ColorPalette::TertiaryMid]];}

.imageLink, #displayArea .imageLink {background:transparent;}

.annotation {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border:2px solid [[ColorPalette::SecondaryMid]];}

.viewer .listTitle {list-style-type:none; margin-left:-2em;}
.viewer .button {border:1px solid [[ColorPalette::SecondaryMid]];}
.viewer blockquote {border-left:3px solid [[ColorPalette::TertiaryDark]];}

.viewer table, table.twtable {border:2px solid [[ColorPalette::TertiaryDark]];}
.viewer th, .viewer thead td, .twtable th, .twtable thead td {background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::Background]];}
.viewer td, .viewer tr, .twtable td, .twtable tr {border:1px solid [[ColorPalette::TertiaryDark]];}

.viewer pre {border:1px solid [[ColorPalette::SecondaryLight]]; background:[[ColorPalette::SecondaryPale]];}
.viewer code {color:[[ColorPalette::SecondaryDark]];}
.viewer hr {border:0; border-top:dashed 1px [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::TertiaryDark]];}

.highlight, .marked {background:[[ColorPalette::SecondaryLight]];}

.editor input {border:1px solid [[ColorPalette::PrimaryMid]];}
.editor textarea {border:1px solid [[ColorPalette::PrimaryMid]]; width:100%;}
.editorFooter {color:[[ColorPalette::TertiaryMid]];}

#backstageArea {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::TertiaryMid]];}
#backstageArea a {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstageArea a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; }
#backstageArea a.backstageSelTab {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
#backstageButton a {background:none; color:[[ColorPalette::Background]]; border:none;}
#backstageButton a:hover {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstagePanel {background:[[ColorPalette::Background]]; border-color: [[ColorPalette::Background]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]];}
.backstagePanelFooter .button {border:none; color:[[ColorPalette::Background]];}
.backstagePanelFooter .button:hover {color:[[ColorPalette::Foreground]];}
#backstageCloak {background:[[ColorPalette::Foreground]]; opacity:0.6; filter:'alpha(opacity:60)';}
/*}}}*/
/*{{{*/
* html .tiddler {height:1%;}

body {font-size:.75em; font-family:arial,helvetica; margin:0; padding:0;}

h1,h2,h3,h4,h5,h6 {font-weight:bold; text-decoration:none;}
h1,h2,h3 {padding-bottom:1px; margin-top:1.2em;margin-bottom:0.3em;}
h4,h5,h6 {margin-top:1em;}
h1 {font-size:1.35em;}
h2 {font-size:1.25em;}
h3 {font-size:1.1em;}
h4 {font-size:1em;}
h5 {font-size:.9em;}

hr {height:1px;}

a {text-decoration:none;}

dt {font-weight:bold;}

ol {list-style-type:decimal;}
ol ol {list-style-type:lower-alpha;}
ol ol ol {list-style-type:lower-roman;}
ol ol ol ol {list-style-type:decimal;}
ol ol ol ol ol {list-style-type:lower-alpha;}
ol ol ol ol ol ol {list-style-type:lower-roman;}
ol ol ol ol ol ol ol {list-style-type:decimal;}

.txtOptionInput {width:11em;}

#contentWrapper .chkOptionInput {border:0;}

.externalLink {text-decoration:underline;}

.indent {margin-left:3em;}
.outdent {margin-left:3em; text-indent:-3em;}
code.escaped {white-space:nowrap;}

.tiddlyLinkExisting {font-weight:bold;}
.tiddlyLinkNonExisting {font-style:italic;}

/* the 'a' is required for IE, otherwise it renders the whole tiddler in bold */
a.tiddlyLinkNonExisting.shadow {font-weight:bold;}

#mainMenu .tiddlyLinkExisting,
	#mainMenu .tiddlyLinkNonExisting,
	#sidebarTabs .tiddlyLinkNonExisting {font-weight:normal; font-style:normal;}
#sidebarTabs .tiddlyLinkExisting {font-weight:bold; font-style:normal;}

.header {position:relative;}
.header a:hover {background:transparent;}
.headerShadow {position:relative; padding:4.5em 0em 1em 1em; left:-1px; top:-1px;}
.headerForeground {position:absolute; padding:4.5em 0em 1em 1em; left:0px; top:0px;}

.siteTitle {font-size:3em;}
.siteSubtitle {font-size:1.2em;}

#mainMenu {position:absolute; left:0; width:10em; text-align:right; line-height:1.6em; padding:1.5em 0.5em 0.5em 0.5em; font-size:1.1em;}

#sidebar {position:absolute; right:3px; width:16em; font-size:.9em;}
#sidebarOptions {padding-top:0.3em;}
#sidebarOptions a {margin:0em 0.2em; padding:0.2em 0.3em; display:block;}
#sidebarOptions input {margin:0.4em 0.5em;}
#sidebarOptions .sliderPanel {margin-left:1em; padding:0.5em; font-size:.85em;}
#sidebarOptions .sliderPanel a {font-weight:bold; display:inline; padding:0;}
#sidebarOptions .sliderPanel input {margin:0 0 .3em 0;}
#sidebarTabs .tabContents {width:15em; overflow:hidden;}

.wizard {padding:0.1em 1em 0em 2em;}
.wizard h1 {font-size:2em; font-weight:bold; background:none; padding:0em 0em 0em 0em; margin:0.4em 0em 0.2em 0em;}
.wizard h2 {font-size:1.2em; font-weight:bold; background:none; padding:0em 0em 0em 0em; margin:0.4em 0em 0.2em 0em;}
.wizardStep {padding:1em 1em 1em 1em;}
.wizard .button {margin:0.5em 0em 0em 0em; font-size:1.2em;}
.wizardFooter {padding:0.8em 0.4em 0.8em 0em;}
.wizardFooter .status {padding:0em 0.4em 0em 0.4em; margin-left:1em;}
.wizard .button {padding:0.1em 0.2em 0.1em 0.2em;}

#messageArea {position:fixed; top:2em; right:0em; margin:0.5em; padding:0.5em; z-index:2000; _position:absolute;}
.messageToolbar {display:block; text-align:right; padding:0.2em 0.2em 0.2em 0.2em;}
#messageArea a {text-decoration:underline;}

.tiddlerPopupButton {padding:0.2em 0.2em 0.2em 0.2em;}
.popupTiddler {position: absolute; z-index:300; padding:1em 1em 1em 1em; margin:0;}

.popup {position:absolute; z-index:300; font-size:.9em; padding:0; list-style:none; margin:0;}
.popup .popupMessage {padding:0.4em;}
.popup hr {display:block; height:1px; width:auto; padding:0; margin:0.2em 0em;}
.popup li.disabled {padding:0.4em;}
.popup li a {display:block; padding:0.4em; font-weight:normal; cursor:pointer;}
.listBreak {font-size:1px; line-height:1px;}
.listBreak div {margin:2px 0;}

.tabset {padding:1em 0em 0em 0.5em;}
.tab {margin:0em 0em 0em 0.25em; padding:2px;}
.tabContents {padding:0.5em;}
.tabContents ul, .tabContents ol {margin:0; padding:0;}
.txtMainTab .tabContents li {list-style:none;}
.tabContents li.listLink { margin-left:.75em;}

#contentWrapper {display:block;}
#splashScreen {display:none;}

#displayArea {margin:1em 17em 0em 14em;}

.toolbar {text-align:right; font-size:.9em;}

.tiddler {padding:1em 1em 0em 1em;}

.missing .viewer,.missing .title {font-style:italic;}

.title {font-size:1.6em; font-weight:bold;}

.missing .subtitle {display:none;}
.subtitle {font-size:1.1em;}

.tiddler .button {padding:0.2em 0.4em;}

.tagging {margin:0.5em 0.5em 0.5em 0; float:left; display:none;}
.isTag .tagging {display:block;}
.tagged {margin:0.5em; float:right;}
.tagging, .tagged {font-size:0.9em; padding:0.25em;}
.tagging ul, .tagged ul {list-style:none; margin:0.25em; padding:0;}
.tagClear {clear:both;}

.footer {font-size:.9em;}
.footer li {display:inline;}

.annotation {padding:0.5em; margin:0.5em;}

* html .viewer pre {width:99%; padding:0 0 1em 0;}
.viewer {line-height:1.4em; padding-top:0.5em;}
.viewer .button {margin:0em 0.25em; padding:0em 0.25em;}
.viewer blockquote {line-height:1.5em; padding-left:0.8em;margin-left:2.5em;}
.viewer ul, .viewer ol {margin-left:0.5em; padding-left:1.5em;}

.viewer table, table.twtable {border-collapse:collapse; margin:0.8em 1.0em;}
.viewer th, .viewer td, .viewer tr,.viewer caption,.twtable th, .twtable td, .twtable tr,.twtable caption {padding:3px;}
table.listView {font-size:0.85em; margin:0.8em 1.0em;}
table.listView th, table.listView td, table.listView tr {padding:0px 3px 0px 3px;}

.viewer pre {padding:0.5em; margin-left:0.5em; font-size:1.2em; line-height:1.4em; overflow:auto;}
.viewer code {font-size:1.2em; line-height:1.4em;}

.editor {font-size:1.1em;}
.editor input, .editor textarea {display:block; width:100%; font:inherit;}
.editorFooter {padding:0.25em 0em; font-size:.9em;}
.editorFooter .button {padding-top:0px; padding-bottom:0px;}

.fieldsetFix {border:0; padding:0; margin:1px 0px 1px 0px;}

.sparkline {line-height:1em;}
.sparktick {outline:0;}

.zoomer {font-size:1.1em; position:absolute; overflow:hidden;}
.zoomer div {padding:1em;}

* html #backstage {width:99%;}
* html #backstageArea {width:99%;}
#backstageArea {display:none; position:relative; overflow: hidden; z-index:150; padding:0.3em 0.5em 0.3em 0.5em;}
#backstageToolbar {position:relative;}
#backstageArea a {font-weight:bold; margin-left:0.5em; padding:0.3em 0.5em 0.3em 0.5em;}
#backstageButton {display:none; position:absolute; z-index:175; top:0em; right:0em;}
#backstageButton a {padding:0.1em 0.4em 0.1em 0.4em; margin:0.1em 0.1em 0.1em 0.1em;}
#backstage {position:relative; width:100%; z-index:50;}
#backstagePanel {display:none; z-index:100; position:absolute; margin:0em 3em 0em 3em; padding:1em 1em 1em 1em;}
.backstagePanelFooter {padding-top:0.2em; float:right;}
.backstagePanelFooter a {padding:0.2em 0.4em 0.2em 0.4em;}
#backstageCloak {display:none; z-index:20; position:absolute; width:100%; height:100px;}

.whenBackstage {display:none;}
.backstageVisible .whenBackstage {display:block;}
/*}}}*/
/***
StyleSheet for use when a translation requires any css style changes.
This StyleSheet can be used directly by languages such as Chinese, Japanese and Korean which use a logographic writing system and need larger font sizes.
***/

/*{{{*/
body {font-size:0.8em;}

#sidebarOptions {font-size:1.05em;}
#sidebarOptions a {font-style:normal;}
#sidebarOptions .sliderPanel {font-size:0.95em;}

.subtitle {font-size:0.8em;}

.viewer table.listView {font-size:0.95em;}

.htmlarea .toolbarHA table {border:1px solid ButtonFace; margin:0em 0em;}
/*}}}*/
/*{{{*/
@media print {
#mainMenu, #sidebar, #messageArea, .toolbar, #backstageButton, #backstageArea {display: none ! important;}
#displayArea {margin: 1em 1em 0em 1em;}
/* Fixes a feature in Firefox 1.5.0.2 where print preview displays the noscript content */
noscript {display:none;}
}
/*}}}*/
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span>&nbsp;
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
</div>
<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>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar closeTiddler closeOthers +editTiddler > fields syncing permalink references jump'></div>
<div class='title' macro='view title'></div>
<div class='subtitle'><span macro='view modifier link'></span>, <span macro='view modified date'></span> (<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>
<div class='tagging' macro='tagging'></div>
<div class='tagged' macro='tags'></div>
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<!--}}}-->
<!--{{{-->
<div class='toolbar' macro='toolbar +saveTiddler -cancelTiddler deleteTiddler'></div>
<div class='title' macro='view title'></div>
<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>
<div class='editor' macro='edit text'></div>
<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser'></span></div>
<!--}}}-->
To get started with this blank TiddlyWiki, you'll need to modify the following tiddlers:
* SiteTitle & SiteSubtitle: The title and subtitle of the site, as shown above (after saving, they will also appear in the browser title bar)
* MainMenu: The menu (usually on the left)
* DefaultTiddlers: Contains the names of the tiddlers that you want to appear when the TiddlyWiki is opened
You'll also need to enter your username for signing your edits: <<option txtUserName>>
These InterfaceOptions for customising TiddlyWiki are saved in your browser

Your username for signing your edits. Write it as a WikiWord (eg JoeBloggs)

<<option txtUserName>>
<<option chkSaveBackups>> SaveBackups
<<option chkAutoSave>> AutoSave
<<option chkRegExpSearch>> RegExpSearch
<<option chkCaseSensitiveSearch>> CaseSensitiveSearch
<<option chkAnimate>> EnableAnimations

----
Also see AdvancedOptions
!Project Setup
#Make a directory to put your project in, the project-directory I used was named {{{~/configureDNSMasq}}}
#Copy the files {{{/etc/dnsmasq.conf}}} and {{{/etc/networking/interfaces}}} into the project-directory.
#Create a file named {{{updateConfiguration.sh}}} and make it executable ({{{chmod +x ./updateConfiguration.sh}}}), this file will serve as our deployment mechanism.

The deployment mechanism doesn't really change, between ips on static networks, so lets go ahead and write it first.
*[[Finding out at what times people visit your page on Facebook]]
	All and all not a bad day today.  I started the morning off by reading some more about Spring Framework JDBC.  Soon [[Fr. Called me|Aggrigating One Single Blog RSS Feeds to Multiple Social Networking Profiles]], my mother came home, and when I was done talking to Fr. about his web questions, I needed to eat lunch, so I made a peanut butter & jelly sandwich.  

	I watched a little bit more of the Wolf Man, while I ate my sandwich, got a little lost in the story a good bit.  I can't believe the Werewolf's name was Larry.  The actor who played the Werewolf was named Lon Chaney.  Broski sent me that tape after the library got rid of it.  I got to the part where Larry's father beat him with a silver cane, and then realized that it was almost time to go to an appointment I had scheduled. 

!Fender Bender!
On my way to my appointment an old-dude and a high schooler had a fender-bender which me late for my appointment.  I got out to make sure they were both okay and didn't need a witness.  The old-dude had a really big car, like the one my grandfather sold for $50, and the young high schooler guy looked like a stoner wore a hoodie and and had a beard.  Both of them were driving slowly when the fender bender happened.  It held up my Blue Bull and the school bus behind me.  I finally got to my appointment, after I asked them if it was okay for me to go.

!Entertainment
Then tonight we went to Lancaster to pickup my sister so we could go see [[The Nut Cracker, Sweet!|http://en.wikipedia.org/wiki/The_Nutcracker]] as performed by the local Mennonite high school.  It was pretty cool, enjoyed it...thought it was over after The Nut Cracker took on the 7 headed mouse, but really it was just the 15 minute intermission...so when we got back they had people dancing again.  And those ballerinas on their toes ouch!  Oh and it wasn't just the high-school that put it on, the high school had help from some actual Ukrainian Ballerinas. 

!Friendly's
After my family and I attended the ballad, we went to Friendly.  I noticed that they were offering ''Fronions'' on the menu :-p that doesn't sound at all appetizing to me. My mother and sister couldn't make up their mind on what to have for desert.  My father and I told them {{{"You best make up your mind or the waitress won't come back until one of yinz goes to the bathroom."}}} and my father and I promptly ordered...receiving our ice-cream 5 minutes later, at which time my mother and sister were still deciding.  While we ate our ice cream in front of them they finally decided on the Frugle Fudge Sunday or something like that.  The waitress didn't come back for quite some time, and then they ordered their Sundays after we were already done with ours.  

!Delivering the Christmas Tree
Finally we took my sisters Christmas tree up to her apartment.  It was in a cardboard box so old that it looked like a bunch of pieces of cardboard held together by a piece of string. 

We also moved her bed so that it wouldn't face the cold outside wall.  And we moved the really cheap bookshelf she inherited from me from when I was in college.  The bookshelf almost collapsed (again) under the stresses of pushing it across the floor.  Someday I think it will collapse as we bought it at Value City for $15 dollars when I was in college.  I hope it doesn't just collapse while my sister is sleeping.  I wouldn't like that.  

So then we said good bye to my sister and we drove home.  EOF.
We didn't get too many trickers or treaters over here.  There was a Gisha Girl which I'm pretty sure only stuck around because she had an umbrella with her costume, and some kids creepy father that dressed as [[Rorschach|http://en.wikipedia.org/wiki/Rorschach_(comics)]] from The Watchmen.  Other than that we really didn't have that much on our front porch, which means that we have tons, tons of left over candy.  

I can hear some poor kid asking his father, "But Daddy!  I wanna go tricker-treating", the response to which of course might have been "Not now son!  The Phillies are in the World Series and I wanna watch the game!"

I really wanted those kids to get their riddlen-ridden-rear-ends to get their trick-er-treat on so we wouldn't have sooo much candy left.  I think they should re-enstate Tricker-treat to another night after the series is over.  
*[[That Roger Wilco Guy|http://www.nickawilliams.com/]]
*[[Making sure geolocation support stays on]]
Oh wtf man...

{{{
LF_ExtPriceOrd |= (*(Xnum *)LF->Get("SELL_QUANTITY_ORDERED") * *(Xnum *)LF->Get("PRICE"));
}}}

That's confusing...

c++decl
cdecl

Maybe these will eventually help!
{{{
<html>
	<head>
		<title>Javascript 1: Introduction to JS :: Lab 15, Project 2</title>
		<script type="text/javascript">
		<!--
			function generateATable()
			{
				tableContainer = document.getElementById("tableDiv");
				var tableElement = document.createElement("table");

				var trElement1 = document.createElement("tr");
				var trElement2 = null;



				var aaCell = trElement1.insertCell();
				var abCell = trElement1.insertCell(0);

				var textNodeAA = document.createTextNode("AA");
				var textNodeAB = document.createTextNode("AB");

				aaCell.appendChild(aaCell);
				abCell.appendChild(abCell);

				var baCell = trElement1.cells[0].cloneNode(FALSE);
				var bbCell = trElement1.cells[1].cloneNode(FALSE);

				var textNodeBA = document.createTextNode("BA");
				var textNodeBB = document.createTextNode("BB");

				trElement2 = trElement1.cloneNode(FALSE);

				baCell.appendChild(textNodeBA);
				bbCell.appendChild(textNodeBB);

				trElement2.appendChild(baCell);
				trElement2.appendChild(bbCell);

				tableElement.appendChild(trElement2);

				tableElement.insertBefore(trElement1, trElement2);

				tableContainer.appendChild(tableElement);
			}
		//-->
		</script>
	</head>
	<body>
		<div id="tableDiv">
			
		</div>
		<a href="javascript:generateATable()">Click here to Generate the Table</a>
	</body>
</html>
}}}
*[[The Mouse is Just Too Fast for Fading Transitions]]
*[[Asked a question|http://groups.google.com/group/tortoisesvn/topics]] on the Tortoise SVN mailing list about why the working copy on my thumb drive doesn't update the icons in the folder when I make a change to a file.
Looking into education for .NET:

Perice College - includes paying for books, software etc... 
.NET Programming - preqsites yes
1. VB.net 1   $1375.00 Fall -> $1435.00 (7-weeks long)
2. VB.net 2   $1375.00 Fall -> $1435.00
3. ASP.NET 3  $1375.00 Fall -> $1435.00

Carolen Stone
<span class="skype_pnh_print_container">215-670-9248</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +12156709248" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">215-670-9248</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>

A little steep wouldn't you say?
*[[Learned a thing of two about making Custom Modules for Joomla|Creating a Hello World Module for Joomla 1.5]]
>I've got to remember to answer [[this question|http://stackoverflow.com/questions/1412697/jquery-method-of-calculating-the-correct-offsetleft-of-an-element-in-a-table]] on StackoverFlow on Monday, as the people that gave me answers helped me figure it out.
*Received an answer to the question I asked [[yesterday|12 April 2009 - aleer]] on the Tortoise SVN mailing list:
{{{
Andrew,
 
Check the TortoiseSVN documentation under settings/icons overlays.  Tortoise
does not show icons by default on removable media, only on fixed drives.
You can modify this on the settings page.
 
Cheers,
 
Tom
}}}
It's Friday the 13th, but I'm trying not to pay attention to that today.  I bet there will be some really cheesy movies on this weekend! Joy!
*[[Making min-width work in IE6]]
*[[Drop.io Developer]]
*[[What ever happened to the pda?]]
*[[Nice new Site (Foley Business Forms)]]!
*[[Todo for foleybf.com]]
*[[Hmm I'll have to send this to my boss|http://headrush.typepad.com/creating_passionate_users/2006/03/how_to_be_an_ex.html]]
Hmm I was thinking...should a catalog really be made up of list items? {{{<li>}}}

Can list items contain tables?

I was thinking of laying out our new catalog at work using unordered lists instead of several layers of tables.

However each of those items in the catalog might contain tables with tabular data so a {{{<li><table>...</table></li>}}} would have to be valid.

*[[Question 1|http://doctype.com/valid-html-syntax-include-table-inside-list-item]]
*[[Question 2|http://doctype.com/best-method-laying-out-multicolumn-lists-css]]
*[[Question 3|http://doctype.com/laying-out-catalog-index-page-unordered-list]]
Went to a pre-conference thing at work today.  It was actually quite enjoyable.  Among the amusing quotes were:

>"When we were looking for a name for our company long ago when we had just started up, our main competition was a company called ''"Galaxy"''.  My son suggested that we name our company ''"Black Hole Systems"'', since black holes swallow up galaxies..."
>You have to be able to let things go. One of the curiosities of Wikipedia is that the most obsessed users always win. You can’t compete with someone who devotes hours every day to maintaining their pet topic, with scripts to protect it. This system, on some level, must work because if it didn’t Wikipedia would be permanently broken.
- [[Stackoverflow Blog|http://blog.stackoverflow.com/2009/04/podcast-49/]]

hmm interesting...really like that story about @codinghorror running down the street beating on the windows of a taxi that almost ran him over.  I remember being like that when I first became a programmer. It's at that point in your life that you realize that you need to learn some soft-skills.
[<img[http://farm3.static.flickr.com/2170/2116340024_c2baf6a92e_m.jpg]]''Added my resume in searchable-form to:''
*Dice.com
*Career Builder.com
*JobCircle.com

Went to [[http://www.ajb.org|www.ajb.org]], but wasn't too successful.  Need to call them and ask for some sort of identification number...
[[Image on Flickr|http://www.flickr.com/photos/leeand00/2116340024/]]
It's cold today...there was a big ice storm.
*[[Writing Documentation for Route 6 Radio]]
!Applied for Jobs At
+++[dice.com]
*Applied for 3 Postions
===<br/>
+++[Phone Calls Recieved]
*Rite Aid - ''Applied''
*Adminstrative Office of PA Courts - ''Applied''
*Evolution Staffing
*__Fidelity__
//(Check your email)//
===
*[[Syncing Files with SyncBack]]
*[[Micro / Nanofluidic Computing|http://www.rle.mit.edu/micronano/movies.htm]]
''Today''
*Saw alot of jobs on Dice today and so I perged all the old jobs I haven't applied for yet out of the database.  Also hotmail is not working today so I'm waiting for it to come back up, and when it does I'll send alot of resumes out.
Material generally isn't boring, it's just something you don't understand and therefore your brain wishes to ignore it at first by making it boring for you.

The best way I've found to read something that I find dry is to use to tool like [tiddlywiki][1] to go over the material.   

Begin by downloading the [tiddlywiki][1], and familiarizing yourself with how to use it:

 - [List of Tiddlywiki YouTube Videos][2]

Now while you are reading the *dry material* make a new [tiddler][3] in your [tiddlywiki][1] and turn any words that you don't understand into new [tiddlers][3] where you can write the meaning of the unknown term and reference it again when it comes back up in the text later.


Let me give you an example.

If you are reading an article/textbook and it says something like:



  [1]: http://www.tiddlywiki.com/
  [2]: http://www.youtube.com/results?search_query=tiddlywiki&search_type=&aq=f
  [3]: http://www.tiddlywiki.com/#Tiddler
*[[Facebook the evil productivity sucking blackhole that weezels itself into other logins]]
*[[Setting up MIA on an OpenWRT Router]]
*[[Mother had me look up washers and dryers today to figure out if a top-loader or a front-loader washing machine was better|Washing Machine Ordeal]]
!College Job Search (Gathering)
I've decided to start looking for a job at a college.  I started off this-morning looking at CMU, which had about 3 potential jobs listed.  

Next I headed out to http://maps.google.com/ zoomed in over PA, and typed in {{{college or university}}}.

''There appear to a whole bunch of colleges''

Found out you can execute Groovy Scripts inside of the beta version of freemind...oh I'm gonna use this!
*[[Unzipping Files in C++]]
*[[Grouping Project Related Stackoverflow Questions Together Using Delicious|Grouping Project Related Stackoverflow Questions Together Using Delicious - Tag Heirachies]]
*[[Searching Tags/Users with Stackoverflow]]
After trousing about the coffee shops in Lancaster, my blog has a new look!
*[[mod_rewrite.c in Wordpress]]
*[[Augmented Reality|http://interactive.digitalpictures.com.au/?p=392]] - Wow I have got to try this out when I get home!
Working on James's site again today, today he wants me to implement several things and here's a list:
*[[Hotel Finder Application|Hotel Finder Application - Route 6 Radio]]
*Wherever rout six crosses the western border and the easter boarder of PA.
*Pictures BIO's on their own page  Lower lefthand side. "What about James and Jeff?)
*===Can get a website off of route 6 radio James@route jeff@ shoot to regular email===
*Make my own profile...Picture of me...interview etc..
*30 Day Time limit...
*
''TekSystems''
Replied to an email from TekSystems from a Mr. Anju Bhalla.
*[[Setup a profile at CyberCoders.com|Sites with My Resume]]
*[[New Job Search Tip|Job Search Tips]] - [[Filling in Those Pesky Text Only Fields with Tables]] 
*[[Getting Some Comments On This Blog]]
*[[Recieved an Email from Object CTalk|Questions Answered for  Object CTalk]]
*[[Got Mail Merge to Work in OOo]]
*[[Tested Myself on the Module 1 SL Quiz|Test: SL Ivory Tower Library of Prims Module 1]]
*[[Entered the Table of Contents into the Marriage Wiki|Marriage Wiki]]
+++[+Applied to Susquehanna.net]
Okay that's all nice and done with...that only took the whole morning! hahah!  Oh well..hopefully they'll pick me up, it sounded like a fun job that I would enjoy.
===

+++[+Called back Sabba]
Sabba said that not riding on an air plane would not be a problem and that they are still considering me for the position, but that the hiring manager still needs to get well.
===

+++[+Received reply from resolutionsconsulting]
#Called J.Y. to confirm date was okay.
#Emailed back resolutionsconsulting to let them know that the date would be fine.
===

+++[+The Matlen Silver Group]
The Matlen Silver Group called me about a build engineer position, and I "email-faxed" them a consent forum for submitting my resume to GSI Commerce.
===
*Recreate the [[blueprint sample page|http://www.blueprintcss.org/tests/parts/sample.html]] and [[blueprint grid tests|http://www.blueprintcss.org/tests/parts/grid.html]] using webby and compass.
*[[DeDuplicating Records in a Third Party Database]]
*[[The Death Of A Coffee Substitute]]
Well today I found a webcast to watch on .NET and I also found a university to learn .NET at.  I'm here sitting outside hoping it doesn't rain before the webcast is over...
*[[GTD|Get Things Done]]
*[[Looking for ]]
Well not much on the job front today.

But tommarrow I need to warm my eyes up in the morning, before I start, that should get me going!
*[[The Tiddlywiki Tab Mystery]]
*[[PhraseExpress Setup]]
*[[What's wrong with Windows]]
Well my hard drive at work crashed two days ago and now I'm trying to pickup the pieces and get my computer back to the state it was in eariler.  I think I may see about using that new feature of Windows Vista to see if I can back it up that way, when I'm done.
*[[Started Setting up my .NET Development Environment|Setting up .NET]]
*[[Getting Control of your Browser Windows with Session Manager]]
>The SQL Server feature 'RS_Server_Adv' is not in a supported state for repair, as it was never successfully configured. Only features from successful installations can be repaired. To continue, remove the specified SQL Server feature.

>The SQL Server feature 'Analysis_Server_Full' is not in a supported state for repair, as it was never successfully configured. Only features from successful installations can be repaired. To continue, remove the specified SQL Server feature.

Just had to uninstall some of the features
*[[Westell 6100 Config]]
*[[DMZ Setup]]
*[[Getting Some Comments On This Blog]] <- Finished that up so now you can post some comments!
*[[Recieved Reply From JavaRanchSaloon]] (About the transfer of setting from one project to another.)
*Received a call from Human Capital, stating that they will probably have some opportunities in the coming months.
*Found a cool site where you can discuss things with other people who are in IT.
**[[http://www.ittoolbox.com]]
*Received a tip from a message board, and needed to update it on my resume, so I started re-posting it online (so far I've got):
**Jobster.com
*[[Found a Great way of deploying with git]]
Ah!!! Stupid laptop!!!!  I opened the case this morning and the thing was way way hot!  It turned on in the case again.  I need to find a way to stop it from doing this, or I'm not going to have a laptop any more!  I ran a diagnostics test on it, and everything seems to be fine, but it smells like burning!  That doesn't seem to be a good sign.  
*[[Testing With JMeter]]
Need a new job.
*[[Geo-RSS]]
''Things I studied Today''
*[[How to Avoid Burnout|Avoiding Burn Out - 3 December 2007]]
I made a dumb comment [[in a blog|http://lehighvalley.tumblr.com/post/62822149/plate-face-foiled]] about some guy that lives in my town and robs stores with a paperplate attached to his face...decieded may I should take it back, he might live here...guy who owns the blog wasn't home, well hopefully if he robs stores with a paperplate on his face he won't be reading this on the Internet.  But there is the Blue Rhino thing so I'm still kinda worried....

Anyway I'm just trying to get a track-back, can I getta track-back?
[[http://lehighvalleyand20something.disqus.com/plate_face_foiled/trackback/|http://lehighvalleyand20something.disqus.com/plate_face_foiled/trackback/]]
*[[Removing Proprietary Attributes from html tags in Awful 3rd Old Third-Party HTML Code Using Regular Expressions]]
*[[Found Great Horizontal Navigation Tutorial]]
*[[Its probably about time I Start a CSS Wiki]]
*[[Creating a Windows VIM Image]]
*[[Choosing the Right LCD Monitor to Buy]]
*[[Geo-RSS]]
*[[Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
*
''Attended''
*[[Marriage Class]]
*Applied to two jobs today
**Entry Level Web Developer at D&H Distributing
**Web Developer at Lancaster Newspaper Inc.
*Sent out 3 Thank you Notes!
*[[Interview with Jason Fried of 37 Signals]]
*[[Building a computer with my boss]]
*[[Looking into Zope - Apache - SSL]]
*[[Math is always faster than doing something procedural]]
''Applied for five jobs''
Today I received an email from Vanguard:
+++[Recieved the following email:]
{{{Good afternoon,
 
I am a Recruiter with Vanguard and I recently received your resume in
consideration of our Technology Leadership Program.  For further
information about the program, please use the following link to view the
job description:
 
https://careers.vanguard.com/pljb/vanguard/vgcareers/applicant/VG/students_it.shtml
 
Only U.S. citizens and lawful permanent residents will be considered for
this program.  Also, a cumulative GPA of 3.0 or higher is preferred.  The
program is open to graduating seniors and professionals with 0-2 years of
work experience.  If you meet these requirements and are interested in the
program and employment with Vanguard (located in Valley Forge, PA), please
take the following steps to schedule a phone interview with one of my
colleagues:
1.  Log on to vanguardcareers.com and create a profile.
2.  Respond back to me with your availability for the next few weeks so
that we may schedule some time to speak further about your interests.
 
I look forward to hearing back from you and discussing the exciting
opportunities waiting for you at Vanguard.
 
Best regards,
Tracy Schatzel
Recruiter
Vanguard
Phone:  <span class="skype_pnh_print_container">(610) 503-5485</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +16105035485" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">(610) 503-5485</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>
Email:  Tracy_Schatzel@Vanguard.com
}}}
===

I really need to get on this tomorrow, and give them a call as I already have a profile on their website.
*[[Looking into CSS Frameworks|Compass and Webby]] and [[Webby|Compass and Webby]] Today.
*[[Sent my application out to Penn State]]
*[[A Chorded Keyboard?]]
*[[Converting IPv4 addresses to IPv6 Equivalent]]
[[Mock Video Interview]]
*[[The ever so useful SQL INSERT IN and UPDATE IN]]
Today I finished creating a tiddlywiki of the [[documentation of the Webby project|http://webby.rubyforge.org/user-manual/]] to [[provide a quick reference to it's users|http://groups.google.com/group/webby-forum/browse_thread/thread/1509d952c604ae74]].  Hopefully somebody will find this useful, and not just me. :-)

Next I need to continue reading/wiki-ee-ing the compass manual, maybe when I'm done they'll want a tiddlywiki manual too! :)

  *later...*

Well they [[seemed to like it|http://groups.google.com/group/webby-forum/browse_thread/thread/1509d952c604ae74]].
*''.NET Course (And be sure to post Gov's phone #)''
**''TODO:'' See if anyone on Craigs List wants to take the .NET course at RACC
**''TODO:'' See if anyone on Facebook's Reading network wants to take the .NET course this summer.
The new internship seems to be swimming along.
My weekend is going great!  Last night I watched a RiffTrax of Jurassic Park with my sister and my Dad, (my mother is in N.J. for the weekend).  Then today my Dad and I went to take my grand parents to Hosses' (Hoss's?) and then off to the grocery store.  That normally would be kinda boring, but I got to try out the new GPS I just got on the way down!  

I was supposed to meet my Aunt in the parking lot of the Giant while my Dad took my grandparents grocery shopping;  she called me on the cellphone, and told me to wait out in front of the store for her.  I waited out in front of the store, and then she called me up and said she was in the parking lot.  

Unfortunately, she was at the wrong Giant.  So she never got to give me the key to get into her house.  

So we had to meet my Aunt at a wedding reception.  

Oh, the reason I needed to get into her house was, that, I needed to install some software I wrote to help my cusin Nickolas find a job; he used to work at a pet store, and they recently went out of business...making my Aunt and Uncles house looking...a bit like a pet store.  

Yeah, so after we were done at the grocery store (I got a great deal on this hair gel, normally it's 13.00 dollars but this place had it for three)  

After we left the grocery store I went into the reception, completely under-dressed for the occasion and got the key from my Aunt.

Then we hung out in perverbal zoo that is my Aunt's place, and I installed the software, while my grandparents and father waited.

We dropped off my grandparents and now I'm home.  So that's been the weekend so far...pretty good if you ask me.
*[[HTML5 Headers: The Mystery Solved]]
Hanging out at Crave today...
*Sent a resume to 
+++[Calling...]
#Jan 7th - Mike Roberts - Corprate Staffing Services -  <span class="skype_pnh_print_container">610-771-1084</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +16107711084" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">610-771-1084</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>


===
#Jan 7th - Java Developer - 1 Year contract - 
#Java Developer <span class="skype_pnh_print_container">570-894-3630</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +15708943630" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">570-894-3630</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span> ????
+++[Called...she's calling me back]
#Jan 7th - Lauren Spary IT Staffing Firm in Philly - <span class="skype_pnh_print_container">215-209-0100</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +12152090100" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">215-209-0100</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>
===<br/>
+++[Called...]
#Jan 7th - Randy McKay - Pyramid Consulting  <span class="skype_pnh_print_container">724-934-0158</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +17249340158" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">724-934-0158</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>
Stated something about jobs in Pittsburgh (with Fedex Ground) , and in Camp Hill.
===<br/>
+++[Called...]
#Bill Blake Sabba Software - Technical Consultant - <span class="skype_pnh_print_container">781-994-1066</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +17819941066" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">781-994-1066</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span>

''eLearning'' - 50% Travel...

Middleware - Platform looks up at our application and 
===
[[article link|http://www.codeproject.com/KB/cpp/pointers.aspx]] - [[article author|http://www.codeproject.com/script/Membership/Profiles.aspx?mid=21]] - [[quiz links|A Beginner's Guide to Pointers: Quizzes]]
!What are pointers?
Pointers are basically the same as any other variable.  However, what is different about them is that intead of containing actual data, they contain a pointer to the memory location where information can be found. This is a very important concept.  Many programs and ideas rely on pointers as the basis of their design, linked lists for example.

!Getting Started
How do I define a pointer?  Well, the same way as any other variable, except that you add an asterisk before its name.  So, for example, the following code creates two pointers, both of which point to an integer:

{{{
int *pNumberOne;
int *pNumberTwo;
}}}

Notice the {{{p}}} prefix in front of the two variable names?  This is a convention used to indicate that the varuiable is a pointer.  Now, let's make these pointers actually point to something.

{{{
pNumberOne = &some_number;
pNumberTwo = &some_other_number;
}}}

The {{{&}}} (ampersand) sign should be read as //"the address of"// and causes the address in memory of a variable to be returned, instead of the variable itself.  So, in this example, {{{pNumberOne}}} is set to equal the address of {{{some_number}}}, so {{{pNumberOne}}} now points to {{{some_number}}}.

Now if we want to refer to the address of {{{some_number}}}, we can use {{{pNumberOne}}}.  If we want to refer to the value of {{{some_number}}} from {{{pNumberOne}}}, we would have to say {{{*pNumberOne}}}.  The {{{*}}} dereferences the pointer and should be read as "the memory location pointed to by," unless in a declaration, as in the line {{{int *pNumber}}}.

!What we've learned so far: An Example
Phew! That's alot to take in.  I'd recommend that if you don't understand any of those concepts, to give it another read through.  Pointers are a complex subject and it can take a while to master them.  Here is an example that demonstrates the ideas discussed above.  It is written in C, without the C++ extensions.  

{{{
#include <stdio.h>

void main()
{
   // declare the variables:
   int nNumber;
   int *pPointer;

   //now, give a value to them:
   nNumber = 15;
   pPointer = &nNumber;

   // print out the value of nNumber:
   printf("nNumber is equal to : %d\n", nNumber);

   // now, alter nNumber through pPointer:
   *pPointer = 25;

   // prove that nNumber has changed as a result of the above by
   // printing its value again:
   printf("nNumber is equal to : %d\n", nNumber);
 
}
}}}

!A Trap
See if you can spot the fault in the program below:

{{{
#include <stdio.h>

int *pPointer;

  void SomeFunction();
  {
    int nNumber;
    nNumber = 25;

    // make pPointer point to nNumber:
    pPointer = &nNumber;
  }
  void main()
  { 
     SomeFunction(); // make pPointer point to something

     // why does this fail?
     printf("Value of *pPointer: %d\n", *pPointer);
  }
}}}

>I'm going to guess that this fails because when {{{SomeFunction()}}} ends, {{{nNumber}}} was declared in the local scope of {{{SomeFunction()}}} and no longer exists when it is called to be printed by {{{*pPointer}}}.

This program firstly calls the {{{SomeFunction}}} function, which creates a variable called {{{nNumber}}} and then makes the {{{pPointer}}} point to it.  Then, however, is where the problem is.  When the function leaves, {{{nNumber}}} is deleted because it is a local varaiable. Local variables are alaways deleted when the exection leaves the block they were defined in.  This means that when {{{SomeFunction}}} returns to {{{main()}}}, the variable is deleted.  So {{{pPointer}}} is pointer at where the variable used to be, which no longer belongs to this program.  If you do understand this, it may be wise to read back over on local and global variables, and on scope.  This concept is also important.

So, how can the problem be solved?  The answer is by using a technique known as [[dynamic allocation|Dynamic Allocation]].  Please be aware that this is different between C and C++.  Since most developers are now using C++, this is the dialect that the code below is using.


!Dynamic Allocation
[[Dynamic Allocation]] is perhaps the key to pointers.  It is used to allocate memory without having to define variables and then make pointers to point to them.  Although the concept may appear confusing, it is really simple.  The following code demonstrates how to allocate memory for an integer.
{{{
int *pNumber;
pNumber = new int;
}}}

The first line declares the pointer, {{{pNumber}}}.  The second line then allocates memory for an integer and then makes {{{pNumber}}} point to this new memory.  Here is another example, this time using a {{{double}}}:

{{{
double *pDouble;
pDouble = new double;
}}}

The formula is the same every time, so you can't really fail with this bit.  What is different about dynamic allocation, however, is that the memory you allocate is not deleted when the function returns, or when the execution leaves the current block.  So, if we rewrite the above example using dynamic allocation, we can see that it works fine now:

{{{
#include <stdio.h>

int *pPointer;

void SomeFunction()
{
	// make pPointer point to new integer

	pPointer = new int;
	*pPointer = 25;
}

int main()
{
	SomeFunction();

	printf("Value of *pPointer: %d\n", *pPointer);
	return 0;
}
}}}

Read through and compile the above code sample.  Make sure you understand why it works.  When {{{SomeFunction}}} is called, it allocates some memory and makes {{{pPointer}}} point to it.  This time, when the function returns the new memory is left intact, so {{{pPointer}}} still points to something useful.  That's it for dynamic allocation!  Make sure you understand this, and then read on to learn about the fly in the ointment, and why there is still a serious error in the code above.

!Memory Comes, Memory Goes
There's always a complication and this one could become quite serious, although, it's very easy to remedy.  The problem is that although the memory that you allocate using dynamic  allocation is conveniently left intact, it actually never gets deleted automatically.  That is, the memory will stay allocated until you tell the computer that you've finished with it.  The upshot of this is that if you ddon't tell the computer that you've finished with the memory, it will be wasting space that other applications or other parts of your application could be using.  This eventually will lead to a system crash through all the memory being used up, so it's pretty important.  Freeing the memory when you've finished with it is very simple.

{{{
delete pPointer;
}}}

That's all there is to it.  you have to be careful, however, that you pass a valid pointer, i.e. that is a pointer that actually points to some memory you've allocated and not just any old rubbish.  Trying to {{{delete}}} memory that's already been freed is dangerous and can lead to your program crashing.  So here's the example again, updated this time so it doesn't waste any memory:

{{{

#include <stdio.h>

int *pPointer;

void SomeFunction()
{
	// make pPointer point to new integer

	pPointer = new int;
	*pPointer = 25;
}

int main()
{
	SomeFunction();

	printf("Value of *pPointer: %d\n", *pPointer);
        delete pPointer;
	return 0;
}
}}}

One line difference is all it took, but this line is essential.  If you don't delete the memory, you get what is known as a "memory leak", where memory is gradually leaking away and can't be reused unless the application is closed.

!Passing Pointers to Functions
The ability to pass pointers to functions is very useful, but very easy to master.  If we were to make a program that takes a number and adds five to it, we might write something like the following:

{{{
#include <stdio.h>

void AddFive(int Number);

void AddFive(int Number)
{
	Number = Number + 5;
}

int main()
{
	int nMyNumber = 18;

	printf("My original number is: %d\n", nMyNumber);
	AddFive(nMyNumber);

	printf("My new number is: %d\n", nMyNumber);

	return 0;
}
}}}

However the problem with this is that the {{{Number}}} referred to in {{{AddFive}}} is a copy of the variable {{{nMyNumber}}} passed to the function, not the variable itself.  Therefore, the line {{{Number = Number + 5}}} adds five to the ''copy'' of the variable, leaving the original variable in {{{main()}}} unaffected.  Try running the program to prove this.

To get around this problem, we can pass a pointer to where the number is kept in memory to the function, but we'll have to alter the function so that it expects a pointer to a number, not a number.  To do this, we change {{{void AddFive(int Number)}}} to {{{void Addfive(int *Number)}}}, adding the asterisk.  Here is the program again, with the changes made.  Notice that we have to make sure we pass the address of {{{nMyNumber}}} instead of the number itself?  This is done by adding the {{{&}}} sign, which (as you recall) is read as "the address of".

{{{
#include <stdio.h>

void AddFive(int *Number)
{
	*Number = *Number + 5;
}

int main()
{
  int nMyNumber = 18;

  printf("My original number is %d\n", nMyNumber);
  AddFive(&nMyNumber);
  printf("My original number is %d\n", nMyNumber);
  return 0;
}
}}}
Try coming up with an example of your won to demonstrate this.  Notice the importance of the {{{*}}} before {{{Number}}} in the {{{AddFive}}} function?  This is needed to tell the compiler that we want to add five to the number pointed to by the variable {{{Number}}}, rather than add five to the pointer itself.  The final thing to note about functions is that you can return pointers from them as well, like this:

{{{
int * MyFunction();
}}}

In this example, {{{MyFunction}}} returns a pointer to an integer.

{{{
#include <stdio.h>

int * AddFive();

int* AddFive()
{
  int *plNumber = new int; // Dynamically allocated so that it 
                           // survives the end of the function call.
  *plNumber = 5;

  return plNumber;
}

int main()
{
   int *pNumber;

   pNumber = AddFive();
   printf("My new number is: %d\n", *pNumber);

   return 0;
}
}}}

!Pointers to Classes
There are a couple of other caveats with pointers, one of which is structures or classes.  You can define a class as follows:

{{{
    class MyClass
    {
    public:
	int m_Number;
	char m_Character;
    };
}}}

Then you can define a variable of type {{{MyClass}}} as follows:
{{{
MyClass thing;
}}}

You should already know this.  If not, try reading up on this area.  To define a pointer to {{{MyClass}}}, you would use:

{{{
MyClass *thing;
}}}

...as you would expect.  Then you would allocate some memory and make this pointer point to the memory:

{{{
thing = new MyClass;
}}}

This is where the problem comes in: how then would you use this pointer?  Well, normally you would write' {{{thing.m_Number}}}, but you can't with a pointer because {{{thing}}} is not a {{{MyClass}}}, but a pointer to it.  So, {{{thing}}} itself does not contain a variable called {{{m_Number}}}; it is the structure that it points to that contains {{{m_Number}}}.  Therefore we must use a different convention.  This is to replace the "{{{.}}}" (dot) with a "{{{->}}}" (dash followed by a greater than sign).  An exampel showing this below:
{{{
class MyClass
{
public:
	int m_Number;
	char m_Character;
};

void main()
{
	MyClass *pPointer;
	pPointer = new MyClass;

	pPointer->m_Number = 10;
	pPointer->m_Character = 's';

	delete pPointer;
}
}}}

!Pointers to Arrays
You can also make pointers that pint to arrays.  This is done as follows:
{{{
int *pArray;
pArray = new int[6];
}}}
This will create a pointer, {{{pArray}}}, and make it point to an array of six elements.  The other method, not using dynamic allocation, is as follows:

{{{
int *pArray;
int MyArray[6];
pArray = &myArray[0];
}}}

Note that instead of writing {{{&MyArray[0]}}}, you can simply write {{{MyArray}}}.  This, of course, only applies to arrays and is a result of how they are implemented in the C/C++ language.  A common pitfall is to write {{{pArray = &MyArray}}}, but this is incorrect.  If you write this, you will end up with a pointer to a pointer to an array (no type), which is certainly not what you want.

!Using Pointers to Arrays
Once you have a pointer to an array, how do you use it?  Well, let's say you have a pointer to an array of {{{int}}}s.  The pointer will initially point to the first value in the array, as the following example shows:

{{{
#include <stdio.h>

int main()
{
	int Array[3];
	Array[0] = 10;
	Array[1] = 20;
	Array[2] = 30;

  	int *pArray;
	pArray = &Array[0];

	printf("pArray points to the value %d\n", *pArray);

	return 0;
}
}}}

To make the pointer move to the next value in the array, we can say {{{pArray++}}}.  We can also, as some of you probably guessed by now, say {{{pArray + 2}}}, which would move the array pointer on by two elements.  The thing to be careful of is that you know what the upper bound of the array is (3 in this example), because the compiler cannot check that you have not gone past the end of array when you are using pointers.  You could easily end up crashing the system that way.  Here is the example again, this time showing the three values that we set:

{{{
#include <stdio.h>

int main()
{
	int Array[3];
	Array[0] = 10;
	Array[1] = 20;
	Array[2] = 30;

	int *pArray;
	pArray = &Array[0];

	printf("pArray points to the value %d\n", *pArray );
	pArray++;
	printf("pArray points to the value %d\n", *pArray);
	pArray++;
	printf("pArray points to the value %d\n", *pArray);

	return 0;
}
}}}

You can also subtract values, so {{{pArray - 2}} is 2 elements from where {{{pArray}}} is currently pointing.  Make sure, however, that you add or subtract to the pointer and not its value.  

>This kind of manipulation using pointers and arrays is most useful when used in loops, such as the for or while loops.

Note also that if you have a pointer to a value, e.g. {{{int* pNumberSet}}}, you can treat it as an array.   For example, {{{pNumberSet[0]}}} is equivalent to {{{*pNumberSet}}}; similarly, {{{pNumberSet[1]}}} is equivalent to {{{*(pNumberSet + 1)}}}.

{{{
#include <stdio.h>

int main()
{
   int *pNumberSet;
   pNumberSet = new int[6];

   for(int i = 0; i < 6; i++)
   {
     pNumberSet[i] = i;

     printf("pNumberSet[%d]: %d\n", i, *(pNumberSet + i));
   }

  
  

   return 0;
}
}}}

One final word of warning for arrays is that if you allocate memory using {{{new}}}, as in the following example:

{{{
int *pArray;
pArray = new int[6];
}}}

...it must be deleted using the following:

{{{
delete[] pArray;
}}}

Notice the {{{[ ]}}} after {{{delete}}}.  This tells the compiler that it is deleting a whole array and not just a single item.  You must use this method whenever arrays are involved; otherwise, you will end up with a memory leak.

!Common Questions and FAQ
''Q:'' Why do I get ''"symbol undefined"'' errors on {{{new}}} and {{{delete}}}?
''A:'' This is most likely caused by your source file being interpreted by the compiler as being a plain C file.  The {{{new}}} and {{{delete}}} operators are a new feature of C++.  This is usually remedied by ensuring that you are using a {{{*.cpp}}} extension on your source code files.

''Q:'' What's the difference between {{{new}}} and {{{malloc}}}?
''A:'' {{{new}}} is a keyword only present in C++ and is now the standard way (other than using Windows' memory allocation routines) to allocate memory.  You should never use {{{malloc}}} within a C\C++ application unless absolutely necessary.  Because {{{malloc}}} is not designed for the example of the problems that can arise.  As a result of the problems that arise from the use of {{{malloc}}} and {{{free}}}, and __because they are now for all intents and purposes obsolete__, they are not discussed in any detail in this article.  I would discourage their use whenever possible.

''Q:'' Can I use {{{free}}} and {{{delete}}} together?
''A:'' You should free memory with the equivalent routine to that used to allocate it.  For instance, use {{{free}}} only on memory allocated with {{{malloc}}}, {{{delete}}} only on memory allocated with {{{new}}} and so on.
>''leeand00:'' 
>>These are some links to some quizzes I made on the article [[A Beginner's Guide to Pointers|http://www.codeproject.com/KB/cpp/pointers.aspx]] written by [[Andrew Peace|http://www.codeproject.com/script/Membership/Profiles.aspx?mid=21]]
#[[Getting Started (1)|http://quizlet.com/set/322852/]]
#[[Dynamic Memory Allocation (2)|http://quizlet.com/set/323393/]]
#[[Passing variables to Functions (3)|http://quizlet.com/set/323679/]]
#[[Pointers to Classes (4)|http://quizlet.com/set/323702/]]
#[[Pointers to Arrays (5)|http://quizlet.com/set/324221/]]
My friend NAT contacted me today and told me about a [[project he built|http://joy2chord.sourceforge.net/]], a chorded keyboard.  I've never heard of such a thing until today, but apparently it is a way to type without so many keys, instead you type using combinations of keys allowing you to type one handed.  NAT says he built his for only $15.  Interesting, now if I could only build one for my Palm TX.
Sure, by now I'd think that everybody already knows how to do this, but something tells me it isn't true.

So could anybody tell me why there aren't a whole lot of C++ programmers left?  Might it have something to do with the fact that it's such a pain in the rear to setup your development environment?  I come from the land of Java, I'm used to things like code completion, and documentation...In Linux its easy to get such things for C++, but in Windoze, unless you've got a nice $800 M$ product, you can't seem to do anything. 

So far I've found a simple VIM Macro that worked for about a half hour and then died, because it won't display the dialog that asks for the new function name.

Wholey Freescrollize [[Strong Bad]]!  Your source code is the length of an aircraft carrier!

[[Setting the Options for Simian|http://www.redhillconsulting.com.au/products/simian/]]
{{{
C:\Users\XETEX\Desktop\simian1\bin>java -jar simian-2.2.24.jar -language=c -thre
shold=100 -ignoreVariableNames -ignoreIdentifiers -ignoreLiterals  "C:\somesrc.cpp"
}}}
''Command Input''

{{{
Similarity Analyser 2.2.24 - http://www.redhillconsulting.com.au/products/simian/index.html
Copyright (c) 2003-08 RedHill Consulting Pty. Ltd.  All rights reserved.
Simian is not free unless used solely for non-commercial or evaluation purposes.

{failOnDuplication=true, ignoreCharacterCase=true, ignoreCurlyBraces=true, ignoreIdentifierCase=true, 
ignoreIdentifiers=true, ignoreLiterals=true, ignoreModifiers=true, ignoreStringCase=true, 
ignoreVariableNames=true, language=C, threshold=100}

Found 153 duplicate lines in the following files:

 Between lines 590 and 918 in C:\somesrc.cpp

 Between lines 203 and 530 in C:\somesrc.cpp

Found 165 duplicate lines in the following files:

 Between lines 442 and 802 in C:\somesrc.cpp

 Between lines 428 and 789 in C:\somesrc.cpp

Found 636 duplicate lines in 4 blocks in 1 files

Processed a total of 505 significant (1221 raw) lines in 1 files

Processing time: 0.109sec
}}}
''Command Output''
Experts at this company enjoy working with a wealth of new technologies, software, methods and tools to turn business strategies into results
/***
!Metadata:
|''Name:''|AddFeaturesPlugin|
|''Description:''|Plugin used to compare features of various products. |
|''Version:''|0.0.1|
|''Date:''|Mar 25, 2012|
|''Source:''|http://sourceforge.net/project/showfiles.php?group_id=150646|
|''Author:''|Andrew J. Leer (leeand00(at) hotmail(dot) com)|
|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|
|''~CoreVersion:''|2.0.11|
|''Browser:''|Firefox 1.5+; InternetExplorer 6.0|

!Syntax:

!Revision History:
|''Version''|''Date''|''Note''|
|0.0.1|Mar 25, 2012|Yup.|

!Code section:
***/
//{{{
config.options.theTitle="FeaturesAllDigitalSolutionProvider";

config.macros.addfeaturesplugin = {
  modifierPressed: false
};

config.macros.addfeaturesplugin.displayFeaturesAll = function() {

		if(store.getTiddler(config.options.theTitle))
			fields = null;

story.displayTiddler("top", config.options.theTitle, null, true, null, null, true);
// DEFAULT_EDIT_TEMPLATE
};

config.macros.addfeaturesplugin.editFeaturesAll =  function() {
    config.commands.editTiddler.handler(null, null,config.options.theTitle);
};

config.macros.addfeaturesplugin.bringUpAndEdit = function(dasArgs) {
      console.log("bringUp");
      config.macros.addfeaturesplugin.displayFeaturesAll();
      config.macros.addfeaturesplugin.editFeaturesAll();
};

config.macros.addfeaturesplugin.keyDown = function(dasArgs) {
  console.log(dasArgs.keyCode);
  if(dasArgs.keyCode == 91) { /* Start menu button */
     console.log("startmenu key down");
     config.macros.addfeaturesplugin.modifierPressed = true;
  }

  if(config.macros.addfeaturesplugin.modifierPressed && 
     dasArgs.keyCode == 71) { /* g key */
      console.log("g key down");
      config.macros.addfeaturesplugin.bringUpAndEdit();
      config.macros.addfeaturesplugin.modifierPressed = false;

      return true;
   }
  return false;
};

config.macros.addfeaturesplugin.keyUp = function(dasArgs) {
  if(dasArgs.charCode == 91) {
     config.macros.addfeaturesplugin.modifierPressed = false;
  }
};

addEvent(document, "keydown", config.macros.addfeaturesplugin.keyDown);
addEvent(document, "keyup", config.macros.addfeaturesplugin.keyUp);
//}}}
!Adding a New Network

Say that you've moved your laptop / development machine to another location where there is a different wifi network with different settings.  What to do?  Well as we did eariler you're going to need to find out what the settings are in this new location.  

The first thing you will need to do is cut a new branch in our git repository since we don't want the settiings from the other network overwritten.  

{{{
git checkout -b <new-network-name>
}}}

Running a {{{git status}}} at this point will confirm that  

vim # changes....
sudo ./updateConfiguration
vim # changes...
sudo ./updateConfiguration
#until it works if you don't know what you're doing...
git commit
}}}



[[edit|Adding a New Network - Network Management - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
!!Local Setup of Apache using Lamp

<<tabs "ewqrqwgvsa2342"
"4.2.1" "httpd.conf" "httpd.conf - Adding a Virtual Host to Apache - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"4.2.2" "virtual-host config file" "virtual-host config file - Adding a Virtual Host to Apache - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
>>

[[edit|Adding a Virtual Host to Apache - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
!!Making dns-names for the virtual hosts on our web-server...
After it is all setup and you want to add additional sites to your development environment, 

Each record in the {{{dnsmasq.conf}}} consists of the form...

{{{
address=/<virtual-hostname>.<suffix>/<ip-address>
ptr-record=<virtual-hostname>.<suffix>,<ip-address>
}}}

And it can even refer to other hosts provided you use their ip

[[edit|Adding dns names to dnsmasq - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
     I've been off of coffee for some time now, but yesterday I gave in and had a shot of espresso in my Chi-tea because I just couldn't get going!  

    So then in due fashion with back when I used to drink coffee to keep going I went out and bought a bunch of exercise equipment (hey! there was a sale!) oh and a bicycle helmet!  Then I came home assembled the exercise equipment and, exercised for a good while.  

Soon I found myself in bed, unable to sleep, thinking to myself I had too much caffeine today...and now I can't stop!

    So I stayed awake and read up on the wonders of coffee.  I came across an article on how coffee causes increased neural activity soon after consumption.  

  "Hmm that's about right...", I thought to myself, "When I woke up thismorning I couldn't get going for about two hours!", I though some more..."Then when the barista talked me into having a shot of espresso in my Chi-tea, I was productive for the rest of the day!", which is great of course, unless you plan on sleeping.  

   I though back even further, "last time I drank any coffee I was having withdrawl symptoms, because it seemed no matter what I did, I just couldn't get enough caffeine to squeeze another drop of energy out of me".

   Shortly there after the coffee stopped working, I went though awful withdrawl symptoms, I had headaches for about a month.  I had practically no energy.


*''Ginsing''
**Organic Plum Passion - Harney &amp; Sons
!A Problem

	Since I started attending the blogosphere, I've never set on using a single place for all of my blog entries.  Copying and pasting the entries everywhere becomes very tedious and time consuming, making sure that every entry is on every page...it was becoming more trouble than it was actually worth. 

	So today I was speaking with [[a priest|http://www.facebook.com/profile.php?id=502920863]] from my Church, who seemed to have a similar problem.  Fr. wants to reach the kids using a Youth Group website for our Church.  Unfortunately all the kids now days hangout on multiple social networking sites, ([[MySpace|http://www.myspace.com]], [[Facebook|http://www.facebook.com]]).  All of these sites have a common place for the youth to meet, which are usually referred to as ''groups''.  Unfortunately to keep all of these groups up to date, you have to go into each social networking sites and update their groups one at a time.  A time consuming operation to say the least.  

So both of us have a similar problem...

!A Solution to Both Problems
	Well the intelligent folks on the web have already come up with a solution to this problem...enter [[RSS Feeds|RSS Feed]].  

<<tiddler "RSS Feed">>

	Now what this all means is that if you are posting content on your blog, you only have to enter that content once, because the RSS Aggregators on each of the sites you want to display the content on pick up your changes and display them.
I think the time has come to discuss an important distinction.  The distinction between [[pleasure]] and [[enjoyment]].

!Pleasure
<<tiddler "pleasure">>

!Enjoyment
<<tiddler "enjoyment">>

[[enjoyment]] [[pleasure]]
Background: #ddff88
Foreground: #000
PrimaryPale: #bbee66
PrimaryLight: #aa0033
PrimaryMid: #440000
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #99cc00
SecondaryMid: #db4
SecondaryDark: #440000
TertiaryPale: #bbee66
TertiaryLight: #EEC591
TertiaryMid: #440044
TertiaryDark: #000
/***

!Metadata:

|''Name:''|ArchivedTimeline|

|''Description:''|Timeline archived monthly.|

|''Version:''|0.7.0|

|''Date:''|Aug 25, 2007|

|''Source:''|http://sourceforge.net/project/showfiles.php?group_id=150646|

|''Author:''|BramChen (bram.chen (at) gmail (dot) com)|

|''License:''|[[Creative Commons Attribution-ShareAlike 3.0 License|http://creativecommons.org/licenses/by-sa/3.0/]]|

|''~CoreVersion:''|2.0.11|

|''Browser:''|Firefox 1.5+; InternetExplorer 6.0|



!Syntax:

{{{<<timeline [modified|created [maxentries [dateFormate]]]>>}}}

!Examples:

{{{<<timeline>>}}}

{{{<<timeline created 10>>}}}

{{{<<timeline modified 10 "MMM DD, YYYY">>}}}



!Revision History:

|''Version''|''Date''|''Note''|

|0.7.0|Jul 25, 2006|Accept a date format parameter|

|0.6.3|Jan 14, 2007|Cleaned codes, Removed config.macros.timeline.slider and config.macros.timeline.onClickSlider|

|0.6.2|Dec 10, 2006|Add monthFormat to display month format for Chinese|

|0.6.1|Aug 12, 2006|A great effect on config.macros.timeline.slider for Firefox, thanks Bob McElrath|

|0.6.0|Jul 25, 2006|Runs compatibly with TW 2.1.0 (rev #403+)|

|0.5.2|Jun 21, 2006|Fixed bugs for dateFormat of TW 2.1|

|~|~|Change default dateFormat to "0DD MMM, YYYY"|

|0.5.1|Jun 04, 2006|Added config.macros.archivedTimeline.orderBy for localization|

|0.5.0|Apr 19, 2006|Fixed bug for twice records of the same date ()|

|~|~|Added Date.prototype.convertToLocalYYYYMMDDHHMM<<br>>in order to backward compatible with 2.0.6-|

|0.4.0|Apr 03, 2006|Added new parameter, {{{<<timeline [sortfield] [maxentries]>>}}}|

|~|~|Added config.options.txtTimelineMaxentries|

|0.3.1|Feb 04, 2006|JSLint checked|

|0.3.0|Feb 04, 2006|Fixed several missing variable declarations|

|0.2.0|Dec 26, 2005|changed for the new feature of Macro timeline of TW 2.0.0 beta 6|

|0.1.0|Nov 3, 2005|Initial release|



!Code section:

***/

//{{{

version.extensions.archivedTimeline = {major: 0, minor: 7, revision: 0,

	date: new Date("Aug 26, 2007"),

	name: "ArchivedTimeline",

	type: "Macro",

	author: "BramChen",

	source: "http://sourceforge.net/project/showfiles.php?group_id=150646"

};

config.options.txtTimelineMaxentries=0;

config.macros.archivedTimeline = {

	tooltips: "Archives sorted by  ",

	orderBy:{modified: "modified", created: "created"},

	monthFormat: "0DD MMM YYYY",

	dateFormat: "0DD MMM YYYY"

};

config.macros.timeline = config.macros.archivedTimeline;



config.macros.timeline.handler = function(place,macroName,params) {

	var field = params[0] ? params[0] : "modified";



	place.appendChild(document.createTextNode(this.tooltips + this.orderBy[field]));

	var tiddlers = store.reverseLookup("tags","excludeLists",false,field);

	var lastMonth = ""; var lastDay = ""; var theText = "----\n"; var i = 0;

	var last = (params[1])?params[1]:config.options.txtTimelineMaxentries;

		last = (isNaN(last)||last<1) ? 0:tiddlers.length-Math.min(tiddlers.length,parseInt(last));

	var dateFormat = params[2] ? params[2] : this.dateFormat;

	var cookie; var archives;

	for (var t=tiddlers.length-1; t>=last; t--) {

		var tiddler = tiddlers[t];

		var theMonth = tiddler[field].convertToLocalYYYYMMDDHHMM().substr(0,6);

		var theDay = tiddler[field].convertToLocalYYYYMMDDHHMM().substr(0,8);

		if(theMonth != lastMonth) {

			if (lastMonth === "") {

				lastMonth = theMonth;

				}

			else {

				place.appendChild(document.createElement('hr'));

				cookie = 'chktimeline'+(i++);

				archives = this.formatString(this.monthFormat, lastMonth);

				var panel = config.macros.slider.createSlider(place,cookie,archives,this.tooltips + archives);

				wikify(theText,panel);

				lastMonth = theMonth; theText = '----\n';

			}

		}

		if(theDay != lastDay){

			theText +=  tiddler[field].formatString(dateFormat) + '\n';

			lastDay = theDay; 

		}

		theText += '* [[' + tiddler.title + ']]\n';

	}

	place.appendChild(document.createElement('hr'));

	cookie = 'chktimeline'+(i++);

	archives = this.formatString(this.monthFormat, lastMonth);

	var panel = config.macros.slider.createSlider(place,cookie,archives,this.tooltips + archives);

	wikify(theText,panel);

	place.appendChild(document.createElement('hr'));

};



config.macros.timeline.formatString = function(template, yyyymm)

{

	var dateString = new Date(yyyymm.substr(0,4)+'/'+yyyymm.substr(4,2)+'/01');

	template = template.replace(/DDD|0DD|DD/g,'');

	return dateString.formatString(template);

};

if (!Date.prototype.convertToLocalYYYYMMDDHHMM){

	Date.prototype.convertToLocalYYYYMMDDHHMM = function(){

		return(String.zeroPad(this.getFullYear(),4) + String.zeroPad(this.getMonth()+1,2) + String.zeroPad(this.getDate(),2) + String.zeroPad(this.getHours(),2) + String.zeroPad(this.getMinutes(),2));

	}

}

//}}}
{{{
	var container = document.getElementById("buttons");
	var btns = container.getElementsByTagName("input");

	for(var i = 0; len = btns.length; i < len; i++) {
		(function(n) {
			btns[n].onclick = function() {
				alert(n);
			 };
		})(i);
	}

}}}
''Fact:''
>There are only {{{2080}}} working hours in a year.

Believe it or not, using all of these hours, __only for work__ or trying to add to these hours can actually hinder your productivity, and worse yet land you in therapy!

A really neat opensource program that can take care of this problem is called [[Workrave|http://www.workrave.org/]].  [[Workrave|http://www.workrave.com/]] runs on Windows and Linux (and I'm guessing MacOSX....).

<<slider "12/3/2007 3:16 PM" "Workrave Introduction" "+Introduction">>
<<slider "12/3/2007 3:14 PM" "WorkRave - Recommended Settings" "+Setting up Workrave to Fit Your Needs">>
{{{root@sysresccd# ls -l /dev/disk/by-id | grep scsi-SATA_VBOX > hdds_byId.txt}}}

[[?|http://forums.virtualbox.org/viewtopic.php?t=4108&highlight=]]

[[?|http://www.derekhildreth.com/blog/how-to-properly-backup-a-virtualbox-machine-vdi/]]
I believe it was a late night on the computer much like this one, when I stumbled across a lone Tweet [[somewhere in the Reading area|http://streamd.in/]]; and I believe it said something about a 3D printer.  Intrigued, and having heard of 3D printers in Make magazine, I clicked on the name: [[tbuser|http://www.twitter.com/tbuser]] and discovered that this solitary tweet had come from none other than [[Tony Buser|http://tonybuser.com/]].  I sent him a message, inquiring about his 3D printer.   

This was no ordinary geek that I had stumbled across on Twitter; Tony is as of this writing is one of two known people in the Berks county area who have built their own RepRap printers.  He's even contributed to the project itself, with his online system for the RepRap called [[Cloudscad|http://blog.cloudscad.com/]].

If you don't know what a Rep Rap 3D printer is, it's a 3D printer capable of reproducing itself.  Reproduces itself? Impossible you say?  Inconceivable?  That's the same thing I said when I received a message back from Tony in which he asked if I were interested in joining a Hackerspace in Reading, PA.  I really didn't think such a thing was possible; but the following Thursday (and several subsequent Thursdays there after) I was proved wrong on two counts:  #There are indeed enough people interested to start a Hackerspace geeky community here in Reading, PA (we're finding more people all the time!)
#The RepRap is capable of producing just about anything (and I'm sure we're going to push it's limits even further at the new Hackerspace)

Now with that little bit of doubt pushed aside, I'd like you to think about yourself as a hacker of technology.  Me? You say? What could I possibly do?  If Tony can found a Hackerspace in Berks County, if a Rep Rap can re-print a copy of itself, than you, you my friend ought to be able to put aside your own self doubt and surprise yourself!  The only thing holding you back is not trying.

The Berks Colab Hackerspace's home on the web is located at [[http://www.berkscolab.org/|http://www.berkscolab.org/]]

If you're interested in joining us, please fill out our [[Interest Survey|http://berkscolab.org/2010/10/27/berks-colab-interest-survey-3/]].
*The less shiny the better.
*Around 48"
*Check Walmart
*''greenest green'' or ''bluest blue'' you can find will work fairly well.
*Try Rayon fabric
Background: #bbbbff
Foreground: #000
PrimaryPale: #99aacc
PrimaryLight: #006699
PrimaryMid: #002244
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #002244
TertiaryPale: #99aacc
TertiaryLight: #aaaaff
TertiaryMid: #000
TertiaryDark: #8B7355 
!By Dave Gifford

Background: #FFFFFF
Foreground: #000
PrimaryPale: #FF8C69
PrimaryLight: #FF8C69
PrimaryMid: #8B4C39
PrimaryDark: #410
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #FFD39B
TertiaryLight: #EEC591
TertiaryMid: #CDAA7D
TertiaryDark: #8B7355
Use these buttons to select different editing processors or mouse functions.

+++[Upper button bar]
The upper button bar can be found in the monitor to the top lieft.  It has the following functions:

''New Movie''
Opens a new movie.

''Load Movie''
Loads a previously saved movie.

''Save Movie''
Saves current movie.

''Create a backup copy''
Creates a backup copy of the current movie with all relevant media files.

''1-Click''
Opens the Movie Show Maker.

''MAGIX Song Maker''
Opens MAGIX Song Maker

''MAGIX Story Maker''
Opens MAGIX Story maker.

''Mixer''
Opens the mixer.

''Program Settings''
Opens program settings.

''Context Help''
Opens the context help for explanations for specic areas of the program.
===<br/>
+++[Lower Button Bar]
The following buttons are available in all modes (Storyboard and timeline modes):

''Undo''
All changes, including objects and cursor manipulations can be undone.

''Redo''
The "Redo" function undoes the previous "Undo" function.

''Delete''
This function deletes all selected objects or scenes from the arrangment.

''Cut selected objects''
Copies all selected objects to the clipboard.

''Copy Objects''
Makes a copy of all selected objects.  The copies appear alongside the original and can be dragged to the correct position using the mouse.

''Insert Clipboard''
This button inserts the contents of the clipboard at the position of the start marker.  The next scenes get moved back.

''Copy''
This button copies the selected scene into the clipboard.  From here it can be moved to a different poistiion in the film or into a different film altogether.

''Duplicate objects''
Duplicates all selected objects.  The copies appear alongside the original and can be dragged to the correct position using the mouse.
===<br/>
+++[Additonal Buttons in the Timeline Mode]
The following buttons are only available in the Timeline mode:

''Video Cleaning''
Opens the video optimization dialog for selected video and picture objects.

''Title Editor''
Opens the Title Editor.

''Form Group''
Orders all selected objects into groups.  As soon as an object is selected in the group, all objects in the group become highlighted so that you can work on them collectively.

''Ungroup''
Turns all selected objects into free-standing objects again.

''Object grid''
Use this button to switch the object grid on and off.  When the object grid is switched on, the objects snap into place beside one another so that everything fits in seamlessly.

''Set chapter markers''
Sets a chapter marker to the position of hte start marker.  Read more in the [[Burn Interface]].

''Set automatic chapter markers''
Opens the dialog to automatically set chapters.  Please also read the section [[Automatically setting chapter markers|Scene Recognition]] in the [[Edit Menu Chapter]]

''Mouse mode for individual objects''
This mouse mode functions much like the "Intelligent mouse mode", except that when moving objects, only the selected objects are moved.

''Curve Mouse Mode''
This mouse mode is used for drawing the volume and effect curves.  The last-editied curve effect is displayed on the object as a red curve.  You can freely draw this type of curve using the curve mouse mode.

''Strech Mouse Mode''
This special mode is for customizing the length of objects.  With timestretching, audio objects can be expanded or compressed using the handles at the bottom.  The duration of the audio material is therefore lengthened without changing the pitch.  Playback of the video object is accelerated/decelerated with the help of the handles at the bottom.

''Preview Audio''
In this mode you can preview audio objects as long as the mouse button is held down, along with the whole length and independent of the start and end markers in the timeline.  Other object types are protected against inadvertent moving.


''Scrub mouse mode''
This mode is especially suiited to searching for specific parts of a video.  By holding down the mouse buytton, the arrangement can be viewed at the point where the cursor is positioned.  The play back cursor follows the movements of the mouse.

''Intelligent mouse mode''
Select objects with a left-click.  When the Shift key is pressed, multiple objects are selected.  

You can move an object by holding down the mouse over it while dragging it to the desired position.  All objects that border the object on the same or on adjacent tracks are also moved, staring from the mouse position.  This means that every object that overlap adjacent tracs (fades, fade effects) and those that directly connect from one to the next ([[Hard Cuts]]) are pushed together (The technical term for it is "Ripple until black").  This is useful for keeping previously specified fades intact when you wish to move involved objects.  To move individual objects, switch to the mouse mode for individual objects (see bellow).  You can also drag an object vertically onto a free track thereby breaking the connection with the following objects.  You will then be able to move it freely without having to move other objects with it.
===<br/>
[[article link|http://www.cplusplus.com/doc/tutorial/templates.html]]

!Function Templates
Function templates are special functions that can operate with [[generic types]]. This allows us to create a function template whose functionality can be adapted to more than one type of class without repeating the entire code for each type.

In C++ this can be achieved using [[template parameters|Template Parameters C++]].  A [[template parameter|Template Parameters C++]] is a special kind of parameter that can be used to pass a type as an argument: just like regular function parameters can be used to pass values to a function, template parameters allow to pass also types to a function.  These function templates can use these parameters as if they were any other regular type.

{{{template <class identifier> function_declaration;}}}
{{{template <typename identifier> function_declaration; }}}

The only difference between both prototypes is the use of either the keyword {{{class}}} or the keyword {{{typename}}}.  Its use is indistinct, since both expressions have exactly the same meaning and behave exactly the same way.

For example, to create a template function that returns the greater one of two objects we could use:

{{{
template <class myType>
myType GetMax (myType a, myType b) {
	return (a>b?a:b);
}
}}}

Here we have created a template function with {{{myType}}} as its template parameter.  This template parameter represents a type that has not yet been specified, but that can be used in the template function as if it were a regular type.  As you can see, the function template {{{GetMax}}} returns the greater of two parameters of this still-undefined type.

To use this function template we use the following format for the function call:

{{{function_name <type> (parameters); }}}

For example, to call GetMax to compare two integer values of type {{{int}}} we can write:

{{{
int x,y;
GetMax <int> (x, y);
}}}

When the compiler encounters this call to a template function, it uses the template to automatically generate a function replacing each appearance of {{{myType}}} by the type passed as the actual template parameter ({{{int}}} in this case) and then calls it.  This process is automatically performed by the computer and is invisible to the programmer.

Here is the entire example:

{{{
// function template
#include <iostream>
using namespace std;

template <class T>

T GetMax(T a, T b) {
	T result;
	result = (a>b) ? a : b;
	return (result);
}

int main() {
	int i=5, j=6, k;

	long l=10, m=5, n;
	k=GetMax <int>(i, j);
	n=GetMax <long>(l,m);
	cout << k << endl;
	cout << n << endl;
	return 0;
}
}}}

!!!Result:
{{{
6
10
}}}


In this case, we have used {{{T}}} as the template parameter name instead of {{{myType}}} because it is shorter and in fact is a very common template parameter name.  But you can use any identifier you like.

In the example above we used the function template {{{GetMax()}}} twice.  The first time with arguments of type {{{int}}} and the second one with arguments of type {{{long}}}.  The compiler has instantiated and then called each time the appropriate version of the function.

As you can see, the type {{{T}}} is used as a parameter {{{GetMax}}} the compiler can find out automatically which data type has to instantiate without having to explicitly specify it within angle brackets (like we have done before specifying {{{int}}} and {{{long}}}).  So we could have written instead:
{{{
int i, j;
GetMax (i, j);
}}}

Since both {{{i}}} and {{{j}}} are of type {{{int}}}, and the compiler can automatically find out that the template parameter can only be {{{int}}}.  This implicit method produces exactly the same result:

{{{
// function template II
#include <iostream>
using namespace std;

template <class T>
T GetMax (T a, T b) {
   return (a>b?a:b);
}

int main () {
	int i=5, j=6, k;
	long =10, m=5, n;
	k=GetMax(i, j);
	n=GetMax(l, m);
	cout << k << endl;
	cout << n << endl;
	return 0;
}
}}}

!!!Result:
{{{
6
10
}}}


Notice how in this case, we called our function template {{{GetMax()}}} without explicitly specifying the type  between angle-brackets {{{<>}}}.  The compiler automatically determines what type is needed on each call.

Because our template function includes only one template parameter (class T) and the funciton tempalte itself accepts two parameters, both of this {{{T}}} type, we cannot call our function template with two objects of different types as arguments:

{{{
int i;
long l;
k = GetMax(i, l);
}}}

This would not be correct, since our {{{GetMax}}} function template expects two arguments of the same type, and in this call to it we use objects of two different types.

{{{
template <class T, class U>
T GetMin (T a, U b) {
	return (a<b?a:b);
}
}}}

In this case, our function template {{{GetMin()}}} accepts two parameters of different types and returns an object of the same type as the first parameter ({{{T}}}) that is passed.  For example, after taht declaration we could call {{{GetMin()}}} with:

{{{
int i,j;
long l;
i = GetMin <int, long> (j, i);
}}}

or simply:

{{{
i = GetMin(j,l);
}}}

even though {{{j}}} and {{{i}}} have different types, since the compiler can determine the appropriate instantiation anyway.

!Class templates
We also ave the possibility to write class templates, so that a class can have members that use template parameters as types.  

For example:

{{{
template <class T>
class mypair {
	T values [2];
   public:
	mypair (T first, T second)
	{
		values[0]=first; value[1]=second;
	}
}
}}}
The class that we have just defined serves to store two elements of any valid type.  For example, if we wanted to declare an object of this class to store two integer values of type {{{int}}} with the value 115 and 36 we would write:

{{{
mypair<int> myobject (115, 36);
}}}

this same class would also be used to create an object to store any other type:
{{{ 
mypair<double> myfloats (3.0, 2.18);
}}}

The only member function in the previous class template has been defined inline with the class declaration itself.  In case that we define a function member outside the declaration of the class template, we must always precede that definition with the {{{template <...>}}} prefix:

{{{
// class templates
#include <iostream>
using namespace std;

template <class T>
class mypair {
	T a, b;
  public:
	mypair (T first, T second)
	     {a=first; b=second;}
    	T getmax();
};

template <class T>
T mypair<T>::getmax ()
{
  T retval;
  retval = a>b? a:b;
  return retval;
}

int main () {
   mypair <int> myobject (100, 75);
   cout << myobject.getmax();
   return 0;
}
}}}

Notice the syntax of the definition of member function {{{getmax}}}:

{{{
template <class T>
T mypair<T>::getmax ()
}}}

Confused by so many {{{T}}}'s?  There are three {{{T}}}'s in this declaration:  The first one is the template parameter.  The second {{{T}}} refers to the type returned by the function.  And the third {{{T}}} (the one between angle brackets) is also a requirement: It specifies that this function's template parameter is also the class template parameter.

!Template specialization
If we want to define a different implementation for a template when a specific type is passed as template parameter, we can declare a specialization of that template.

For example, let's suppose that we have a very simple class called {{{mycontainer}}} that can store one element of any type and that it has just one member function called {{{increase}}}, which increases its value.  But we find that when it stores an element of type {{{char}}} it would be more convenient to have a completely different implementation with a function member {{{uppercase}}}, so we decide to declare a class template specialization for that type:

{{{
//template specialization
#include <iostream>
using namespace std;

// class template
template <class T>
class mycontainer {
	T element;
   public:
	mycontainer (T arg) {element=arg;}
	T increase () {return ++element;}
};

// class template specifications
template <>
class mycontainer <char> {
	char element;
    public:
	mycontainer (char arg) {element = arg; }
	char uppercase()
	{
		if((element>='a') && (element<='z'))
			element+='A'-'a';
		return element;
	}
};

int main () {
	mycontainer<int> myint(7);
	mycontainer<char> mychar ('j');
	cout << myint.increase() << endl;
	cout << mychar.uppercase() << endl;
	return 0;
}
}}} 

This is the syntax used in the class template specialization:
{{{ 
template <> class mycontainer <char> { ... };
}}}
  Posting #:   	 4174
 Job Title:  	Software Developer
 Division:  	SEI
 Department:  	SEI-CERT
 Job Grade:  	N/A
 Hiring Range Min:  	Negotiable
 Hiring Range Max:  	Negotiable
 Job Classification Code:  	4513
 FT/PT Status:  	Regular Full Time
 Location:  	5000 Forbes Avenue Pittsburgh, Pennsylvania 15213-3890 United States
 Additional Posting Information:  	 
 Job Description:  	
Summary

The CERT Program® is part of the Software Engineering Institute (SEI), a federally funded research and development center at Carnegie Mellon University in Pittsburgh, Pennsylvania. CERT engages in cutting-edge research and development, and provides robust training and education programs focused on ensuring that software developers, Internet security experts, network and system administrators, and others are able to resist, recognize, and recover from attacks on networked systems. The Development team within the CERT Coordination Center (CERT/CC) provides technical capability to the development of tools and software systems amplifying the CERT/CC's operational capabilities. The primary roles of the Development team include: software development, software design, integration and testing of software systems, requirements analysis and specification synthesis, packaging and deployment assistance of software systems. The successful candidate will serve as a self-motivated, strong contributor in the design, development, and deployment of a variety of enterprise-level systems that support the CERT/CC's core business activities. The individual in this position will be responsible for a combination of in-house development and integration of 3rd-party (including open-source) systems.

''Minimum Requirements''

*BS in Computer Science, Computer Engineering or equivalent plus three years experience developing software systems; 
*Candidates should have at least 2 years of experience in developing enterprise applications 
*within a small team and will be able to demonstrate experience in full life-cycle development from:
**conceptual design 
**to deployment, 
**systems integration, 
**the creation of mission-critical information storage 
**and retrieval systems 
***(e.g., CRM, financial, or publishing systems), 
*use of source code control, 
*configuration management, 
*problem tracking tools; 
*successful candidates will apply sound software engineering practices to system design and development 
**(e.g., 
***systematic approach to system specification, 
***architecture, 
***design, 
***development and documentation of code, 
***configuration management, 
***inspections and testing, 
***packaging and deployment
*be expert in Java/JEE at an enterprise level, 
*have significant experience Perl or other dynamic languages, 
*possess excellent technical problem-solving skills, 
**develop, 
**document, 
**explain technical decisions, 
*be strongly self-motivated to tackle challenging problems, 
*learn quickly and have a history of producing creative and innovative solutions, 
*prioritize work effectively, 
*interact effectively with technical and non-technical audiences via both written and verbal communications, 
*collaborate and work effectively within a closely coordinated team environment, 
*maintain composure while dealing with difficult people, 
*recognize and deal appropriately with confidential and sensitive information, 
*handle shifting priorities, 
*meet inflexible deadlines, 
*possess mentoring/training skills; 
*primarily sedentary in an office setting with some mobility. 
*Ability to travel to various locations within the SEI and CMU community, 
**customer sites, 
**conferences, 
**and offsite meetings with some frequency; 
**normal office conditions; however, close contact with computer for prolonged periods of time; *the ability to work well under pressure of deadlines and with confidential information; 
*candidate must pass a background investigation, 
*be eligible to obtain a United States DoD Secret Clearance, and be a U.S. citizen;

''Preferred Requirements''

*Master of Science in Computer Science, 
*Computer Engineering or equivalent plus one year experience developing software systems; or PhD; ideal candidates will have experience with a significant number of the following: experience with build technologies such as 

*Ant/make, 
*scripting languages in general, 
*interested in researching, 
*learning, 
*evaluating and reporting on various new technologies or implementations, developing web services and related technologies (e.g., XML, WSDL, SOAP, REST, XSLT) , applications using RPC mechanisms (e.g., XML-RPC); messaging (e.g., JMS), creating web-based applications and services in security-sensitive environments (e.g., familiarity with x.509 certificates, PKI, encryption, defense-in-depth concepts), leading small team development efforts, serving as a database (DBA) or system administrator, packaging and deploying server-side applications on Linux and/or UNIX systems (e.g., RPM, WAR, EAR), developing content management systems and related technologies (e.g., Alfresco, Bricolage), developing web-based user interfaces (e.g., XHTML, CSS, JavaScript, AJAX).
Type the text for 'Check the Sound Settings'
!Step 1: Check the Speakers
>First we need to check your speakers to ensure that there is indeed sound coming from them.  [>img[http://www.route6radio.com/images/radiohelp/speakerssmall.png]]

>If your speakers need to be plugged into a wall outlet make sure they are plugged into an electrical wall outlet.  

>Make sure that your speakers are powered on as well (sometimes they will have a little green or red light that will light up to let you know that the speakers are turned on).

''If the little green or red light is not lit up, please be sure that:''
##The speakers are plugged in to an electrical wall outlet. [img[http://www.route6radio.com/images/radiohelp/electricalplug.png]]
##The power button is pressed. [img[http://www.route6radio.com/images/radiohelp/r6r_power_switch.png]]

''Make sure that if your pair of speakers has a volume knob that it is turned up about three fourths of the way up. [img[http://www.route6radio.com/images/radiohelp/r6r_vol.png]]''

''Finally be sure that the speakers or head phones are plugged into the computer and connected to the right spot, There should be a ''Green Jack'' in which you can plug in your  //speakers// or //headphones//.''

| [img[http://www.route6radio.com/images/radiohelp/plugplugged.png]] |
| ''The Green Jack in the back of your computer.'' |

If you still don't understand, please be sure to [[click here|Extended Headphone Jack Help]]

Otherwise proceed to the next step, [[checking the sound settings|Check the Sound Settings]].
>I've been trying to figure out what makes a good flat-panel monitor for computer programming for a good while now.

>I'm trying to figured it out so I went to this [[blog post|http://mitchfincher.blogspot.com/2007/11/migraine-headaches-computer-monitors.html]] and discovered the [[follow website|http://www.techmind.org/lcd/index.html]] with advice from someone who works in the LCD monitor industry on buying a monitor.

!LCD technology and tests
LCD monitors are rapidly becoming shipped with new computers by default, and are superior to the old CRT screens for the majority of applications.  Although liquid crystal displays boats perfect image geometry and should be perfectly sharp, in reality they still have shortcomings:
*Viewing angle dependancies
*Poor blacks
*Motion-blur
are still issues, particularly for photographic and LCD television applications.  Certain flicker or shimmers can be caused by sub-optimal user-adjustment, or shortcuts taken at the factory.  On this page I explain a little of LCD screen technology and give you some pointers to the factors which separate teh best from the rest.  A large number of test patterns are provided to aid in setting and diagnosis of  your display.

!Active-matrix LCD technology 
A modern desktop liquid crystal display (LCD) computer-screen consists of an active-matrix panel and polarizers (which together act as an electricilly-controlled pixel-level light filter) situated immediatly in front of a backlight (large-area uniform light source - usualy consisting of one to four cold-cathode florescent lamps (CCFL), a lightguide diffuser).  The panel is connected to a dozen or so row- and column-driver chips which address the display with the picture data, and are driven by the rest of the monitors electronics.  I'm not going explain the basics of LCD panel in any more detail - this is already covered on hundreds of sites.

!LCD vs. CRT
The table bellow shows the main factors differentiating LCD and CRT displays from a users' perspective.

|!LCD |!CRT |
|compact |bulky |
|lightweight |heavy |
|low power (c. 20W) |high power (c. 150W) |
|perfectly sharp |limited sharpness; tend to blur more at high brightness, and with age |
|perfect image geometry |tends to suffer from geometric distortions, which may be picture (brightness) dependent, and worsen with age. |
|"consistent" tonal scale |strong bright areas can cause other regions of the picture to dim. |
| excellent text contrast| poor text contrast (limited bandwidth) |
| do not normally flicker| inherently flicker (although peoples sensitivity varies) |
| constrast/colour change with viewing angle)| constistent image irrespective of viewing angle. |
|poor black on dark images |good blacks (quality monitor, properly adjusted) |
|native interface would be digital (e.g. DVI) |naturally suited to analog interface |
|image //can// be sub-optimal with analog interface |

On the basis of image-quality alone, in my opinion  LCD is the montor of choice for "office" and technical/CAD applications (largely text-based, or detailed but colour-non-critical graphics), while CRT still has the upper hand for high-end photographic/art work and for television displays.
Higher priced LCDs (probably usuing "In-Plane Switching" "IPS" liquid crystal modes) marketed specifically for pre-press or photographic work should have colors which are less affected by viewing angles for that application (IPS tends to have a less- good black-state -lower contrast- however).

"Vertically Aligned" eg "MVA" (Multidomain -VA) boast the darkest blacks, equivalently highest contrast, or any LCD technology, but response time and viewing angle are poorer than IPS.

!LCD Tests
!!Clock/phasing for Analog inputs

LCD panels use discrete pixels and ideally should be connected to the image source via a digital interface such as DVI.  In an analog video signal from a computer's "VGA connector" the luminace data for one pixel runs into the next in a time continuum.  @@To properly recover the data back into the correct discrete pixels requires accurate synchronization of a "sampling-clock" in the monitor to the "pixel clock" in the graphics card.@@  Although possible, this can be technically tricky to get right (the VGA output was never designed for this!)  @@Symptoms of incorrect clock/phase settings include blurry or shimmering text, and shimmering on fine cross hatch patterns.@@  The "automatic" adjustment of many LCD monitors is not always successful, and manual tweaking may be needed.  It is probably wise to allow the monitor (and PC) to warm up for 5 to 10 minutes before running this test.
*[[Clock/phasing test screen|http://www.techmind.org/lcd/phasing.html]]
For an illustrated explanation of what these controls do, and how to use them, see [[Clock/Pitch and Phase controls|http://www.techmind.org/lcd/phasexplan.html]]

!Inversion
In liquid crystal pixel cells, it is only the magnitude of the applied voltage which determines the light transmission (the transmission vs. voltage function is symmetrical about 0V).   To prevent polarisation (and rapid permanent damage) of the liquid crystal material, the polarity of the cell voltage is reversed on alternate video frames.  Unfortunately it is very difficult to get //exactly// the same voltage on the cell in both polarities, so the pixel-cell brightness will tend to flicker to some extent at half the frame-rate.  If the polarity of the whole screen were inverted at once then the flicker would be highly objectionalble.  Instead, it is usual to ahve the polarity of nearby pixels in anti-phase, thus cancelling out the flicker over areas of any significant size.  In this way the flicker can be made imperceptible for most "natural" images.

<html>
<body>
<table>
<tr><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td width=160>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td width=200>&nbsp;<br>&nbsp;</td></tr>
<tr><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td width=64>&nbsp;<br>&nbsp;</td></tr>
<tr><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td width=200>&nbsp;<br>&nbsp;</td></tr>
<tr><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td>&nbsp;<br>&nbsp;</td></tr>
<tr><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><b>+</b></td><td width=200>&nbsp;<br>&nbsp;</td></tr>
<tr><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><b>+</b></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><b>+</b></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><b>+</b></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td>&nbsp;<br>&nbsp;</td>

 <td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td bgcolor="#ffc0c0"><center><b>-</b></center></td><td bgcolor="#c0ffc0"><center><b>-</b></center></td><td bgcolor="#c0c0ff"><center><b>-</b></center></td><td>&nbsp;<br>&nbsp;</td></tr>
<tr><td colspan=13>Line-paired RGB sub-pixel<br>dot-inversion pattern</td><td colspan=13>Row inversion (lower power)<br>used eg. on laptops</td><tr>

</table>
</body>
</html>

The following test patterns deliberately excite only one polarity-half of the inversion pattern for some common schemes, and one of them ''should'' cause your screen to flicker.  This is ''not'' a fault with the screen, @@bgcolor(red): but enables you to find out which inversion scheme your screen uses.@@

Note: if using an analog-input monitor, the following tests will not be meaningful unless the clock and phasing settings are correct (see [[previous test|http://www.techmind.org/lcd/phasing.html]]).

@@color(red):Warning to anyone who suffers from epielepsy@@or other extreme flicker-sensitivity: one or more of the tests bellow is likely to make your LCD flicker at 30 to 40Hz.

*[[Pixel dot-inversion|http://www.techmind.org/lcd/dotinv.html]]
*[[RGB sub-pixel dot-inversion|http://www.techmind.org/lcd/dotinvrgb.html]]
*[[Line-paired pixel dot-inversion|http://www.techmind.org/lcd/dotinv2l.html]]
*[[Line-paired pixel dot-inversion (offset)|http://www.techmind.org/lcd/dotinv2lb.html]]
*[[Line-paired RGB sub-pixel dot-inversion|http://www.techmind.org/lcd/dotinvrgb2l.html]]
*[[Line-paired RGB sub-pixel dot-inversion (offset)|http://www.techmind.org/lcd/dotinvrgb2lb.html]]

*[[Row-inversion (also known as line-inversion|http://www.techmind.org/lcd/rowinv.html]] - likely to be used on laptops.
*[[Line-paired row-inversion|http://www.techmind.org/lcd/rowinv2l.html]] - likely to be used on laptops.
*[[Line-paired row-inversion (offset)|http://www.techmind.org/lcd/rowinv2lb.html]] - likely to be used on laptops.

*[[Dot-inversion (green test)|http://www.techmind.org/lcd/greendot.html]] - will flicker with the (non line-paired) dot-inversion schemes.
*[[Line-paired dot-inversion (green test)|http://www.techmind.org/lcd/greendot2l.html]] - will flicker with either of the line-paired dot-inversion schemes.
*[[Line-paired dot-inversion (green test)|http://www.techmind.org/lcd/greendot2lb.html]] - will flicker with either of the line-paired dot inversion schemes (offset).

>My laptop screen seems to use [[Line-paired RGB sub-pixel dot-inversion|http://www.techmind.org/lcd/dotinvrgb2lb.html]] since it flicker's when I view that image.
>My screen down at work seems to get thrown off by [[Line-paired RGB sub-pixel dot-inversion (offset)|http://www.techmind.org/lcd/dotinvrgb2lb.html]]

On IE, you can ''switch to full-screen (and back) using F11''.  You mighta lso want to set the toolbar to auto-hide (right-button menu when in full-screen mode).

//Extreme tech://
The inversion patter for any given screen will inevitably flicker to some extend and is not a fault.  @@If it really flickers a great deal then it //may// indicate that common-electrode voltage has not been setup properly.  @@  In that case you might also perceive a "dot crawl" effect on plain colors of medium brightness.  A grossly mis-set common-voltage will also make your screen more susceptible to temporary 'image sticking' problems.  Common-electrode voltage can sometimes be adjusted by means of an //internal// preset, or on a manufacturer's configuration screen. (adjusted for minimum flicker on the inversion-pattern)...but doing so would almost certainly invalidate your warrentee.  Typically, with optimum setting, the centre of the screen will have minimum flicker on the inversion pattern, while the flicker will increase somewhat toward the left and right edges.  If there's a distinct minimum anywhere on the screen, then the setting is pretty close.  Note also that the optimum setting is likely to drift over the life of your screen, and may be slightly affected by temperature and the greylevel of the test pattern.  
//Any adjustments are made at your own risk!//
*[[Dot-crawl / line-crawl test page|http://www.techmind.org/lcd/dotcrawl.html]]

>Now I'm not entirely sure what the dotcrawl test page is supposed to do; I did notice however that the box with the horizontal lines in it did seem to move vertically upwards.

Some diagonal cross-hatch patterns used for shading by CAD programs can interact with inversion and cause objectionaable flicker on some LCD monitors - this should only be a problem if the manufacturer has left the common-electrode voltage grossly mis-set.  Having seen the severity of the effect on some new monitors (and how easily it could have been tweaked out at the factory) I'm beginning to for the opinion [January 2005] that in some cases this flicker //could// argueably be classified as "fault" with the product.

Laptop LCD screens tend to be optimised for lower power, wioth some relaxation of image-quality criterion.  As well as (often) lower brightness and less saturated colors, laptop screens usually use 'row inversion' (aka 'line inversion') scheme rather than the dot inversion now universal in desktop screens.  @@If you look closely at a row-inversion LCD, particularly if it is shown a fairly plain, mid-brightness color, you may see a slight horizontal line interference pattern on alternate lines, which may appear to drift up or down on the screen.  This is also not uncommon on color mobile-phone displays, or personal DVD players.@@

!Cross-talk
Owing to the way rows and columns in the display are adressed, and charge is pushed around, the data on one part of the display has the potential to influence what is displayed elsewhere.  This is generally known as ''cross-talk'', and in @@matrix displays@@ typically occurs in the horizontal and vertical directions.  Cross-talk used to be a serious problem in the old passive matrix (STN) displays, but it is rarely discernible in modern active-matrix (TFT) displays.

A fortunate side-effect of inversion (see above) is that, for most display material, what little cross talk there is, is largely canceled out.

For most practical purposes, the level of cross talk in modern LCDs is negligible.

Certain patterns, particularly those involving fine dots, can interact with inversion and reveal visible cross-talk.  If you try moving a small Window in front of the [[inversion pattern|http://www.techmind.org/lcd/index.html]] (above) which makes your screen flicker the most, you may well see cross-talk in the surrounding pattern.

Different patterns are required to reveal cross-talk on different displays (depending on their inversion scheme).  the following patterns may show cross-talk on your screen.

*[[Crosstalk 1|http://www.techmind.org/lcd/crosstalk1.html]]
*[[Crosstalk 2|http://www.techmind.org/lcd/crosstalk2.html]]
*[[Crosstalk 3|http://www.techmind.org/lcd/crosstalk3.html]]
*[[Crosstalk 4|http://www.techmind.org/lcd/crosstalk4.html]]

@@These patterns are not comprehensive and should not be used blindly to rate one screen against another. @@  The appearance of a visible cross-talk from any of these patterns does not indicate a "fault condition" with your display!

!Color, and viewing-angle dependence

Colors displayed by LCD screens tends to vary with viewing angle.  Please go to the following page to see this effect:
*[[Color and viewing-angle dependence|http://www.techmind.org/lcd/colour.html]]
>I can definitely see this...but I don't think I would have noticed if you hadn't said anything about it. Interesting.

@@Most low-price 15" and 17" LCD monitors use the Twisted Nematic ("TN") liquid crystal mode; with these displays the image looks much lighter if looked down on from above, and much darker if looked at from bellow.@@

>Yup, that's my laptop's display!

@@bgcolor(green):Newer liquid-crystal modes such as ''Vertical Alignment ("VA"), or ''In-Plane Switching ("IPS") '' have less viewing-angle dependence, but may suffer slower response times and/or lower contrast.@@

!Greyscale setup
Although not specific to LCD screens, I'm providing a greyscale test-page for completeness.
*[[Greyscale alignment page|]]

>"Bear in mind that the amount of ambient light in your room will affect how the colors display"
>>Neat I really didn't know about that.  Maybe that's why those "brown flowers" I used on that webpage looked to good to me as wall paper when I was at [[crave|http://www.crave8.com]]

!Refresh rate, response time, flicker and motion-blur

There seems to be alot of confusion and mis-infromation on these topics on the we; here's my clarification...

''Refresh Rate'' is the rate at which the electronics in the monitor addresses (updates) the brightness of the pixels on the screen (typically 60 to 75Hz).  For each pixel, an LCD monitor maintains a constant light output from one addressing cycle to the next (sometimes referred to as 'sample-and-hold'), so the display has no refresh dependent flicker.
@@//There should be no need to set a high refresh rate to avoid flicker on an LCD.//@@

>Ah ha!  well that clears up that little line of bull...I've seen 100Hz refresh rates on the net for LCD monitors...hmm makes ya think!

''Response time'' relates to the time take for the light throughput of a pixel to fully react to a change in its electrically-programmed brightness.  the viscosity of the liquid-crystal material means it takes a finite time to reorient in response to a changed electric field.  A second effect (which ahs a rather more complicated explanation) is that the capacitance of the LC material is affected by the molecule alignment, and so if a step chance brightness is programmed, as the LC realigns the cell voltage changes and the brightness to which it settles is not quite what was programmed.  Unless 'overdrive' (which tries to pre-compensate for this effect) is employed, it may take several refreshes before the light output stabilizes to the correct value.  Response Rate for dark-to-light is normally different from light-to-dark, and is often slower still between mid-greys.  VESA and others define standard ways of measuring response time, but a single figure rarely tells the whole story.

@@Manufacturers 'response times' rarely tell the whole story.  Unless bellow 16ms are likely to be of only marginal benefit, owing to more-dominant 'sample and hold' effects (see bellow)@@.

The visual effect of ''motion blur'' is self-explanatory and is fairly intuative to realize that a slow pixel response-time will cause this problem.
For each class, names of related objects should be recorded.  All objects required to fulfill responsibilities are obvious collaborators. Classes that require / supply services or data from/to the class under consideration should also be recorded.
The notion of //stress-free productivity// starts with off-loading what needs to get done from one's head, capturing everything that is necessary to:
*Track
*Remember
*Take Action On
Into what Allen calls a //bucket:// a physical:
*Inbox
*Tape Recorder
*Notebook
*A PDA
*A Desktop etc...

The idea is to get everything out of your head and into a collection device, ready for processing.  All buckets should be emptied (processed) at least once per week.

Allen doesn't advocate any preferred collection method, leaving the choice to the individual.  He only insists upon the importance of emptying the buckets regularly.  Any storage space (physical inbox, email inbox, tape recorder, notebook, PDA etc.) that is processed regularly by the individual is acceptable.
Background: #D9BD74
Foreground: #68382
PrimaryPale: #8C9A89
PrimaryLight: #18f
PrimaryMid: #3D4025
PrimaryDark: #D9BEA7
SecondaryPale: #ffc
SecondaryLight: #401F1C
SecondaryMid: #3D
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #8C9A89
TertiaryMid: #3D40
TertiaryDark: #666
Error: #f88
Today, I'm looking into the idea of using a [[CSS Framework|http://acts-as-architect.blogspot.com/2008/11/compass-primer.html]] and [[Webby|http://webby.rubyforge.org/tutorial/]] to build the static pages dynamically that I need to create for work.

>''Note:'' As I stated [[here|http://stackoverflow.com/questions/518168/utilitiy-dynamic-creation-of-static-pages-im-not-asking-this-because-i-want-t]] (no [[points|http://stackoverflow.com/faq#reputation]] for that question), I would much rather use a [[content management system|http://www.joomla.org/]] to build such pages, but my current employer doesn't believe in using a serverside scriping language unless they've written it themselves. 

So here I go, even if not by choice.  At least now if I need to throw something together quick I can do so without setting up a server.  Seems like this might work for proof of concept or maybe rapid prototype development.  (Still it wouldn't be my first choice...)

To get started on this I have started to download and install Ubuntu on Virtualbox since the OS they provide me at work wouldn't be suitable for this task.  In the mean time, I've decided to read the articles on [[Compass|http://acts-as-architect.blogspot.com/2008/11/compass-primer.html]] and [[Webby|http://webby.rubyforge.org/tutorial/]] while ubuntu downloads and installs.

Unfortunately, a client called me in the middle of my reading so I started installing Ubuntu, it appears to be installed correctly.

Alright now I can get to the business of actually trying this thing out.  I first installed {{{git}}} which I suppose is the new subversion.  

Next I installed ruby using the command:
{{{
sudo apt-get install rails
}}}

Next up we have to check sass out of the repository:
{{{
$ git clone git://github.com/nex3/haml.git
}}}
...and compile it...
{{{
$cd haml
$cd rake install
}}}

haml eh?  I didn't think this had anything to do with Mark...

Okay and now I'm supposed to test it...

{{{
$ sass -v 
The program 'sass' is currently not installed. You can install it by typing install sufary
}}}

Hmm good to know...I wonder what happened...take a trip to the {{{./bin}}} directory and ah, there it is...

{{{
$ cd ./bin
$ ./sass -v
Haml 2.1.0.ddd4a99
}}}

Okay there we are, now on to installing Compass...
{{{
$ gem sources --add http://gem.github.com/
}}}
Added a repository to {{{gem}}}

{{{
$ sudo gem install chriseppstein-compass
}}}

Okay thanks Chris now I believe it's installed...lets just test it out:

{{{
$ compass
bash: compass: command not found
}}}

Great!  I sent a question to the mailing list, and now I'll go work on [[Webby|Installing Webby]] for a while...

Okay [[Chris Eppstein|http://groups.google.com/groups/profile?enc_user=zHXCZRMAAACiZjOE_R-okBTcA9n3prf0h-kUg4S0n7nbF1Te82ZIng]] the guy that wrote this thing just got back to me and [[re-compiled the Compass gem that wasn't working right|http://groups.google.com/group/compass-users/browse_thread/thread/9a55a9eae3b5d1cf/ab570ecfdbcc7610?lnk=gst&q=leeand00#ab570ecfdbcc7610]]  I re-ran the command:
{{{
sudo gem install chriseppstein-compass
}}}
For now this seems to have fixed the problem as running:
{{{
compass -v
Compass 0.3.9
Copyright (c) 2008 Chris Eppstein
Released under the MIT License.
}}}
Seems about right.
IPv6 addresses have a third form for specifying IPv4 addresses.  But what if we want to convert those addresses into IPv6 form?

IPv4 addresses are made up of four octets; each octet is a decimal numbers that represent 8-bits. (see [[this firewall.cx article to view this clearly|http://www.firewall.cx/networking-topics/protocols/supernetting-a-cidr-/189-supernetting.html]])

IPv6 addresses are made up of eight hexquads; each hexquad is a hexidecimal number that represents 16-bits.

Of course there's always the [[Third Form|https://wiki.ubuntu.com/IPv6#Reading_IPv6_Addresses]] for representing such addresses, but I thought it would be interesting to find out how one converts this from IPv4 to IPv6.

And now thanks to some of my friends over at [[Server Fault|http://serverfault.com/questions/319190/ipv6-ipv4-third-form-conversion/319196#319196]] I believe I've come across an answer.

Take an address such as was given to me in the example question from [[Server Fault|http://serverfault.com/questions/319190/ipv6-ipv4-third-form-conversion/319196#319196]]:

{{{192.168.50.254}}}

the chap on [[Server Fault said|http://serverfault.com/questions/319190/ipv6-ipv4-third-form-conversion/319196#319196]] that the result comes out to be:

{{{::c0a8:32fe}}}

Well now how did he come to this conclusion?

The answer is quite simple...[[use a hex converter program|http://www.subnetonline.com/pages/converters/hex-to-bin-to-dec.php]] to convert each of the octets as follows:
----
In the first octet is {{{192}}}, entering this into the [[hex converter program|http://www.subnetonline.com/pages/converters/hex-to-bin-to-dec.php]] as a decimal results in the hexidecimal number {{{c0}}}.

...so lets concatenate that to the first hexquad of our IPv6 address: {{{::c0}}}
----
Converting {{{168}}} to hex in the same way results in {{{a8}}}

...concatenation of this to our existing hexquad results in {{{::c0a8}}}
----
Since two octets fit within a single hexquad, the next two octets will create the next hexquad in our address:

Converting {{{50}}} to hex in the same way as above results in a hexadecimal {{{32}}}

...once again concatenation of this to our existing hexquad results in {{{::c0a8:32}}}
----
And as for the last octet {{{254}}} from decimal to hex this conversion results in {{{fe}}}

and concatenated to the end of the existing address completes our address with {{{::c0a8:32fe}}}.
[[Article Link|http://docs.joomla.org/Tutorial:Creating_a_Hello_World_Module_for_Joomla_1.5]]

A module is a lightweigh and flexible extension taht is used for page rendering.  They are used for small bits of the page that are generally less complex and are able to be seen across different components.

You can see many examples of modules in the standard Joomla! install: - menus - Lastest News - Login form - and many more.

This tutorial will explain how to go about creating a simple Hello World module.  Through this tutorial you will learn the basic file structure of a module.  This basic structure can then be expanded to produce more elaborate modules.

+++[+File Structure]
There are four basic files that are used in the standard pattern of module development:

>[[mod_helloworld.xml]]
>>This file contains information about the module. It defines the files that need to be installed by the Joomla! installer and specifies configuration parameters for the module.

>[[helper.php]]
>>This file contains the helper class which is used to do the actual work in retrieving the information to be displayed in the module (usually from the database or some other source).

>[[tmpl/default.php]]
>>This is the module template.  This file will take data collected by the [[mod_helloworld.php]] and generate the HTML to be displayed on the page.
===<br/>
+++[+Creating mod_helloworld.php]
The [[mod_helloworld.php]] file will perform three tasks:
#Include the helper.php file which contains the class to be used to collect the necessary data.
#Invoke the template to display the output.
#Include the template to display the output.

The helper class is defined in our [[helper.php]] file.  This file is included with a require_once statement:

{{{
require_once( dirname(__FILE__).DS.'helper.php' );
}}}

[[require_once|http://us.php.net/manual/en/function.require-once.php]] is used because our helper functions are defined within a class, and we only want the class defined once.

Our helper class has not been defined yet, but when it is, it will contain one method: {{{getHello()}}}

For our basic example, it is really not necessary to do this - the "Hello World" message that this method returns could simply be included in the template.  We use a helper class here to demonstrate the basic technique.

Our module currently does not use any parameters, but we will pass them to the helper method anyway so that it can be used later if we decide to expand the functionality of our module.

The helper class method is invoked in the following way:
{{{
$hello = modHelloWorldHelper::getHello( $params );
}}}

The one line that we haven't explained so far is the first line.  This line checks to make sure that the file is being included form the Joomla! application.  This is necessary to prevent variable injection and other potential security concerns.
===<br/>
+++[+Creating helper.php]
The helper.php file contains that helper class that is used to retrieve the data to be displayed n the module output.  As stated eariler, out helper class will have one method: {{{getHello()}}}.  This method will return the 'Hello, World' message.

Here is the code for the [[helper.php]] file:
<<slider "9/12/2008 2:54 PM" "helper.php" "++helper.php">>

An important point ot note is that the template file ahs the same scope as the [[mod_helloworld.php]] file.  What this means is that the variable $hello can be defined in the [[mod_helloworld.php]] file and then used in the $hello file without any extra declarations or function calls.
===<br/>
+++[+Creating mod_helloworld.xml]
The [[mod_helloworld.xml]] is used to specify which files the installer needs to copy and is used by the Module Manager to determine which parameters are used to configure the module.  Other information about the module is also specified in this file.

The code for [[mod_helloworld.xml]] is as follows:
<<slider "9/12/2008 3:15 PM" "mod_helloworld.xml" "+mod_helloworld.xml">>

You will notice that there are two additional files that we have not yet mentioned: {{{index.html}}} and {{{tmpl/index.html}}}.  These files are include so that these directories cannot be browsed.  If a used attempts to point their browsers to these folders, the index.html file will be displayed.  These files can be left empty or can contain the simple line:
{{{
<html><body bgcolor="#FFFFFF"></body></html>
}}}
===<br/>
+++[+Conclusion]
Module development for Joomla! is a fairly simple, straightforward process.  Using the techniques described in this tutorial, an endless variety of modules can be developed with little hassle.
===<br/>
Hmm sounds almost like //Model - View - Controller//
Today I'm trying to figure out how you create an image using the new WIM format from windows. Last week my [[RAID array at work died|24 October 2008 - aleer]], and now I need a way to get back up and running, fast! It's supposed to create a hardware agnostic image so that if your hardware fails you don't have to use the same hardware to restore the backup of your data.

+++[Creating a Windows Live CD (can't believe I'm saying this)]
I am following the article [[here|http://userssuck.com/2007/03/30/create-a-winpe-boot-disk-for-imaging-repair/]]

So far I have gotten the {{{.img}}} burned and installed the AIK.  

I tried to create a windows PE image for my Intel 64-bit processor but received the following error:
{{{
C:\Program files\...\PETools\>copype.cmd ia64 C:\WinPE_ia64
Invalid architecture: ia64
}}}

I noticed that there are directories in the {{{PETools}}} directory for {{{amd64}}} and {{{x86}}}, which make me assume that those would be valid architectures.

I wrote to the author of the article by leaving a comment on this blog.  And then after work today, he got back to me!  Here is what he had to say:


>Hi Andrew,
>I've added a comment to the story for you, but figured it might be quicker for you if I followed up with you via email.  To answer your question, ia64 is for the Itanium series of Intel processors.  ''__Most likely what you'll want is the amd64 option which is compatible with Intel's Pentium D, Core, and Core2 line of processors.__''<br/>
>I hope this helps.  If you run into any other questions, let me know. I've been deploying Vista in production and creating custom winpe disks since shortly after Vista was released, and have probably run into just about every problem  you may encounter. 
>Regarding your blog comment about Vista being hardware agnostic, I can definitely vouch for that.  I had a hard drive that I moved through 3 different computers with drastically different hardware without a hitch.  If you're planning on deploying an image to a wide variety of hardware, you can also use the pnputil command with the -a flag to add drivers to the driver store on your reference computer, so when you take the image and deploy it, they'll all be there.  I generally grab all the drivers for all the current models of Dell's that I'm supporting and add them to the driver store to be safe, and we run that one image across 4 models of Optiplex desktops and 7 models of Latitude laptops.

Okay, so this time I tried it, and using the amd64 profile, and I got:

{{{
C:\Program Files\Windows AIK\Tools\PETools>copype.cmd amd64 C:\WinPE_amd64

===================================================
Creating Windows PE customization working directory

    C:\WinPE_amd64
===================================================

        1 file(s) copied.
        1 file(s) copied.
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\bcd
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\boot.sdi
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\bootfix.bin
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\etfsboot.com
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\fonts\chs_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\fonts\cht_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\fonts\jpn_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\fonts\kor_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\boot\fonts\wgl4_boot.ttf
9 File(s) copied
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\bcd
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\fonts\chs_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\fonts\cht_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\fonts\jpn_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\fonts\kor_boot.ttf
C:\Program Files\Windows AIK\Tools\PETools\amd64\EFI\microsoft\boot\fonts\wgl4_boot.ttf
6 File(s) copied
        1 file(s) copied.
        1 file(s) copied.

Success

Updating path to include peimg, oscdimg, imagex

   C:\Program Files\Windows AIK\Tools\PETools\
   C:\Program Files\Windows AIK\Tools\PETools\..\AMD64
}}}

On to the next step.  According to the tutorial, the next step is to copy the tool for creating VIM images into the directory we just created. ({{{WinPE_amd64}}})

{{{
C:\WinPE_amd64>copy "C:\Program files\Windows AIK\Tools\AMD64\imagex.exe" .\WinPE_amd64\iso\Tools\
}}}

Alright, that seemed to work.   

Now the tutorial says I'm supposed to create a file for ImageX so that it excludes certain files.
The files name is {{{wimscript.ini}}} and needs to be located in the same directory as we copied {{{imagex.exe}}} into.

Finally he says we need to make an ISO file of the new Windows PE distribution we just made.
(and I imagine burn it to a cd).  I've never seen this command before, but lets give it a shot.

{{{
oscdimg -n -bc:\WinPE_amd64\etfsboot.com c:\WinPE_amd64\ISO c:\WinPE_amd64\winpe_amd64.iso
}}}
===<br/>
+++[Removing Hardware Information]
I am now following this tutorial, the second part in the Users Suck!  VIM creation series.

The following command is supposed remove any trace of hardware information and thus make the back up hardware agnostic.
I'm a little concerned that this might screw my computer, up, but seeing as it isn't even setup yet, I don't think that's much of a problem.
{{{
C:\windows\system32\sysprep\sysprep.exe /generalize /oobe
}}}

A window then appeared with a title bar saying {{{Sysprep is working}}} and I waited for it to complete.  It now appears that my computer has shutdown.  Maybe this is the part where I'm supposed to boot from the Windows PE CD I created in the last step...Okay after booting from the CD it says {{{"Windows is Loading Files"}}} and you wait for it to boot from the CD.  

===<br/>
+++[Finding a place to put the image]
Now that Windows PE has booted up, we need to check if it is indeed been dolled out an ip address from the dhcp server.  
===<br/>
+++[Creating the Image]

===<br/>

+++[Rebooting]
Shockingly since we removed all the hardware specific stuff with the {{{sysprep.exe}}} command, the computer starts up with {{{please wait while windows starts up for the very first time}}}.
===
[[article link|http://www.fewt.com/2011/01/building-dmz-with-dd-wrt.html]]

#Logged into DD-WRT Router.
#Visited the {{{Setup->Networking}}} tab.
##Under {{{VLAN Tagging}}}, clicked {{{Add}}}
##In resulting {{{Tagging}}}
[img[http://i9.photobucket.com/albums/a58/Maskkkk/Leave.png]]
<<gradient vert #cecece #ffa500 #ffffff>>Set Limits!>>
If you're anything like me you get ''really'' involved in your projects at work.  Staying longer than necessary, and forgetting to leave long after ''5:00 PM''!

I can tell you from //personal//, ''painful'', experience that doing this too often (''I.E. everyday...'') is dangerous to your ''health'' as well as your ''career''!
>>If your boss makes a stink about this, by all means @@color(red):__GET A NEW JOB!__@@.  
>>>You won't be there long anyway.  Five months at most of this type of behavior and you'll be having health problems.

>So if you find the cleaning lady at your office dismissing you for the day, everyday...this timer in [[Workrave|http://www.workrave.org]] will be really helpful.  
I've been tasked with removing a duplicate record from a third party database.

In order to achieve this the first thing I did was to gather a list of tables and all their fieldnames.  Using MS-Access and VBA [[this wasn't terribly difficult to achieve|http://stackoverflow.com/questions/1275502/using-vba-to-export-all-ms-access-sql-queries-to-text-files/12482264#12482264]].  

Now that I have a list of tables and their fields, I can place this data in an excel spreadsheets and search / filter for fields that appear to have a foreign key to the duplicate record.  

|!Field Description |!Field Name |!Table Name |
| | ... | ... |

For example, there is a table called {{{T_Employee}}} that has a duplicate record.  {{{T_Employee}}} has a primary key of type {{{COUNTER(10)}}} which is related to foreign keys in other tables of type {{{INTEGER(10)}}}, and this provides our first clue for what we are looking for...

I spoke with a gentleman at the company that created / supports this 3rd party database and they gave me a list of tables they thought records should be updated or deleted from...Handily this gentleman also included in the list, a list of tables with rows for update, and a list of tables with rows for deletion.  While this didn't give me a list of all the tables it provided a pretty good starting point for creating an ERD to refer to when creating the de-duplication queries, and also for finding other fields that he may have forgotten to tell me relate.

When looking at the list of tables and their fields that relate to our duplicate record, I found patterns in the field names which also helped to narrow down which fields / tables need to be taken into a account in our duplicate record merger; for example some of the foreign keys related to our duplicate records primary key contained the following strings (where {{{*}}} is a wildcard character:
*{{{*_EmployeeID}}}
*{{{*_Caregiver}}}
*{{{*_CaregiverID}}}
*{{{*_Emp}}}
*{{{*_EmpID}}}
*{{{Pay_Emp_ID}}}

After using these strings to filter through the list of fields in the table above, and copying them into another blank spreadsheet, I was able to find more tables that were related (abet not explicitly through relationships) and compare them to the fields I already had in my ERD.

!Clues
*The primary key of duplicate record is {{{COUNTER(10)}}} therefore...
**The foreign keys of the duplicate records should be {{{INTEGER(10)}}}.


The idea here is to merge the records (and their related records) and then later to look for duplicates.  Simply deleting won't do the trick because users are entering information for both records as though they are active.

#Get a list of all tables in the database and their fields, (via VBA CSV export and import into excel)
#Ask somebody with more knowledge about the database for which records with foreign keys related to the duplicate need to be updated and deleted.
#Create an ERD with the relationship and how they relate to the duplicate.
**''Note:'' Put the table with the duplicate record in the middle of the ERD, so that it's foreign relations surround it.
**Also split these groups of tables into both UPDATEable and DELETEable record relations.
#Test these relations to make sure they return actual records in the expected 1-M or M-M relationships.
#Look over the list of field names you were given, and try to spot patterns in the names, now if we use the patterns in these names, we should be able to find other foreign keys and related tables.  
**For example, if you find 5 field names named {{{*_EmployeeID}}} //({{{*}}} being the wildcard)//, back in the excel spreadsheet of table and field-names, filter with {{{text filters->contains}}} and type {{{_EmployeeID}}}, the resulting list should give you a list of other foreign keys in other tables which you can go back and ask the person with more knowledge about; so copy them into a separate blank spreadsheet of possibly related field names. You may have to do this several times for each foreign-key field name-pattern that you find.
#In the new list of possibly related field names, compare them to the ones in your ERD, bold them if they are present, and color them red if they are to be deleted, and blue if they are to be updated.
#Finally with the fields you are not certain about, go to the person in support and ask them about the other field names that you found.
#Finally, you can take your findings in the possibly related fieldnames spreadsheet, and write a script to update the fields to be updated, delete the fields to be deleted (including the duplicate record itself) and finally use a deduplication tool like [[duke|http://code.google.com/p/duke/]] to check for duplicates between the duplicate records', child-records, and the non-duplicate records' child-records.
#
 
[[5 June 2014]] [[4 April 2013]] [[22 October 2012]] [[24 March 2012]] [[10 January 2012]] [[25 November 2011]] [[2 September 2011 - aleer]] [[Hitchhikers Guide to The Galaxy and The Babel Fish...]] [[Berks Colab]] [[Saving and Growing - Carpatho-Rus Chant and Hymnology]] [[2 December 2009 - aleer]] [[What's wrong with Windows]] [[Really hoping I can get an answer to this question]] [[Interview with Jason Fried of 37 Signals]] [[15 October 2009 - aleer]] [[12 September 2009 - aleer]] [[Upgrading to OOo 3.1.0 From 3.0.1]] [[Miloro and his Mother And Sister Singing at Pascah]] [[ZUI]] [[22 May 2009 - TODO]] [[Spending the Weekend at Crave]] [[29 April 2009 - aleer]] [[16 April 2009 - aleer]] [[12 April 2009 - aleer]] [[JSUnit 2.2 on Firefox 3.07 - FTW]] [[Fixing Activesync 4.5 on my ASUS A626]]
[[8 February 2009 - aleer]] [[6 February 2009 - aleer]] [[Using Tiddlywiki to Diagnose a Patients Symptoms]] [[2 March 2009 - aleer]]
!Deploying the settings using our shell script

[[edit|Deploying Settings - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
!Writing the Deployment Mechanism
{{{

# Copy the configuration files out to their respective locations
sudo cp ./dnsmasq.conf /etc/dnsmasq.conf
sudo cp ./interfaces /etc/network/interfaces

#Restart Networking
sudo /etc/init.d/networking stop
sudo /etc/init.d/networking start

# Restart the dnsmasq service
sudo /etc/init.d/dnsmasq stop
sudo /etc/init.d/dnsmasq start

#Restart lampp (or whatever webserver you happen to be using...)
sudo /opt/lampp/lamp_stop
sudo /opt/lampp/lamp_start

}}}

Now anytime we modify the configuration, we can easily just run this script and have everything deployed, configured and ready to go.
|!Table Header 1|!Table Header 2|
|Cell |Cell |
{{{
function displayFeaturesAll() {
var theTitle = "FeaturesAllDigitalSolutionProvider";

		if(store.getTiddler(theTitle))
			fields = null;

story.displayTiddler("top", theTitle, null, true, null, null, true);
// DEFAULT_EDIT_TEMPLATE
}
}}}

{{{
function editFeaturesAll() {
    var theTitle = "FeaturesAllDigitalSolutionProvider";
    config.commands.editTiddler.handler(null, null,theTitle);
    
}
}}}
Any organizational system is no good if excessive time is spent organizing tasks instead of actually doing them.  Allen's contention is that if one can make it simple, easy, and fun to take the necessary actions, one will be less inclined to procrastinate or become overwhelmed with too many [[Open Loops|Open Loops - GTD]]
#Signed up for a free developer key here: [[http://api.drop.io|http://api.drop.io]]
**@@''Note:'' they say that I'll probably need to sign up for a premium key later.
#Went to the following URL: [[http://api.drop.io/drops/about?api_key=[YOUR_API_KEY]&version=2.0|http://api.drop.io/drops/about?api_key=[YOUR_API_KEY]&version=2.0]] to try it out.
#Hold the plug to your headphones or speakers which looks like the following: 
|[img[http://www.route6radio.com/images/radiohelp/plugs.jpg]]|
| ''Headphone or Speaker Plug'' |
#Now, in the back of the computer, look for a set of holes
The holes you will be plugging your headphones or speakers into will most likely be located in the back of your computer.  Make sure you plug it into the right one, since there are three of them. 
|[img[Three plugs in the back of your computer|http://www.route6radio.com/images/radiohelp/empty_plugs.png]]|
| ''Head Phone '' |
The main thing that's REALLY EVIL about Facebook is that there are so many external productivity sites that use Facebook Connect as a login option. This requires that you login to Facebook to login to these other sites.  Meaning that if you want to login to a productive site, such as [[Quizlet.com|http://www.quizlet.com]] and when you signed up for it, you were just too damn lazy to enter your email address and a password, and then store the password in a password keeper (see how much work that is?)...instead you joined the site using Facebook Connect, which means if you had a facebook account, you had to use a total of two mouse clicks to join the site.   I don't think it takes a genious to see which couse of action //"Joe Webuser"// is going to pick.

However, many of these sites have an option to disconnect or unlink from Facebook and to just use a regular username and password instead. (Though they're usually burried in the settings somewhere).  This seems to be missing from the article but is essential to anyones ability to ignore the productivity sucking blackhole that is Facebook.

Facebook is an absolutely horribe drag on concentration, and I would even go so far as to attribute the fall of Western civilization to it; it's polarizing our country by leading to un-civialized conversations about guns, abortion, religion, and sexual orientation, that you never would have had the balls to have if you weren't sitting in front of a computer screen instead of within an arms lengths of anybodys fist.  Prior to Facebook, you could have remained friends with these people because your views and their views about these un-civalized and un-discussed topics would have remained in the "I'm afraid to talk about these section of the brain".  

So, lets review...the symptoms in our country caused by Facebook are: 

{{{
Lack of Productivity + Cult-like dedication to left or right causes = Polarization and fall of Western Civialization
}}}

...and just because you wanted to keep up with your relatives and friends. 

Basically this means much of the Facebook consuming populus can't work together because they're all too angry at each other about their differing views on topics that have nothing at all to do with productivity, thus the GDP falls, and thus peoples ability to concentrate is disappated

And if you try to tell someone how awful their facebook usage is for them, they look at you a bit like Gollum from the LoTR would if you tried to take away //his precious//:

[img[http://i9.photobucket.com/albums/a58/Maskkkk/Gollum.jpg]]
''The way most people react when you tell them Facebook is bad for them...''

Facebook is much worse than TV ever was.  TV is not ever present, on every website you visit, and it doesn't ask you to use it as an easier login than 

Lifehacker suggests that people should use a program on their router that limits 

So with that here is my attempt at installing MIA 


So to fix all of this and reclaim your productivitiy you need to:
#Make a list of all the sites you use regularlly that you use Facebook Connect to login to...
#Switch these sites to use something else.  <br/>These first two steps will no doubt be a long and ardugous task...that will take quite a bit of time...your browser history will really come in handy at this point.
#Setup your router and cellphone so that it restricts access to http://connect.facebook.com/ and http://www.facebook.com/
##And Gollum if you can't part with //your precious// so easily, restrict it to just during the set times during the day when you need to get things done.
##If you run a simple end-user friendly modem, this will likely be easier.
##If you run a not-so-simple opensource router like I do (OpenWRT), you'll need to setup a program called MIA (Mom's Internet Access Helper) to get this done.
##Alternately, you've also got the option to setup a local dns that will prevent you from accessing the sites...though it isn't quite as effective as doing this through your router, it can come in handy when your connected at a different location...a good start to this is my article [[Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]].
Discovered that using a [[certain perl module|http://search.cpan.org/~lunatic/Text-ASCIITable-0.18/lib/Text/ASCIITable.pm]] I can create plain-text tables for those pesky job applications that only allow you to use text.
{{{
   .=-----------=.
   | info | info |
   |-===========-|
   | info | info |
   |=-----+-----=| <-- between each row
   | info | info |
   '=-----------='
}}}
{{{
\<td.+(align=\"right\"|style=)
}}}

Maybe this could be better...
{{{
/*jQuery.each(jQuery("a.tiddlyLink"), function(index, theLink){
  if(theLink.innerHTML == "FeaturesAllDigitalSolutionProvider") {
     console.log(theLink.onclick);
  }
});*/
}}}



Over the past few days I've been 
{{{Home | }}}

*
*Make it look less default.
Alright nice!  I got my Activesync syncing again!  

!The Problem
I haven't been able to make this thing sync for over a month, and I couldn't figure out what the [>img[http://www.mobilitysite.com/blogimages/ASUSLaunchesStainlessSteelPDAtheASUSA626_8149/ASUSa6265.jpg]]problem was...whenever I'd plug it into my computer's USB port, I would get a "connecting..." message from Activesync 4.5 and then it would fail.  Microsoft's crummy trouble shooter came up, and I tried all the things they asked me to, but none of them worked.  

!The Fix
Tonight I finally got some time, and found a way of fixing the problem.  I had to:
#{{{Start->Activesync->Menu->Connections...}}} and I made sure that the {{{Synchronize all PCs using this connection:}}} was checked and that {{{`USB Default}}} was selected in the dropdown list.
#I went to {{{Start->Settings->Connections->USB Settings}}} and change the setting to {{{ActiveSync (low speed)}}}
[[Centering a Horizontal Navigation in a Liquid Layout |http://www.3point7designs.com/blog/2007/04/09/justified-horizontal-navigation-with-liquid-layouts/]]
[[Deployment with git|http://danbarber.me/using-git-for-deployment/]]
!Putting version control in place with GIT
When we switch between networks wired or wireless, provided we are using a static ip available within a static range in that network we can store the version of our configuration as a whole (both files) in a named branch in a GIT repository.

But first, we're going to init version control by running {{{git init}}} in the project directory, next we'll add the files to the project, and lastly after committing some modifications we'll cut another branch to store more settings in.

#In the project-directory run {{{git init}}}
#Run {{{git add .}}} to add all the files to the vcs,
#Lastly run {{{git commit}}} to commit the initial version of the files.
**When prompted give it a message of {{{Initial Commit}}}
What two key elements are promoted through GTD?
Control and perspective.
What are the three models used in GTD to gain control and perspective?
1. A workflow process\n2. A framework with 6 levels of focus.\n3. A natural planning method.
What is the "Workflow Process" used for?
To gain control over all the tasks and commitments which one needs or wants to get done.
What are the five steps of the workflow process?
1. Collect\n2. Process\n3. Organize\n4. Review\n5. Do
What is the second major model in GTD?
Six Different Levels of Focus
What are the six different levels of focus?
1. Current Actions\n2. Current Projects\n3. Areas of responsibility\n4. Yearly goals\n5. 5 year vision\n5. Life goals.
As one ____ in the altitude of the six different levels of focus one is able to see the bigger picture.
What are the "open loop holes" in GTD terminology?
*projects\n*actions\n*unfinished business\n*commitments
Input gained from a variety of "heights" gives one
A varying perspective.
Once a week you should, weekly review focusing on...
Different levels of the six different levels of focus.
Why should you weekly review the six levels of focus?
So that perspective gained from the review will drive one's priorities, which in turn determines the priority of if and when one is to do the particular individual tasks and commitments gathered during the workflow processs.
The Workflow Model has a "horizontal" focus on...
Doing individual tasks.
The Natural Planning Model has a "vertical" focus on...
planning projects and thinking through topics.
What are the five stages of the natural planning model?
1. Defining the purpose and principles.\n2. Envisioning the outcome.\n3. Brainstorming\n4. Organizing.\5.Identifying Next Actions.
*[[Tickler File|Tickler File - GTD]]
*[[Software Tools for GTD]]
*[[Other Tools]]

[[edit tiddler|GTD Tools and Techniques]]
>Today I was looking to using geo-rss, so far I've found an example geo-rss feed [[here|http://www.fao.org/geonetwork/srv/en/rss.latest?georss=simple]], and I've used [[dipity|http://www.dipity.com]] to map it out.

>My next task is figuring out how to add this to my blog content so I can map my posts, which seems to me that it may have something to do with changing the way the rss feed is generated in tiddlywiki:

>Seeing as the RSS feed is generated like this for the [[example geo rss feed||http://www.fao.org/geonetwork/srv/en/rss.latest?georss=simple]] I found earlier looks like this:
{{{
<rss xmlns:gml="http://www.opengis.net/gml" 
     xmlns:georss="http://www.georss.org/georss" 
     xmlns:media="http://search.yahoo.com/mrss/" 
     version="2.0">
}}}

>And my blog's RSS feed kinda like this:
{{{
<?xml version="1.0"?>
<rss version="2.0">
}}}

>I need to find a way to put the three xml namespaces in the rss of the blog.

There also appears to be a microformat for this:
{{{
<span class="georss:point" title="43.3432 -69.2341">Here is a point</span>
}}}

<html>
<body>
<span class="georss:point" title="43.3432 -69.2341">Here is a point</span>
</body>
</html>

Ah, I seem to have found a function in the tiddlywiki called {{{generateRss()}}} which generates the headers for the RSS feed, I will either have to [[override|http://tiddlywikiguides.org/index.php?title=Overriding_core_functions]] this method in a plugin (if you can do that...) or modify the code myself.
[[From Wikipedia|http://en.wikipedia.org/wiki/GTD]]

//Getting Things Done// (commonly abbreviated as GTD) is an action management method created by David Allen, and described in a book of the same name.  Both "Getting Things Done" and "GTD" are registered trademarks of the David Allen Company.

GTD rests on the principle that a person needs to move tasks out of the mind by recording them externally.  That way, the mind is freed from the job of remembering everything that needs to be done, and can concentrate on actually performing those tasks.

!GTD Methodology
GTD is defined by David Allen on his website.  In traditional time management, priorities usually play a central role.  In contrast, Allen promotes two key elements in his version of time management:
*control 
*perspective

Allen advocates three major models for gaining control and perspective:
#A workflow process
#A framework with 6 levels of focus
#A natural planning method.

The first major model is the //workflow process,// which is used to gain control over all the tasks and commitments which one needs or wants to get done.

!!Work Flow Phases
The [[workflow process|Work Flow Phases - GTD]] consists of five distinct phases listed below:
#[[Collect|Collect - GTD]]
#[[Process|Process - GTD]]
#[[Organize|Organize - GTD]]
#[[Review|Review - GTD]]
#[[Do|Do - GTD]]

!!Six Levels of Focus
Allen uses an altitude analogy to illustrate his second major model, [[6 Different Levels of Focus|6 Levels of Focus - GTD]], from the bottom up, are:
#[[Current Actions|Current Actions - GTD]]
#[[Current Projects|Current Projects - GTD]]
#[[Areas of Responsibility|Areas of Responsibility - GTD]]
#[[Yearly Goals|Yearly Goals - GTD]]
#[[5 Year Vision|5 Year Vision - GTD]]
#[[Life Goals|Life Goals]]
As one ascends in altitude, one is able to consider the "bigger picture."  
Considering: 
*projects
*actions 
*unfinished business
*commitments 
("open loops" in GTD terminology) and other "input" from a variety of "heights" gives one varying perspective.

Allen advocates a weekly review focused on different levels.  The perspective gained from these reviews.  The perspective gained from these reviews should drive one's priorities, which in turn determines the priority of if and when one is to do the particular individual tasks and commitments gathered during the workflow process.  During a weekly review, the user determines the context for the tasks and places them on the appropriate lists.  

Examples of grouping together similar tasks include:
*Making a list of telephone calls to make.
*Making a list of errands to do while downtown.

Context lists can be defined by the set of tools available or by the presence of individuals or groups for whom one has items to discuss or present.

Allen expects that the first two models are sufficient most of the time to gain control and perspective on the majority of tasks and projects.  However, there are some cases in which more involved planning and thinking are necessary.  This leads to the third major model, which is the [[natural planning method|Natural Planning Method - GTD]].  

!!The Natural Planning Model
While the [[Workflow Model|Workflow Model - GTD]] has a "horizontal" focus on doing individual tasks, the [[Natural planning method|Natural Planning Model - GTD]] has a "vertical" focus on planning projects and thinking through topics.

The [[Planning Model|Natural Planning Model - GTD]] consists of 5 stages:
#[[Defining the purpose and principles|Defining the Purpose and Principles - GTD]]
#[[Envisioning the outcome|Envisioning The Outcome - GTD]]
#[[Brainstorming|Brainstorming - GTD]]
#[[Organizing|Organizing - GTD]]
#[[Identifying next actions|Identifying Next Actions]]

GTD is based on making it easy to:
*Store
*Track
*Retrieve
all information related to the things that need to get done.  Allen suggests that many of the mental blocks we encounter are cuased by insufficient 'front-end' planning (i.e., for any project we need to clarify what is to be achieved and what specific actions are required to achieve it.).  It is most practical, according to Allen, to do this thinking in advance, generating a series of actions which we can later undertake without any further planning.

Allen contends that our mental "reminder" system is inefficient and seldom reminds us of what we need to do at the time and place that we can do it.

Consequently, the "next actions" stored by context in the "trusted system" act as an external support which ensures that we are presented with the right reminds at the right time.

A capsule of GTD from Allen's book __//Ready for Anything//__:
>"Get everything out of your head.  Make decisions about actions required on stuff when it shows up - not when it blows up.  Organize reminds of your projects and the next actions on them in appropriate categories.  Keep your system current, complete and reviewed sufficiently to trust your intuitive choices about what you are doing (and not doing) at any time.

<<tiddler "GTD Tools and Techniques">>
Browser sessions can quickly get unruly and swallow up massive swathes of your computer's memory.  When this occurs, often the browser becomes prone to crashes and thus you loose your work; And although this has been made better by browsers which restore your session (i.e. opening every window that was open at the time of the crash) it is still a sub-optimal solution since you still load up all of the windows back into memory that you originally had open (causing yet another enviable crash at some time down the road).  

Enter the [[Session Manager|https://addons.mozilla.org/en-US/firefox/addon/session-manager/]] plugin for Firefox.  The session manager helps keep the unruly number of tabs you may have open at any given time in memory in check by organizing them into sessions (//read:// groups of urls, windows and tabs) that work just like the return of the windows that are persisted when Firefox crashes, except that it give you control over all the groups of windows that you want to open at a given time, instead of having only a single persistent session when the browser is closed or crashes.  

The utility is limitless!  Need to quick switch between tasks?  
For instance suppose one client needs you to work on their firewall configuration, and another client needs you to add html5 microformats to their website.

These are completely different tasks with completely different sets of documentation that need looked at.  So we can make one session for the firewall client, and make another session for the html5 client.  Then you can easily switch between them if say for instance you're working on the firewall when the html5 client calls you, you can easily switch sessions (without having the windows for both tasks open at the same time).

While I'm aware of [[tab candy|http://vimeo.com/13560319]] that Firefox offers, [[tab candy|http://vimeo.com/13560319]] works more like a messy desk than it does a solid pattern for being able to store and organize groups of urls for use at a later time.  [[Tab candy|http://vimeo.com/13560319]] is also limited to only one level of storage where as [[Session Manager|https://addons.mozilla.org/en-US/firefox/addon/session-manager/]] has a way of grouping sessions into single level folders, making it especially great for re-opening documentation on bugs that may be reopened over time.

The easiest way to split an unruly Firefox session into something manageable is to:
#Open a text editor
#Go through your tabs one by one and add them to a list like so...
**(Of course I'm using stupid examples but it's just so you get the idea)
{{{
Router Stuff
- http://www.openwrt.org
- http://www.ip6tables.org

Social Networking
- http://plus.google.com
- http://www.facebook.com
- http://www.twitter.com
- http://www.myspace.com

etc...
}}}

And then close out all of your windows and start opening the urls from above in one single list, in windows as you would have them organized.  

For example you might take all of the urls listed under {{{Router Stuff}}} and open them in two separate tabs or windows...

After you have opened them click the orange Firefox logo at the top of the window, and click {{{Session Manager -> Session Manager -> Save Session}}}.

The {{{Session Manager}}} dialog will appear and you can enter a name as well as a group for the session. 

If you want subsequent windows that you open with the session to be saved and added to the session when you are using the session and open them again check {{{Make this an auto-save session}}}.

>In some cases I would recommend this, but in other cases I would not.  It's probably better to re-save your session manually, adding the new windows because it forces you to think before mindlessly adding more urls to the session; this kind of defeats the point of removing the clutter in the first place.

Lastly when you're done, click the {{{Save}}} dropdown button at the top left part of the window and click {{{save}}}.

Now that particular session will appear in the {{{Firefox -> Session Manager}}} menu under the group you categorized it under.

Now repeat the process for the other URLs in the list.  Now, isn't that less clutter and less memory?  Feels great doesn't it?  

I looked today to see if there was a way to get a commenting system in place on this blog.  I checked the [[TiddlySpot FAQ|http://faq.tiddlyspot.com/]] and it said that if I use a service called [[Haloscan|http://www.haloscan.com/]] combined with a [[macro for haloscan|http://end.com/~speth/HaloscanMacro.html]],  I can actually have users comment on my blog entries.  

	However, it appears that their service is currently down.  I'll have to try this another day.  Feedback in this blog would really be great!  I can't wait to try it!
I'm at the womelsdorf library and I'm using a monitor that isn't hard on the eyes at all it's called a [[ViewSonic VA912b|http://www.viewsonic.com/products/desktopdisplays/lcddisplays/valueseries/va912b/]]

(I was running it at 1024x768)

And here's the bit that makes all the difference:
''Panel Surface:'' Anti-glare 

>It just so happens you can write groovy scripts that can be evaluated inside of Freemind beta.  Sweet! Here we go...strait from the [[freemind wiki|http://freemind.sourceforge.net/wiki/index.php/FreeMind_0.9.0:_The_New_Features#Scripting_via_Groovy]]:

{{{
def log = c.getFrame().getLogger(this.getClass().getName());

log.info("groovy script start!");
log.info("node.isLeaf(): " + node.isLeaf());
log.info("node.getChildCount(): " + node.getChildCount());
log.info("node.getClass().getName(): " + node.getClass().getName());
}}}

Yields the following results:

{{{
    note.isLeaf(): false
    node.getChildCount(): 3
    node.getClass().getName(): freemind.modes.mindmapmode.MindMapNodeModel
}}}


!Scripting via Groovy
Groovy scripts may be attached to individual nodes in that map.  

When the "evaluate" is selected via the menu or keypress ''(Alt-F8)'', all nodes in the map are searched (depth-first) for one or more attributes named {{{script}}}.  If such an attribute is found, the value of the attached attribute is passed to the Groovy engine to execute.

Only nodes are evaluated, which attribute keys start with {{{script}}}.  However there is noting preventing a script on one node from acting on other nodes via normal operations (e.g. {{{node.getChildren()}}} or similar) as far as I can tell from the code.

!Assignment vs. Operation
If the value of the script attribute starts with the equals sign {{{"="}}}, the the node text will be replaced by the RESULT of the script evaluation.  Be careful not to overwrite your nodes!  See the example for using the {{{"node.getText()"}}} in an assignment script.

If the value of the script attribute does not begin with the equals sign, then the script will run and may affect the map, but the expression result is not assigned to the node text.
I just figured out a neater way to group together related sets of questions using [[del.icio.us|http://del.icio.us/]].

Today I was trying to figure out how to [[Unzip Files in C++|Unzipping Files in C++]], we'll use this an our example.

I have five questions that I need answered concerning this issue:

*[[projects|http://delicious.com/leeand00/projects]]
**[[xetex-unzip|http://delicious.com/leeand00/xetex-unzip]] (tagged with [[projects|http://delicious.com/leeand00/projects]])
***[[question 1|http://stackoverflow.com/questions/1833888/unziping-files-to-existing-directories-in-visual-studio-2005-c]] (tagged with [[xetex-unzip|http://delicious.com/leeand00/xetex-unzip]]
***[[question 2|http://stackoverflow.com/questions/1836191/tips-for-writing-the-least-verbose-visual-c-code-you-can-in-visual-studio-2005/1836295#1836295]] (tagged with [[xetex-unzip|http://delicious.com/leeand00/xetex-unzip]])
***[[question 3|http://stackoverflow.com/questions/1837333/which-version-of-zlib-should-i-use-with-visual-c-on-visual-studio-2005]] (tagged with [[xetex-unzip|http://delicious.com/leeand00/xetex-unzip]])
***[[question 4|http://stackoverflow.com/questions/1837312/which-version-of-boost-should-i-use-with-c-visual-studio-2005]] (tagged with [[xetex-unzip|http://delicious.com/leeand00/xetex-unzip]])

When you click any of the links I've created above their children display, making a hierarchy of tags.
>No I think you have it backwards, God is always here but if you don't have faith in him it does not matter if you believe in him because he is not a positive force in your life. Like if I have a car and I don't have faith in its abilities then the car is nothing to me because I won't use it. you see what I mean......... :) x
- [[source|http://uk.answers.yahoo.com/question/index?qid=20080719130827AAjySLw]]
A while ago I started making a blog theme for Wordpress to try out some HTML 5.  I started making it, [[read about how HTML 5 handles headers differently to make way for screen readers|http://diveintohtml5.info/semantics.html#new-elements]].  At that time I structured pages in this blog theme with {{{<header>}}}s {{{<footer>}}}s and {{{<sections>}}}. Though the semantic markup looked a little verbose to me, but I continued along following what I knew about it from my reading.  

Then it came time to start coding the CSS for the site.  At that point my CSS, though well organized ended up becoming (unbelievably) more verbose than my semantic markup; "What have I done wrong?" I wondered to myself.   Well today after buying a book called [[Smashing Book 4|http://www.smashingmagazine.com/smashing-book-4-new-perspectives/]] and starting upon the first chapter, I found a footnote that led to the blog of [[stubbornella|http://www.stubbornella.org/content/2011/09/06/style-headings-using-html5-sections/]].  The first chapter of [[Smashing Book 4|http://www.smashingmagazine.com/smashing-book-4-new-perspectives/]] drove home the point that using selectors and id tags to style your CSS elements is evil, and that you should use reusable classes instead.  And [[stubbornella|http://www.stubbornella.org/content/2011/09/06/style-headings-using-html5-sections/]]'s blog drove this point home even further when she pointed out the error of the exact reason for my CSS code verbosity: Using section element selectors to style much of my content.  I verified this on the [[Programmers Stackexchange|http://programmers.stackexchange.com/questions/220791/why-are-section-header-and-footer-tags-not-used-much-when-i-see-sit?noredirect=1#220791]] where I was rightly beaten over the head with a few downvotes to remind me that the HTML5 spec is not yet officially released.

With that said I believe I have some major stylesheet refactoring to.
Things which absolutely have to be done by a particular deadline or meetings and appointments which are fixed in time and place.
<html>
<body>
<iframe width="420" height="345" src="http://www.youtube.com/embed/p5mWQFGF7w8" frameborder="0" allowfullscreen></iframe>
</body>
</html>
I think I first read Hitchhikers Guide to the Galaxy when I was about 12 years old.  I remember coming across the following passage, which didn't bother me at the time, but after a few Philosophy classes in college, it really bugged me for years:

>"I refuse to prove that I exist," says God, "for proof denies faith, and without faith I am nothing."
>"But," says Man, "the Babel fish is a dead giveaway isn't it? It could not have evolved by chance. It proves that You exist, and so therefore, by Your own arguments, You don't. Q.E.D."
>"Oh dear," says God, "I hadn't thought of that," and promptly vanishes in a puff of logic.
>"Oh, that was easy," says Man, and for an encore goes on to prove that black is white and gets himself killed on the next zebra crossing.
[[Demonstration of the rationalist/fideist paradox in H2G2|http://en.wikipedia.org/wiki/Fideism#In_culture]]

Though I comprehended most of it, I didn't quite comprehend the line {{{and without faith I am nothing}}}. 

I didn't quite understand why God would be nothing if not for faith...so I did some Googling and as usual found someone else asking my question:


>If god is nothing without faith,....?
>does that mean lack of faith makes god non-existent?
[[link|http://uk.answers.yahoo.com/question/index?qid=20080719130827AAjySLw]]

Despite it not being the number one answer, these two answers made the most sense to me:
<<tabs "cookie" 
            "1" "H2G2 helpful answer 1" "H2G2 helpful answer 1"
            "2" "Hitchhikers Guide to The Galaxy and The Babel Fish...helpful answer 2" "Hitchhikers Guide to The Galaxy and The Babel Fish...helpful answer 2">>

So instead here is the re-written version of the paradox:

>"I refuse to prove that I exist," says God, "for proof denies faith, and without faith I am nothing, @@to you who doesn't believe in me@@"
>Your assumption that God exists ONLY if faith exists is erroneous.
>
>God exists whether or not we believe in Him.
>
>Having faith in Him doesn't mean that He has suddenly "POPPED" into existence!!!! Sorry, but that's an utterly rediculous idea.
>
>Let's see now... in the "OLD" days, before "White Man" discovered and explored the continent of Austrailia, NO White man had ever seen a Duck-billed Platypus.... nor did the scientists of that day even believe that such a "mixed-up" animal could EXIST.
>
>But it did... for THOUSANDS, if not millions of years, it existed and lived, thrived and roamed the lands of Austrailia.
>
>Now, even when the White explorers returned to Europe, with drawings, even LIVING platypuses, many scientists STILL REFUSED to believe it's existence. They thought these were HOAXES.
>
>So what makes God's existence any different?
>
>So, if the Duck-billed platypus is nothing without anyone believing it exists, does that mean they don't exist because no one believes they exist?
>
>
>Have a blessed day.
- [[source|http://uk.answers.yahoo.com/question/index?qid=20080719130827AAjySLw]]
[[article link|http://www.codeproject.com/KB/cpp/complex_declarations.aspx]] | [[By Vikram A Punathambekar|http://www.codeproject.com/script/Articles/MemberArticles.aspx?amid=55714]]

>Ever came across a declaration like {{{int * ( * (*fp1) (int) ) [10] }}} or something similar that you couldn't fathom?  This article will teach you to interpret such complex C/C++ declarations, including the use of typedef, const and function pointers.

!Contents
*[[Introduction|How to interpret complex C/C++ declarations - Introduction]]
*[[The Basics|How to interpret complex C/C++ declarations - The Basics]]
*[[The const modifier|How to interpret complex C/C++ declarations - The const modifier]]
*[[The subtleties of typedef|How to interpret complex C/C++ declarations - the subleties of typedef]]
*[[Function Pointers|How to interpret complex C/C++ declarations - Function Pointers]]
*[[The right-left rule|How to interpret complex C/C++ declarations - The right-left rule]] [Important]
*[[Further Examples|How to interpret complex C/C++ declarations - Further examples]]
*[[Credits|How to interpret complex C/C++ declarations - Credits]]
Function pointers are probably the greatest source of confusion when it comes to interpreting declarations.  Function pointers were used in the old DOS days for writing TSRs; in the Win32 world and X-Windows, they are used in callback functions.  There are lots of other places where function pointers are used: 
*Virtual Function Tables
*Some Templates in STL
*Win NT/2K/XP system services.  Let's see a simple example of a funcition pointer:
{{{
int (*p)(char);
}}}
This declares {{{p}}} as a pointer to a function that takes a {{{char}}} argument and returns and {{{int}}}.

A pointer to a function that takes two {{{float}}}s and returns a pointer to a pointer to a {{{char}}} would be declared as:
{{{
void * (*a[5]) (char * const, char * const);
}}}
Ever came across a declaration like {{{int * ( * (*fp1) (int) ) [10];}}} or something similar that you couldn't fathom?  This article will teach you to interpret C/C++ declarations, starting from mundane ones //(Please bear with me here)// and move on to very complex ones.  We shall see examples of declarations that we come across in everyday life, then move on to the troublesome {{{const}}} modifier and {{{typedef}}}, conquer function pointers, and finally see the [[right-left rule]], which will allow you to interpret any C/C++ declaration accurately.  I would like to emphasize that it is __not__ considered good practice to write messy code like this;  I'm merely teaching you how to understand such declarations.  
Let me start with a very simple example.  Consider the declaration:
{{{
int n;
}}}

This should be interpreted as ''"declare {{{n}}} as an {{{int}}} "''.

Coming to the declaration of a pointer variable, it would be declared as something like:
{{{
int* p;
}}}
This is to be interpreted as ''"declare {{{p}}} as an {{{int *}}}"'' i.e., as a pointer to an {{{int}}}.  
>I'll need to make a small note here
>>It is always better to write a pointer (or reference) declaration with the {{{*}}} (or {{{&}}}) preceding the variable rather than following the base type.  This is to ensure there are no slip-ups when making declarations like:
{{{
int* p, q;
}}}
At first sight, it looks like {{{p}}} and {{{q}}} have been declared to be of type {{{int *}}}, but actually, it is only {{{p}}} that is a pointer, {{{q}}} is a simple int.
----
We can have a pointer to a pointer, which can be declared as:
{{{
char **argv;
}}}
In principle, there is no  limit to this, which means you can have a pointer to a pointer to a pointer to a {{{float}}}, and so on.

Consider the declarations:
{{{
int RollNum[30][4];
int (*p) [4]=RollNum;
int *q[5];
}}}

Here, {{{p}}} is declared as a pointer to an array of 4 {{{int}}}s, while {{{q}}} is declared as an array of 5 pointers to integers.

We have a mixed bag of {{{*}}}s and {{{&}}}s in a single declaration, as explained below:

{{{
int **p1;      // p1 is a pointer to a pointer to an int.

int *&p2;     // p2 is a reference to a pointer to an int.

int &*p3;     // ERROR: Pointer to a reference is illegal.

int &&p4;    // ERROR: Reference to a reference is illegal.

}}}
The {{{const}}} keyword is used when you want to prevent a variable (oops, that's an oxymoron) from being modified.  When you declare a {{{const}}} variable, you need to initialize it, because you can't give it a value at any other time.
{{{
const int n = 5;
int const m = 10;
}}}
The two variables {{{n}}} and {{{m}}} above are both of the same type - constant integers.  This is because the C++ standard states that the {{{const}}} keyword can be placed before the type or the variable name.  Personally, I prefer using the first style, since it makes the {{{const}}} modifier stand out more clearly.

{{{const}}} is a bit more confusing thwn it comes to dealing with pointers.  For instance, consider the two variables {{{p}}} and {{{q}}} in the declaration below:

{{{
const int *p;
int const *q;
}}}

Which of them is a pointer to a {{{const int}}}, and which is a {{{const}}} pointer to an {{{int}}}?  Actually, they're both pointers to {{{const int}}}s.  A {{{const}}} pointer to an {{{int}}} would be declared as:
{{{
int * const r= &n; // n has been declared as an int
}}}

Here, {{{p}}} and {{{q}}} are pointers to a {{{const int}}}, which means that you can't change the value of {{{*p}}}.  {{{r}}} is a {{{const}}} pointer, which means that once declared as above, an assignment like {{{r=&m;}}} would be illegal (where {{{m}}} is another {{{int}}}).but the value of {{{*r}}} can be changed.

To combine these two declarations to declare a {{{const}}} pointer to a {{{const int}}}, you would have to declare it as:
{{{
const int * const p = &n;  // n has been declared as const int.
}}}

The following declarations should clear up any doubts over how {{{const}}} is to be interpreted.  Please note that some of the declarations will NOT compile unless they are assigned values during declaration itself.  I have omitted them for clarity, and besides, adding that will require another two lines of code for each example.
{{{
char ** p1;			// Pointer to	Pointer to	char

const char **p2;	     // Pointer to 	Pointer to const char

char * const * p3; 	     // Pointer to const pointer to 	 char

const char * const * p4;  // Pointer to const pointer to const char

char ** const p5;	     // const pointer to	pointer to	char

const char ** const p6;   // const pointer to	     pointer to      char 

char * const * const p7;  // const pointer to const pointer to 	  char

const char * const * const p8; // const pointer to const pointer to const char
}}}
This is a simple rule that allows you to interpret any declaration.  It runs as follows:

Start reading the declaration from the innermost parentheses, go right and then go left.  When you encounter parentheses, the direction should be reversed.  Once everything in the parentheses has been parsed, jump out of it.  Continue till the whole declaration has been parsed.

One small change to the right-left rule:  When you start reading the declaration for the first time, you have to start from the identifier, and not the innermost parentheses.

!Examples:
<<tabs "7/10/20084:20 PMs" 
      "Example 1" "How to interpret complex C/C++ declarations - The right-left rule example" "How to interpret complex C/C++ declarations - The right-left rule example">>
{{{
int * (* (*fp1) (int) ) [10];
}}}

This can be interpreted as follows //(read the right-most column up and down when finished)//:
|1. |Start from the variable name | {{{fp1}}} |
|2. |Nothing to the right but ) so go left to find {{{*}}} | is a pointer |
|3. |Jump out of parenteses and encounter ({{{int}}}) | to a function that takes an {{{int}}} as argument. |
|4. | Go left, find {{{*}}} | and returns a pointer |
|5. |Jump out of parentheses, go right and hit {{{[10]}}} | to an array of 10 |
|6. |Go left find {{{*}}} | pointers to |
|7. |Go left again, find {{{int}}} | {{{int}}}s |
!Result
{{{fp1}}} is a pointer to a function that takes an {{{int}}} as argument, and returns a pointer, to an array of 10 pointers to {{{int}}}s.
{{{
int *( *( *arr[5]) ()) ();
}}}

|1. |  |  |
{{{typedef}}} allows you a way to overcome the +++^10em^[*-applies-to-variable-not-type rule]Remember this?<br/>{{{int* p, q;}}} <br/> and how they're not both pointers?===.  If you use  {{{typedef}}} like:

{{{
typedef char * PCHAR;
PCHAR p,q;
}}}

both {{{p}}} and {{{q}}} become pointers.  If the {{{typedef}}} had not been used, {{{q}}} would be a {{{char}}}, which is counter-intuitive.

Here are a few declarations made using {{{typedef}}}, along with the explanation:

{{{
typedef char * a;	// a is a pointer to a char

typedef a b();		 // b is a function that returns 
			       // a pointer to a char

typedef b *c;		// c is a pointer to a function

typedef c d();		// d is a function returning
			      // a pointer to a function
			      // that returns a pointer to a char

type def d *e;		// e is a pointer to a function
			      // returning a pointer to a
			      // function that returns a 
			      // pointer to a char.

e var[10];		  // var is an array of 10 pointers to 
			      // functions returning pointers to
			      // functions returning pointers to chars.
}}}

{{{typedef}}}s are usually used with structured declarations as shown below.  The following structure declaration allows you to omit the {{{struct}}} keyword when you create variables even in C, as is normally done in C++.

{{{
typedef struct tagPOINT
{
	int x;
	int y;
}POINT;

POINT p; /* Valid C code */
}}}
[[article link|http://hotjobs.yahoo.com/resume/Five_Common_Cover_Letter_Mistakes__2003228-1318.html?subtopic=Cover+Letters]]
#Read the document out loud.
**You may catch spelling errors you may have missed //({{{jog}}} instead of {{{job}}})//
#Only after you have double checked your cover letter should you attach it and send it off.
#Make sure you've added exactly which job you are applying for.
#Research the Company
#Make sure you don't repeat yourself.
<html>
<body>
<a href="http://ipv6.he.net/certification/scoresheet.php?pass_name=leeand00" target="_blank"><img src="http://ipv6.he.net/certification/create_badge.php?pass_name=leeand00&badge=1" width=128 height=128 border=0 alt="IPv6 Certification Badge for leeand00"></img></a>
</body>
</html>
|!Placement in List |!Corresponding Id in Database|
| 1 | 15 |
#Installed Ruby [[eariler|Compass and Webby]]
#Installed Red Cloth:
{{{
apt-get install libredcloth-ruby1.8
}}}
#Installed ruby1.8-dev (thanks to [[phresus and mando|http://stackoverflow.com/questions/520862/installing-webby-on-ubuntu]])
{{{
apt-get install ruby1.8-dev
}}}
#Installed hpricot 0.6
{{{
sudo gem install hpricot --version=0.6.0
}}}
#Installed webby
{{{
sudo gem install webby
}}}
#Installed bones (dependency required by webby after I tried to run it)
{{{
sudo gem install bones
}}}
#Installed cucumber (dependency required by webby after I tried to run it again...)
{{{
sudo gem install cucumber
}}}
#Installed hoe (dependency required by webby after I tried to run it again...curious name on that one...)
{{{
sudo gem install cucumber
}}}
#Installed RedCloth
{{{
sudo gem install RedCloth
}}}
/***
|''Name:''|IntelliTaggerPlugin|
|''Version:''|1.0.2 (2007-07-25)|
|''Type:''|plugin|
|''Source:''|http://tiddlywiki.abego-software.de/#IntelliTaggerPlugin|
|''Author:''|Udo Borkowski (ub [at] abego-software [dot] de)|
|''Documentation:''|[[IntelliTaggerPlugin Documentation]]|
|''~SourceCode:''|[[IntelliTaggerPlugin SourceCode]]|
|''Licence:''|[[BSD open source license (abego Software)]]|
|''~CoreVersion:''|2.0.8|
|''Browser:''|Firefox 1.5.0.2 or better|
***/
/***
!Version History
* 1.0.2 (2007-07-25): 
** Feature: "Return" key may be used to accept first tag suggestion (beside "Alt-1")
** Bugfix: Keyboard shortcuts (Alt+3 etc.) shifted
* 1.0.1 (2007-05-18): Improvement: Speedup when using TiddlyWikis with many tags
* 1.0.0 (2006-04-26): Initial release

***/
// /%
if(!version.extensions.IntelliTaggerPlugin){if(!window.abego){window.abego={};}if(!abego.internal){abego.internal={};}abego.alertAndThrow=function(s){alert(s);throw s;};if(version.major<2){abego.alertAndThrow("Use TiddlyWiki 2.0.8 or better to run the IntelliTagger Plugin.");}version.extensions.IntelliTaggerPlugin={major:1,minor:0,revision:2,date:new Date(2007,6,25),type:"plugin",source:"http://tiddlywiki.abego-software.de/#IntelliTaggerPlugin",documentation:"[[IntelliTaggerPlugin Documentation]]",sourcecode:"[[IntelliTaggerPlugin SourceCode]]",author:"Udo Borkowski (ub [at] abego-software [dot] de)",licence:"[[BSD open source license (abego Software)]]",tiddlywiki:"Version 2.0.8 or better",browser:"Firefox 1.5.0.2 or better"};abego.createEllipsis=function(_2){var e=createTiddlyElement(_2,"span");e.innerHTML="&hellip;";};abego.isPopupOpen=function(_4){return _4&&_4.parentNode==document.body;};abego.openAsPopup=function(_5){if(_5.parentNode!=document.body){document.body.appendChild(_5);}};abego.closePopup=function(_6){if(abego.isPopupOpen(_6)){document.body.removeChild(_6);}};abego.getWindowRect=function(){return {left:findScrollX(),top:findScrollY(),height:findWindowHeight(),width:findWindowWidth()};};abego.moveElement=function(_7,_8,_9){_7.style.left=_8+"px";_7.style.top=_9+"px";};abego.centerOnWindow=function(_a){if(_a.style.position!="absolute"){throw "abego.centerOnWindow: element must have absolute position";}var _b=abego.getWindowRect();abego.moveElement(_a,_b.left+(_b.width-_a.offsetWidth)/2,_b.top+(_b.height-_a.offsetHeight)/2);};abego.isDescendantOrSelf=function(_c,e){while(e){if(_c==e){return true;}e=e.parentNode;}return false;};abego.toSet=function(_e){var _f={};for(var i=0;i<_e.length;i++){_f[_e[i]]=true;}return _f;};abego.filterStrings=function(_11,_12,_13){var _14=[];for(var i=0;i<_11.length&&(_13===undefined||_14.length<_13);i++){var s=_11[i];if(s.match(_12)){_14.push(s);}}return _14;};abego.arraysAreEqual=function(a,b){if(!a){return !b;}if(!b){return false;}var n=a.length;if(n!=b.length){return false;}for(var i=0;i<n;i++){if(a[i]!=b[i]){return false;}}return true;};abego.moveBelowAndClip=function(_1b,_1c){if(!_1c){return;}var _1d=findPosX(_1c);var _1e=findPosY(_1c);var _1f=_1c.offsetHeight;var _20=_1d;var _21=_1e+_1f;var _22=findWindowWidth();if(_22<_1b.offsetWidth){_1b.style.width=(_22-100)+"px";}var _23=_1b.offsetWidth;if(_20+_23>_22){_20=_22-_23-30;}if(_20<0){_20=0;}_1b.style.left=_20+"px";_1b.style.top=_21+"px";_1b.style.display="block";};abego.compareStrings=function(a,b){return (a==b)?0:(a<b)?-1:1;};abego.sortIgnoreCase=function(arr){var _27=[];var n=arr.length;for(var i=0;i<n;i++){var s=arr[i];_27.push([s.toString().toLowerCase(),s]);}_27.sort(function(a,b){return (a[0]==b[0])?0:(a[0]<b[0])?-1:1;});for(i=0;i<n;i++){arr[i]=_27[i][1];}};abego.getTiddlerField=function(_2d,_2e,_2f){var _30=document.getElementById(_2d.idPrefix+_2e);var e=null;if(_30!=null){var _32=_30.getElementsByTagName("*");for(var t=0;t<_32.length;t++){var c=_32[t];if(c.tagName.toLowerCase()=="input"||c.tagName.toLowerCase()=="textarea"){if(!e){e=c;}if(c.getAttribute("edit")==_2f){e=c;}}}}return e;};abego.setRange=function(_35,_36,end){if(_35.setSelectionRange){_35.setSelectionRange(_36,end);var max=0+_35.scrollHeight;var len=_35.textLength;var top=max*_36/len,bot=max*end/len;_35.scrollTop=Math.min(top,(bot+top-_35.clientHeight)/2);}else{if(_35.createTextRange!=undefined){var _3b=_35.createTextRange();_3b.collapse();_3b.moveEnd("character",end);_3b.moveStart("character",_36);_3b.select();}else{_35.select();}}};abego.internal.TagManager=function(){var _3c=null;var _3d=function(){if(_3c){return;}_3c={};store.forEachTiddler(function(_3e,_3f){for(var i=0;i<_3f.tags.length;i++){var tag=_3f.tags[i];var _42=_3c[tag];if(!_42){_42=_3c[tag]={count:0,tiddlers:{}};}_42.tiddlers[_3f.title]=true;_42.count+=1;}});};var _43=TiddlyWiki.prototype.saveTiddler;TiddlyWiki.prototype.saveTiddler=function(_44,_45,_46,_47,_48,_49){var _4a=this.fetchTiddler(_44);var _4b=_4a?_4a.tags:[];var _4c=(typeof _49=="string")?_49.readBracketedList():_49;_43.apply(this,arguments);if(!abego.arraysAreEqual(_4b,_4c)){abego.internal.getTagManager().reset();}};var _4d=TiddlyWiki.prototype.removeTiddler;TiddlyWiki.prototype.removeTiddler=function(_4e){var _4f=this.fetchTiddler(_4e);var _50=_4f&&_4f.tags.length>0;_4d.apply(this,arguments);if(_50){abego.internal.getTagManager().reset();}};this.reset=function(){_3c=null;};this.getTiddlersWithTag=function(tag){_3d();var _52=_3c[tag];return _52?_52.tiddlers:null;};this.getAllTags=function(_53){_3d();var _54=[];for(var i in _3c){_54.push(i);}for(i=0;_53&&i<_53.length;i++){_54.pushUnique(_53[i],true);}abego.sortIgnoreCase(_54);return _54;};this.getTagInfos=function(){_3d();var _56=[];for(var _57 in _3c){_56.push([_57,_3c[_57]]);}return _56;};var _58=function(a,b){var a1=a[1];var b1=b[1];var d=b[1].count-a[1].count;return d!=0?d:abego.compareStrings(a[0].toLowerCase(),b[0].toLowerCase());};this.getSortedTagInfos=function(){_3d();var _5e=this.getTagInfos();_5e.sort(_58);return _5e;};this.getPartnerRankedTags=function(_5f){var _60={};for(var i=0;i<_5f.length;i++){var _62=this.getTiddlersWithTag(_5f[i]);for(var _63 in _62){var _64=store.getTiddler(_63);if(!(_64 instanceof Tiddler)){continue;}for(var j=0;j<_64.tags.length;j++){var tag=_64.tags[j];var c=_60[tag];_60[tag]=c?c+1:1;}}}var _68=abego.toSet(_5f);var _69=[];for(var n in _60){if(!_68[n]){_69.push(n);}}_69.sort(function(a,b){var d=_60[b]-_60[a];return d!=0?d:abego.compareStrings(a.toLowerCase(),b.toLowerCase());});return _69;};};abego.internal.getTagManager=function(){if(!abego.internal.gTagManager){abego.internal.gTagManager=new abego.internal.TagManager();}return abego.internal.gTagManager;};(function(){var _6e=2;var _6f=1;var _70=30;var _71;var _72;var _73;var _74;var _75;var _76;if(!abego.IntelliTagger){abego.IntelliTagger={};}var _77=function(){return _72;};var _78=function(tag){return _75[tag];};var _7a=function(s){var i=s.lastIndexOf(" ");return (i>=0)?s.substr(0,i):"";};var _7d=function(_7e){var s=_7e.value;var len=s.length;return (len>0&&s[len-1]!=" ");};var _81=function(_82){var s=_82.value;var len=s.length;if(len>0&&s[len-1]!=" "){_82.value+=" ";}};var _85=function(tag,_87,_88){if(_7d(_87)){_87.value=_7a(_87.value);}story.setTiddlerTag(_88.title,tag,0);_81(_87);abego.IntelliTagger.assistTagging(_87,_88);};var _89=function(n){if(_76&&_76.length>n){return _76[n];}return (_74&&_74.length>n)?_74[n]:null;};var _8b=function(n,_8d,_8e){var _8f=_89(n);if(_8f){_85(_8f,_8d,_8e);}};var _90=function(_91){var pos=_91.value.lastIndexOf(" ");var _93=(pos>=0)?_91.value.substr(++pos,_91.value.length):_91.value;return new RegExp(_93.escapeRegExp(),"i");};var _94=function(_95,_96){var _97=0;for(var i=0;i<_95.length;i++){if(_96[_95[i]]){_97++;}}return _97;};var _99=function(_9a,_9b,_9c){var _9d=1;var c=_9a[_9b];for(var i=_9b+1;i<_9a.length;i++){if(_9a[i][1].count==c){if(_9a[i][0].match(_9c)){_9d++;}}else{break;}}return _9d;};var _a0=function(_a1,_a2){var _a3=abego.internal.getTagManager().getSortedTagInfos();var _a4=[];var _a5=0;for(var i=0;i<_a3.length;i++){var c=_a3[i][1].count;if(c!=_a5){if(_a2&&(_a4.length+_99(_a3,i,_a1)>_a2)){break;}_a5=c;}if(c==1){break;}var s=_a3[i][0];if(s.match(_a1)){_a4.push(s);}}return _a4;};var _a9=function(_aa,_ab){return abego.filterStrings(abego.internal.getTagManager().getAllTags(_ab),_aa);};var _ac=function(){if(!_71){return;}var _ad=store.getTiddlerText("IntelliTaggerMainTemplate");if(!_ad){_ad="<b>Tiddler IntelliTaggerMainTemplate not found</b>";}_71.innerHTML=_ad;applyHtmlMacros(_71,null);refreshElements(_71,null);};var _ae=function(e){if(!e){var e=window.event;}var tag=this.getAttribute("tag");if(_73){_73.call(this,tag,e);}return false;};var _b2=function(_b3){createTiddlyElement(_b3,"span",null,"tagSeparator"," | ");};var _b4=function(_b5,_b6,_b7,_b8,_b9){if(!_b6){return;}var _ba=_b8?abego.toSet(_b8):{};var n=_b6.length;var c=0;for(var i=0;i<n;i++){var tag=_b6[i];if(_ba[tag]){continue;}if(c>0){_b2(_b5);}if(_b9&&c>=_b9){abego.createEllipsis(_b5);break;}c++;var _bf="";var _c0=_b5;if(_b7<10){_c0=createTiddlyElement(_b5,"span",null,"numberedSuggestion");_b7++;var key=_b7<10?""+(_b7):"0";createTiddlyElement(_c0,"span",null,"suggestionNumber",key+") ");var _c2=_b7==1?"Return or ":"";_bf=" (Shortcut: %1Alt-%0)".format([key,_c2]);}var _c3=config.views.wikified.tag.tooltip.format([tag]);var _c4=(_78(tag)?"Remove tag '%0'%1":"Add tag '%0'%1").format([tag,_bf]);var _c5="%0; Shift-Click: %1".format([_c4,_c3]);var btn=createTiddlyButton(_c0,tag,_c5,_ae,_78(tag)?"currentTag":null);btn.setAttribute("tag",tag);}};var _c7=function(){if(_71){window.scrollTo(0,ensureVisible(_71));}if(_77()){window.scrollTo(0,ensureVisible(_77()));}};var _c8=function(e){if(!e){var e=window.event;}if(!_71){return;}var _cb=resolveTarget(e);if(_cb==_77()){return;}if(abego.isDescendantOrSelf(_71,_cb)){return;}abego.IntelliTagger.close();};addEvent(document,"click",_c8);var _cc=Story.prototype.gatherSaveFields;Story.prototype.gatherSaveFields=function(e,_ce){_cc.apply(this,arguments);var _cf=_ce.tags;if(_cf){_ce.tags=_cf.trim();}};var _d0=function(_d1){story.focusTiddler(_d1,"tags");var _d2=abego.getTiddlerField(story,_d1,"tags");if(_d2){var len=_d2.value.length;abego.setRange(_d2,len,len);window.scrollTo(0,ensureVisible(_d2));}};var _d4=config.macros.edit.handler;config.macros.edit.handler=function(_d5,_d6,_d7,_d8,_d9,_da){_d4.apply(this,arguments);var _db=_d7[0];if((_da instanceof Tiddler)&&_db=="tags"){var _dc=_d5.lastChild;_dc.onfocus=function(e){abego.IntelliTagger.assistTagging(_dc,_da);setTimeout(function(){_d0(_da.title);},100);};_dc.onkeyup=function(e){if(!e){var e=window.event;}if(e.altKey&&!e.ctrlKey&&!e.metaKey&&(e.keyCode>=48&&e.keyCode<=57)){_8b(e.keyCode==48?9:e.keyCode-49,_dc,_da);}else{if(e.ctrlKey&&e.keyCode==32){_8b(0,_dc,_da);}}if(!e.ctrlKey&&(e.keyCode==13||e.keyCode==10)){_8b(0,_dc,_da);}setTimeout(function(){abego.IntelliTagger.assistTagging(_dc,_da);},100);return false;};_81(_dc);}};var _e0=function(e){if(!e){var e=window.event;}var _e3=resolveTarget(e);var _e4=_e3.getAttribute("tiddler");if(_e4){story.displayTiddler(_e3,_e4,"IntelliTaggerEditTagsTemplate",false);_d0(_e4);}return false;};var _e5=config.macros.tags.handler;config.macros.tags.handler=function(_e6,_e7,_e8,_e9,_ea,_eb){_e5.apply(this,arguments);abego.IntelliTagger.createEditTagsButton(_eb,createTiddlyElement(_e6.lastChild,"li"));};var _ec=function(){if(_71&&_72&&!abego.isDescendantOrSelf(document,_72)){abego.IntelliTagger.close();}};setInterval(_ec,100);abego.IntelliTagger.displayTagSuggestions=function(_ed,_ee,_ef,_f0,_f1){_74=_ed;_75=abego.toSet(_ee);_76=_ef;_72=_f0;_73=_f1;if(!_71){_71=createTiddlyElement(document.body,"div",null,"intelliTaggerSuggestions");_71.style.position="absolute";}_ac();abego.openAsPopup(_71);if(_77()){var w=_77().offsetWidth;if(_71.offsetWidth<w){_71.style.width=(w-2*(_6e+_6f))+"px";}abego.moveBelowAndClip(_71,_77());}else{abego.centerOnWindow(_71);}_c7();};abego.IntelliTagger.assistTagging=function(_f3,_f4){var _f5=_90(_f3);var s=_f3.value;if(_7d(_f3)){s=_7a(s);}var _f7=s.readBracketedList();var _f8=_f7.length>0?abego.filterStrings(abego.internal.getTagManager().getPartnerRankedTags(_f7),_f5,_70):_a0(_f5,_70);abego.IntelliTagger.displayTagSuggestions(_a9(_f5,_f7),_f7,_f8,_f3,function(tag,e){if(e.shiftKey){onClickTag.call(this,e);}else{_85(tag,_f3,_f4);}});};abego.IntelliTagger.close=function(){abego.closePopup(_71);_71=null;return false;};abego.IntelliTagger.createEditTagsButton=function(_fb,_fc,_fd,_fe,_ff,id,_101){if(!_fd){_fd="[edit]";}if(!_fe){_fe="Edit the tags";}if(!_ff){_ff="editTags";}var _102=createTiddlyButton(_fc,_fd,_fe,_e0,_ff,id,_101);_102.setAttribute("tiddler",(_fb instanceof Tiddler)?_fb.title:String(_fb));return _102;};abego.IntelliTagger.getSuggestionTagsMaxCount=function(){return 100;};config.macros.intelliTagger={label:"intelliTagger",handler:function(_103,_104,_105,_106,_107,_108){var _109=_107.parseParams("list",null,true);var _10a=_109[0]["action"];for(var i=0;_10a&&i<_10a.length;i++){var _10c=_10a[i];var _10d=config.macros.intelliTagger.subhandlers[_10c];if(!_10d){abego.alertAndThrow("Unsupported action '%0'".format([_10c]));}_10d(_103,_104,_105,_106,_107,_108);}},subhandlers:{showTags:function(_10e,_10f,_110,_111,_112,_113){_b4(_10e,_74,_76?_76.length:0,_76,abego.IntelliTagger.getSuggestionTagsMaxCount());},showFavorites:function(_114,_115,_116,_117,_118,_119){_b4(_114,_76,0);},closeButton:function(_11a,_11b,_11c,_11d,_11e,_11f){var _120=createTiddlyButton(_11a,"close","Close the suggestions",abego.IntelliTagger.close);},version:function(_121){var t="IntelliTagger %0.%1.%2".format([version.extensions.IntelliTaggerPlugin.major,version.extensions.IntelliTaggerPlugin.minor,version.extensions.IntelliTaggerPlugin.revision]);var e=createTiddlyElement(_121,"a");e.setAttribute("href","http://tiddlywiki.abego-software.de/#IntelliTaggerPlugin");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">"+t+"<font>";},copyright:function(_124){var e=createTiddlyElement(_124,"a");e.setAttribute("href","http://tiddlywiki.abego-software.de");e.innerHTML="<font color=\"black\" face=\"Arial, Helvetica, sans-serif\">&copy; 2006-2007 <b><font color=\"red\">abego</font></b> Software<font>";}}};})();config.shadowTiddlers["IntelliTaggerStyleSheet"]="/***\n"+"!~IntelliTagger Stylesheet\n"+"***/\n"+"/*{{{*/\n"+".intelliTaggerSuggestions {\n"+"\tposition: absolute;\n"+"\twidth: 600px;\n"+"\n"+"\tpadding: 2px;\n"+"\tlist-style: none;\n"+"\tmargin: 0;\n"+"\n"+"\tbackground: #eeeeee;\n"+"\tborder: 1px solid DarkGray;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .currentTag   {\n"+"\tfont-weight: bold;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .suggestionNumber {\n"+"\tcolor: #808080;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .numberedSuggestion{\n"+"\twhite-space: nowrap;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .intelliTaggerFooter {\n"+"\tmargin-top: 4px;\n"+"\tborder-top-width: thin;\n"+"\tborder-top-style: solid;\n"+"\tborder-top-color: #999999;\n"+"}\n"+".intelliTaggerSuggestions .favorites {\n"+"\tborder-bottom-width: thin;\n"+"\tborder-bottom-style: solid;\n"+"\tborder-bottom-color: #999999;\n"+"\tpadding-bottom: 2px;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .normalTags {\n"+"\tpadding-top: 2px;\n"+"}\n"+"\n"+".intelliTaggerSuggestions .intelliTaggerFooter .button {\n"+"\tfont-size: 10px;\n"+"\n"+"\tpadding-left: 0.3em;\n"+"\tpadding-right: 0.3em;\n"+"}\n"+"\n"+"/*}}}*/\n";config.shadowTiddlers["IntelliTaggerMainTemplate"]="<!--\n"+"{{{\n"+"-->\n"+"<div class=\"favorites\" macro=\"intelliTagger action: showFavorites\"></div>\n"+"<div class=\"normalTags\" macro=\"intelliTagger action: showTags\"></div>\n"+"<!-- The Footer (with the Navigation) ============================================ -->\n"+"<table class=\"intelliTaggerFooter\" border=\"0\" width=\"100%\" cellspacing=\"0\" cellpadding=\"0\"><tbody>\n"+"  <tr>\n"+"\t<td align=\"left\">\n"+"\t\t<span macro=\"intelliTagger action: closeButton\"></span>\n"+"\t</td>\n"+"\t<td align=\"right\">\n"+"\t\t<span macro=\"intelliTagger action: version\"></span>, <span macro=\"intelliTagger action: copyright \"></span>\n"+"\t</td>\n"+"  </tr>\n"+"</tbody></table>\n"+"<!--\n"+"}}}\n"+"-->\n";config.shadowTiddlers["IntelliTaggerEditTagsTemplate"]="<!--\n"+"{{{\n"+"-->\n"+"<div class='toolbar' macro='toolbar +saveTiddler -cancelTiddler'></div>\n"+"<div class='title' macro='view title'></div>\n"+"<div class='tagged' macro='tags'></div>\n"+"<div class='viewer' macro='view text wikified'></div>\n"+"<div class='toolbar' macro='toolbar +saveTiddler -cancelTiddler'></div>\n"+"<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser'></span></div>\n"+"<!--\n"+"}}}\n"+"-->\n";config.shadowTiddlers["BSD open source license (abego Software)"]="See [[Licence|http://tiddlywiki.abego-software.de/#%5B%5BBSD%20open%20source%20license%5D%5D]].";config.shadowTiddlers["IntelliTaggerPlugin Documentation"]="[[Documentation on abego Software website|http://tiddlywiki.abego-software.de/doc/IntelliTagger.pdf]].";config.shadowTiddlers["IntelliTaggerPlugin SourceCode"]="[[Plugin source code on abego Software website|http://tiddlywiki.abego-software.de/archive/IntelliTaggerPlugin/Plugin-IntelliTagger-src.1.0.2.js]]\n";(function(){var _126=restart;restart=function(){setStylesheet(store.getTiddlerText("IntelliTaggerStyleSheet"),"IntelliTaggerStyleSheet");_126.apply(this,arguments);};})();}
// %/
I was [[on stackoverflow today|http://stackoverflow.com/questions/1674915/how-to-teach-someone-that-less-is-more/1675199#1675199]] and I asked a question about (well I didn't know what it was at the time, but...) technical debt.  

One of the answers led me to an [[interview with Jason Fried of 37Signals| http://www.inc.com/magazine/20091101/the-way-i-work-jason-fried-of-37signals_pagen_2.html]]  in which I found some really neat things that Fried does:

----
>"Then companies start adding more and more stuff to keep their existing customers happy. But you end up dying with your customer base, because the software is too complicated for a newcomer"

I tend to remember having a really difficult time figuring out exactly how the software at the company I am currently employed at and I noticed that customers around here usually get what they want (this makes the software overly complex in my opinion).  Although I'm sure this doesn't win Mr. Fried too many friends, I understand why he does it.  


----
>"We want to get rid of interruption as much as we possibly can, because that's the real enemy of productivity."

The way we constantly answer phones around where I work now, it's no wonder that we don't get much done.


----
>"After lunch, I get a little lazy between 1 p.m. and 3 p.m. I don't feel that productive, so I'm usually screwing around, which I think is really important."

>"Everyone should read stuff on the Web that's goofy or discover something new."

I would have to agree with this, because if you don't screw around you generally won't learn anything new.


-----
>"I hate it when businesses treat their employees like children."

This seems to imply that he doesn't like the type of organization where the messages come down, but if any messages go back up, they are completely ignored or the originator of the message is punished for their input.  I really hate this sort of thing too because not only does it damage the relationship between the higher-up and their employees, it could also be bad for the business as a whole.  Now don't get me wrong, the person in charge that is cutting the pay checks should still make the final decision; but they definitely need to be able to listen to and take into account input from their employees.  Otherwise they'll have a Last Czar of Russia situation where the king has no-idea what the needs of the people are.


----
 >"What's the point? (of the 40 hour work week) As long as the work gets done, I don't care what people do all day."

Agreed.


----
>Around 3 p.m., I like to have another cup of tea as a pick-me-up. The one I'm drinking lately is gyokuro, which has high levels of theanine, a potent amino acid that helps you really focus for a few hours.

I'll have to look into that drink he's talking about, I've never heard of it, maybe it just hasn't hit the East Coast yet.
One of the things that has always annoyed me as we've all moved in the direction of desktop web development to mobile web-development is the inability to develop a mobile, mobile web development environment on a laptop, that can be easily transported from network to network with little downtime in the reconfiguration of the development environment, while still being able to access the development webserver on the mobile device on which it is being tested.  

>''Note:'' At the moment this only works for static ip addresses, but in the future maybe I'll do a writeup on a way to do this for dynamic ips.  

>''Note:'' You only have to create a new branch of configuration for each new network you visit.

An easy solution to this can be found with the tools Bash, DNSMasq and GIT.  Here's how these tools will be used:
*GIT will serve as our version control for configurations between networks.
*{{{/etc/dnsmasq.conf}}} and {{{/etc/networking/interfaces}}} will serve as our configuration files that will be tracked for different networks by branches in GIT.
*Bash will serve as our deployment mechanism, to:
**Deploy configurations to Ubuntu and DNSMasq
**And restart services such as Networking, DNSMasq, and our webserver after the configuration is deployed.
I was working a good bit on CSS this week, and I realize that I've forgotten a bit since my high-adieus from web development last year.  

For instance the whole {{{float: left;}}} {{{float: right;}}}  ... {{{clear: both}}} thing, I completely forgot about that.  

Also I've made a good number of toolbars lately (well okay so I made like two), but both would have been made easier/faster with the [[previous aforementioned tutorial|Found Great Horizontal Navigation Tutorial]].  

Oh and I forgot that CSS3 seems to be rearing it's ugly head (hopefully it's alot nicer than the previous CSS's. //(CSS's?)...//

So this got me thinking I should really make myself a personal Wiki for all things CSS.  I need to drop the whole: {{{"Oh, but CSS is so easy...I don't need a wiki for that..."}}} yeah let your pride go and see what you can really accomplish; write it down!
Okay today I finally got JSUnit working on Firefox 3 again.  I wish I could say it was easier to do but it isn't....[>img[http://www.jsunit.net/logos/logo_jsunit.gif]]

#Make sure in {{{about:config}}} that the property {{{browser.cache.check_doc_frequency}}} is set to {{{1}}}.
**The browser interprets this setting as //"check for a new page every time it's loaded."//
#Make sure in {{{about:config}}} that the property {{{security.fileuri.strict_origin_policy}}} is set to {{{false}}}.
**Yes, this is a security setting, so you'll probably want to set it back to true later.
#When running a test in {{{testRunner.html}}}, ''instead of'' specifying it's path in the conveniently provided file browser, specify the path to your test in the url parameter {{{testpage}}}.
**(If you want you can also specify an {{{autorun=true}}} parameter as well so you don't have to click the ''Run'' button everytime.)
!!Example of specifying the page to test via URL:

{{{
file:///.../testRunner.html?testpage=c:/temp/someTest.html
}}}

...and if you still have trouble, make sure for certain that you are editing the right copy of the file.  If you have more than one checkout it is very easy to be in the wrong directory and miss it because 
<<slider "12/22/2007 7:31 PM" "Filling in Those Pesky Text Only Fields with Tables" "+Filling in Those Pesky Text-Only Fields with Tables">>
#[[Fix the Menus]]
#[[Look Into Route 6 Motel Search Rates Via Web Service]]
#[[Look|Website Look]]

[[Directions]]
<html>
<body>
<object width="425" height="344"><param name="movie" value="http://www.youtube.com/v/wHEoMpMvz7A&hl=en&fs=1"></param><param name="allowFullScreen" value="true"></param><embed src="http://www.youtube.com/v/wHEoMpMvz7A&hl=en&fs=1" type="application/x-shockwave-flash" allowfullscreen="true" width="425" height="344"></embed></object>
</body>
</html>

More great music!
<html>
<body>
<object width="425" height="344"><param name="movie" value="http://www.youtube.com/v/zZt64_XOflk&hl=en&fs=1"></param><param name="allowFullScreen" value="true"></param><embed src="http://www.youtube.com/v/zZt64_XOflk&hl=en&fs=1" type="application/x-shockwave-flash" allowfullscreen="true" width="425" height="344"></embed></object>
</body>
</html>

Now that's music!
!Local Setup
Now that version control has been applied to our project, we can start tinkering with the settings, customizing them for each network we might connect to or develop on.  

<<tabs "sdfwefrwfsad"
"3.1" "Local Setup of the network card" "Local Setup of the network card - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.2" "Local Setup of DNSmasq" "Local Setup of dnsmasq - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.3" "Configuration Deployment" "Configuration Deployment - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.4" "Configuration Testing" "Configuration Testing - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.5" "Network Management" "Network Management - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq" 
>>
!!Local Setup of dnsmasq
We're going to be a little bit more careful with the {{{dnsmasq.conf}}} file, it's not as simple as the interfaces file, and it contains instructions used for configuring it.  First we'll set the domain...

<<tabs "sdafwrf3223eadf"
"3.2.1" "Setting up a domain for dnsmasq" "Setting up a domain for dnsmasq - Local Setup of dnsmasq - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.2.2" "Tweeking dnsmasq" "Tweeking dnsmasq - Local Setup of dnsmasq - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
>>
!!Local Setup of the network card
The first thing we need to do any sort of web development work (or even internet access) is an ip address, and thus we have to change the settings in the {{{interfaces}}} file of our project-directory.  The {{{interfaces}}} file will be deployed later when we run our bash script.  

Now the file may have some other content in it to begin with, but remember that in our initial commit, we saved those changes earlier so we don't have to worry about losing them; thus the file contents can be replaced with the following:
{{{
auto lo
iface lo inet loopback


auto eth0
iface eth0 inet static
address 10.0.2.202
netmask 255.255.255.0
gateway 10.0.0.1
dns-search leerdomain-localLAN
dns-nameservers 127.0.0.1 10.0.1.10 10.0.1.9
}}}


The first thing we do is setup the loopback interface.  

In the file above we are setting the ip address of the local development machine to {{{10.0.2.202}}}, this will be the ip address that our local dns-names resolve to in the next step.  We also set the gateway and the netmask of the network, if these are unknown, or if the format of the ip address is unknown, these can be easily tracked down by looking at another machine on the network (preferably one with a static ip address). 

Also we set the dns-search suffix which we will also be setting in the next step.  I set mine to {{{leerdomain-local}}} because the {{{.local}}} suffix is being used by the the [[bonjour software|http://en.wikipedia.org/wiki/.local]] from Apple.  

And lastly, if you still have network-manager setup (as opposed to uninstalling it and using {{{/etc/resolve.conf}}}), Ubuntu 12.04 and on are capable of taking the client dns nameservers ip addresses from the {{{interfaces}}}, making things a bit more convenient.  After writing {{{dns-nameservers}}} you can add as many space separated dns server ips as you'd like; in the example above I'd like my development machine to use the ip address of the localhost, {{{127.0.0.1}}} since it's the same machine that will be hosting dnsmasq (my local development dns server).  

If I were setting up a dns client on a mobile device like an iPhone, Android or a Tablet, a pc or anything else on the same network with us, I would have to set it to point to the ip of this machine (the {{{address}}} in the example above) , since in order to resolve the dns address using our local dns server the client has to be pointing at it.

With that we can save our file and go on to connect up the local dnsmasq name-server.
*Wants to post events like the fall follage festival, do a bit on the radio about fall nistalga.
*Be able to book motel rooms
**[[Yahoo Travel API|http://developer.yahoo.com/travel/]]
**[[Yahoo PHP REST CALL API|http://developer.yahoo.com/php/]]
!Code Base Blues
I recently got a new job working at a company where the code base is over ten years old.  I noticed that the code is rather lengthy, non-object oriented, contains very little documentation, and in a day of languages like Ruby and Groovy, it is very difficult to read.  There aren't many subroutines, and when there is a subroutine it goes on for about five pages and does way more than just one thing.  
!!But There's A Pattern Here Somewhere...
Eventually you'll realize that there is a method to what appears at first sight to be madness.  I have started to notice an order (not a design pattern) to the code, it can still be very frustrating to read, but realizing this definitely makes it easier.  I have found that when reading code like this, it can be helpful to do two things:
#Ask the development team that has been writing it for so long for advice 
**(Request they make you screen casts explaining the various faucets of the code if they'll do so...)
#Use VIM as an editor to cut those five page subroutines down to a manageable size.
**Without disturbing the way the team at large already does things.

VIM has some wonderful facilities for accomplishing this, one of them included out of the box is code folding, 
!Creating Folds
>First what you need to do is tell VIM how you want it to ''recognize'' a fold.  Bellow are some of the ways you can do this:

>The best way I've found to do this is to use the ''marker'' option for folding code.  The ''marker'' option works quite well in that as long as it is a language that supports C/C++ style comments (a.k.a Java, C#, Perl etc..) you can always make code snippets 


!Opening and Closing Folds
>''Note:'' Be sure your in VIM's //normal mode// before trying this, otherwise you'll just get a //"zo"// or //"zc"// typed in your code that you didn't want.
|!Keys to Type |!What these keys do |
| {{{zo}}} |Opens the fold under the cursor |
| {{{zc}}} |Closes the fold under the cursor |
+++[RDBMS or filesystem?]
Interesting, in the [[Zope documentation|http://www.zope.org/Resources/ZopeIntro/]] it says that you indeed can hook Zope up to a real database instead of just the binary file it uses by default.  I was unaware of this and need to look into this further.
>"Zope objects are stored in a high-performance transactional object database that can use either the filesystem or an RDBMS as its backing store."
===
Name: Blue
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
Name: Green
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: Red
Background: #fff
Foreground: #000
PrimaryPale: #fdd
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: Smoke
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: Teal
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
<html>
<body>
<object height="346" width="430" data="http://lads.myspace.com/videos/vplayer.swf?u=YUhSMGNEb3ZMMk52Ym5SbGJuUXViVzkyYVdWekxtTmtiaTV0ZVhOd1lXTmxMbU52YlM4d01EQTNOekl4THpBekx6TXlMemMzTWpFNU1qTXpNQzVtYkhZPQ==&amp;d=71" allownetworking="all" allowscriptaccess="never" type="application/x-shockwave-flash">
  <param value="never" name="allowScriptAccess"/>
  <param value="all" name="allowNetworking"/>
  <param value="http://lads.myspace.com/videos/vplayer.swf?u=YUhSMGNEb3ZMMk52Ym5SbGJuUXViVzkyYVdWekxtTmtiaTV0ZVhOd1lXTmxMbU52YlM4d01EQTNOekl4THpBekx6TXlMemMzTWpFNU1qTXpNQzVtYkhZPQ==&amp;d=71" name="movie"/>
</object>
</body>
</html>
----
+++[Articles]
[[Avoiding Burn Out|Avoiding Burn Out - 3 December 2007]]
===
----
<<tag "Archives">>
+++[Blogroll]
[[Eric Wendelin's Blog|http://eriwen.com/]]
[[Cropped and Blurred|http://croppedandblurred.blogspot.com]]
[[My Cozen and Her Friends|http://scavengervlog.blogspot.com/]]
[[RiverC|http://riverc.tumblr.com/]] | [[RiverC's other blog|http://blog.riverc.org/]]
[[Adam Altemus |http://www.adamaltemus.com/?p=20]]
[[Tony Buser|http://tonybuser.com/]]
===

----
+++[Settings]
[[Welcome to Tiddlyspot]]
GettingStarted
[[MainMenu]]
[[DefaultTiddlers]]
[[Pings and Trackbacks|http://www.haloscan.com/]]
===

----
<html>
<body>
<a href="http://webmonkey.com" target="_new"><img src="http://www.google.com/s2/favicons?domain=webmonkey.com"/></a>
<a href="http://www.bloglines.com" target="_new"><img src="http://www.google.com/s2/favicons?domain=bloglines.com"/></a>
<a href="http://del.icio.us/leeand00/" target="_blank"><img src="http://www.google.com/s2/favicons?domain=del.icio.us"/></a>
<a href="http://www.facebook.com/people/Andrew_J_Leer/"><img src="http://www.google.com/s2/favicons?domain=facebook.com"/></a>
<a href="http://twitter.com/leeand00/" target="_new"><img src="http://www.google.com/s2/favicons?domain=www.twitter.com"/></a>
<a href="http://www.jobster.com/people/andrewleer" target="_new"><img src="http://www.google.com/s2/favicons?domain=www.jobster.com" width="16" height="16"/></a>
<a href="http://remix.kwed.org/" target="_new"><img src="http://www.google.com/s2/favicons?domain=remix.kwed.org"</a>
<a href="http://www.mediafly.com/Users/leeand00" target="_new"><img src="http://www.google.com/s2/favicons?domain=www.mediafly.com"/></a>
<a href="http://www.flickr.com/leeand00/" target="_new"><img src="http://www.google.com/s2/favicons?domain=www.flickr.com"/></a>
<a href="http://java.sun.com" target="_new"><img src="http://www.google.com/s2/favicons?domain=java.sun.com"/></a>
</body>
</html>
----
<<tiddler "Total StackExchange Rep">>
<<tiddler "My Facebook Profile">>
<<tiddler "IPv6 Certy">>
Okay after trying to figure this out for some time, 

I discover a forum posting that read that if you use the following stylesheet:
{{{
	/* the following rules apply only to IE6 */
	* html /* put what every you want here */{
		/*and these styles will only work with IE6 */
	}
}}}
IE6 will read it, and all other browsers will ignore it's contents.

I also discovered that the following stylesheet code will cause IE6 to have a min-width, only problem being that the other browsers won't ignore it unless it is contained in the rules above.


{{{

     width: expression(document.body.clientWidth < 933? "933px" : document.body.clientWidth > 1202? "1200px" : "auto");
}}}

And thus we have (only applying the rule to IE6):

{{{
	/* the following rules apply only to IE6 */
	* html #all{
		width: expression(document.body.clientWidth < 933? "933px" : document.body.clientWidth > 1202? "1200px" : "auto");
	}
}}}
When working in HTML5 using geolocation support you want to be able to test what happens when a user accepts geolocation for a particular site, or denys it.

However the browser usually saves the user's preferences for a particular site, so undoing this takes a few menu clicks.

<<tabs "574"
"Firefox" "Making sure geolocation support stays on - Firefox" "Making sure geolocation support stays on - Firefox"
"Chrome" "Making sure geolocation support stays on - Chrome" "Making sure geolocation support stays on - Chrome" 
>> 
Enable or disable location sharing

#Click the wrench icon wrench icon on the browser toolbar.
#Select Options (Preferences on Mac and Linux; Settings on a Chromebook).
#Click the Under the Hood tab.
#Click Content settings.
#In the page that appears, scroll down to the "Location" section. Select your default permission for future location requests:
**Allow all sites to track my physical location: Select this option to let all sites automatically access your location.
**Ask me when a site tries to track my physical location: Select this option if you want Google Chrome to alert you whenever a site requests your location.
**Do not allow any site to track my physical location: Select this option to automatically deny site requests for your location.

>Click Manage exceptions to remove previously-granted permissions for specific sites.
>How do I undo a permission granted to a site?
>
>If you've given Firefox permission to always give your location to a site and later change your mind, you can easily revoke that permission. Here's how:
>
>>Navigate to the site to which you've given permission
>>Go to the Tools menu, then select Page Info
>>Select the Permissions tab
>>Change the setting for Share Location
From the [[Firefox website|http://www.mozilla.org/en-US/firefox/geolocation/#undo-permission]]
<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</script>
<script type="text/javascript">
_uacct = "UA-6221972-1";
urchinTracker();
</script>
|!Date |!Task |
|[[2/22/2008|22 February 2008]] | Entered Table of Contents into Marriage Wiki |
>''Or:'' Stupid Excel tricks to do comparisons instead of writing stupid VBA code to verify something.

>@@color(red): Please note that the {{{SocialSecurityNumber}}} field ''__IS NOT__'' and actual SSN but a PRIMARY KEY.@@
----
----
From the post merge (or uncommited transaction)
{{{
CREATE VIEW getMeThemUnCommitedCounts AS SELECT e.SocialSecurityNumber, V_VisitDate, count(*) AS cnt
FROM T_Visit_Log AS x INNER JOIN T_Employees AS e ON x.V_EmployeeID = e.SocialSecurityNumber
WHERE e.SocialSecurityNumber = 60003660 OR e.SocialSecurityNumber = 60003926
GROUP BY e.SocialSecurityNumber, V_VisitDate
ORDER BY V_VisitDate, e.SocialSecurityNumber;
}}}
----
From the pre merge (or 
{{{
CREATE VIEW getMeThemOriginalCounts AS SELECT e.SocialSecurityNumber, V_VisitDate, count(*) AS cnt FROM T_Visit_Log x INNER JOIN T_Employees e ON x.V_EmployeeID = e.SocialSecurityNumber WHERE e.SocialSecurityNumber = 60003660 OR e.SocialSecurityNumber = 60003926 GROUP BY e.SocialSecurityNumber, V_VisitDate ORDER BY  V_VisitDate, e.SocialSecurityNumber
}}}

Followed by a call to the other view
{{{
SELECT  V_VisitDate, sum(cnt) FROM getMeThemOriginalCounts GROUP BY V_VisitDate
}}}
----
----
When comparing two columns of INTEGER or DATE values together from a database, and a database with changes in it (or if you like a transaction without the changes, and a transaction with the changes in it), you can take the results of a query of 515 or so rows from both sources and dump them into excel side by side.

I myself was doing a count after merging a duplicate record from the imposter to the original to verify if the counts still matched before commiting the transaction and there were 515 records so eyeballing it was not really an option.

#Dump the records into excel side by side, and subtract the counts (or dates) from each other in a separate field, and make the equation go the whole way to the bottom.  At the bottom sum the newly created separate field with the sum of the two fields and see if it comes out to zero.  If it does come out to zero there are no differences between the two columns.

Doing this procedurally, would have been expensive not only to the CPU, but also would have taken alot of time, using math instead to figure this out was faster and cheaper.
Background: #ffeedd
Foreground: #000
PrimaryPale: #ddaa99
PrimaryLight: #cc9999
PrimaryMid: #552233
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #cccccc
SecondaryDark: #552233
TertiaryPale: #ddaa99
TertiaryLight: #EEC591
TertiaryMid: #552233
TertiaryDark: #8B7355
{{{
tr "																	" : 566
form "																	" : 499
tr "																	" : 494
table "																" : 348
td "															" : 347
tr "														" : 345
table "													" : 344
td "												" : 343
tr "											" : 342
table "										" : 318
td "									" : 317
tr "								" : 166
table "							" : 165
td "						" : 32
tr "					" : 31
table "				" : 27
td "			" : 26
tr "		" : 23
table "	" : 22
}}}



{{{
td "			" : 26
tr "		" : 23
table "	" : 22
}}}

{{{
<!-- 10/31/09 <form name="form1" method="post" action="CHECK_OUT_REFERENCE" onsubmit="return (validateAndAttachAdditionalFieldsToSpecialInstructions() == true) ? true : false"> 10/31/09-->


tag = {
	"tagText" : null,
	"indent"  : null,
	"lineNumber" : null
};

var stack = [];
var tag = nextTag();

if(tag.isOpening())
{
   stack.push(tag);	
}
else if(tag.isClosing() 
{
   var poppedTag = stack.pop();

   if(poppedTag.tagText != tag.tagText)
   {
	// EITHER:
	// Throw an error and tell the user
	// what line it is on (poppedTag.lineNumber, indent)
        //
	// OR:
	//
	// Replace the missing tag where before inserting the closing tag.
   }
}
}}}
[img[http://i9.photobucket.com/albums/a58/Maskkkk/MicroBreak.png]]<<gradient vert #cecece #ffa500 #ffffff>>Take a Microbreak>>
The [[Microbreak]] is the shortest and most frequent of the <<tag "timer">>s in [[Workrave|http://www.workrave.org]].  
>Although, modifying the settings can change this, the [[Microbreak]] timer is meant to give your eyes a short break, relatively frequently.
!How it Works
#''When the [[Microbreak]] <<tag "timer">> runs out, a Mr. Lightbulb appears on the screen.'' [>img[Unlike Clippy, the friendly Mr. Lightbulb is unlikely to be the bane of your existance.|http://i9.photobucket.com/albums/a58/Maskkkk/mrlightbulb.png]]
**...if you stop typing and moving the mouse, the [[Microbreak]] @@color(green):will begin@@.
**...if you do not stop moving the mouse and keyboard, the [[Microbreak]] @@color(red):will not begin@@.
#''You'll hear a //*Sparky Sound*//''
**...and As you hear this, close your eyes, this signifies the beginning of the [[Microbreak]].
#''Wait...and rest your eyes''
**Breathe in and out, so your heart can pump and provide fresh @@color(red):hemoglobin@@ to your @@color(blue):tired eyes@@.
**...alternatively, if you are lucky enough to have a window look far off and out into the distance.
#''Next you'll hear a //*Pop! Sound*//''
**...this indicates it's safe to //return to work//.
<html>
<body>
<object width="320" height="240" ><param name="allowfullscreen" value="true" /><param name="allowscriptaccess" value="always" /><param name="movie" value="http://www.facebook.com/v/214520005716" /><embed src="http://www.facebook.com/v/214520005716" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="320" height="240"></embed></object>
</body>
</html>
Background: #eeddaa
Foreground: #000
PrimaryPale: #ddcc99
PrimaryLight: #bb8833
PrimaryMid: #553322
PrimaryDark: #000
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #cccccc
SecondaryDark: #553322
TertiaryPale: #ddcc99
TertiaryLight: #EEC591
TertiaryMid: #553322
TertiaryDark: #8B7355
Today, I went over to [[College Grad.com|http://vcf.collegegrad.com/Candidate/]] to try my hand at their mock interview process.

You need a webcam and a microphone to get started.   

First a video sequence of an interviewer shows up and asks the following common interview question(s):

+++[Question 1]
>''Tell us about yourself.''

Groan!  What do I say now?  Luckily the mock interview process gives you time to record your answer again...so I went out to [[WikiAnswers.org|http://wiki.answers.com/Q/How_do_you_answer_'Please_tell_us_about_yourself'_in_a_job_interview]] where they told me the following:

>''A person is defined in 3 different ways:''
>>1. Who he is right now.
>>2. What he has done in the past.
>>3. What he will become in the future.

And of course they specify that you need to answer these questions //professionally//, not about your personal self.

I came up with the following answers to those three questions:

>"I am a Computer Programmer."

>"I have 2 years in team environments experience developing  Java, J2EE, MVC and AJAX based web applications."

>"In the future I would like to learn other languages and frameworks to increase my marketability in the Software Engineering Field."
===

+++[Question 2]
>''What type of positions are you seeking?''


===
*//In one of those buttery scenes// I can't believe it's not butter (on my pecs)
*No, no I'm not Atlas, I'm Fabio the Greek god of lust.
Rated NR
Copyright 1997 Windmill Productions
Review by [[Andrew Leer|http://leeand00.tiddlyspot.com/]]

!The Characters
Danny Nilesen - 
Teddie Nielsen - 
Phillip Frodden - The sleazy, overly male boyfriend of  Danny's aunt, played by Timothy Bottoms.  His character plays as though he should be on the [[Lifetime|http://www.mylifetime.com/on-tv/schedule/daily]] after house work special.  
Wilshire Frodden - 
Gus - 
Colleen Mithell
Atlas -
Sheriff Tyrell - 
Billy - 
Dolores Mitchell - 
Medic -
Girl in Store -

!The Plot
Shot on location in Utah, Mr. Atlas looks like a movie from the Hallmark Channel, for people who thought Touched By An Angel and Walker Texas Ranger were too religious.  

!Things I Learned From This Movie


!Stuff to Watch For
01:23 - 8086 Fighter!
@@color(red):01:46 - RANDOM ACT OF BULLY VIOLENCE AGAINST DANNY!@@
@@color(red):0:2:00 - RANDOM ACT OF BULLY VIOLENCE AGAINST A TEXT BOOK!@@
@@color(red):02:03 - RANDOM ACT OF BULLY VIOLENCE AGAINST DANNY!@@
04:30 - No, but I have some Rubies!
07:44 - Timothy Bottoms lives up to his name.


!Sounds

!Images

[[Mr Atlas Jokes]]
<html>
<body>
<div class="vcard">
<a class="url fn" href="http://leeand00.tiddlyspot.com">Andrew Leer</a>
<a class="email" href="mailto:leeand00 -at- hotmail.com">leeand00 -at- hotmail.com</a>
<div class="adr">
	<span class="locality">PA</span>
	<span class="country-name">US</span>
</div>
<div class="tel">724-422-4873</div>
</div>
</body>
</html>
<html>
<body>
<a href="http://www.facebook.com/people/Andrew_J_Leer/698010716" title="Andrew J. Leer's Facebook profile" target=_TOP><img src="http://badge.facebook.com/badge/698010716.957.294104454.png" border=0 alt="Andrew J. Leer's Facebook profile"></a>
</body>
</html>
/***
|Name|NestedSlidersPlugin|
|Source|http://www.TiddlyTools.com/#NestedSlidersPlugin|
|Version|2.3.1|
|Author|Eric Shulman - ELS Design Studios|
|License|http://www.TiddlyTools.com/#LegalStatements <<br>>and [[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]]|
|~CoreVersion|2.1|
|Type|plugin|
|Requires||
|Overrides|Slider.prototype.stop|
|Description|show content in nest-able 'slider' or 'floating' panels, without needing to create separate tiddlers for each panel|

!!!!!Configuration
<<<
Enable animation for slider panels
<<option chkFloatingSlidersAnimate>> allow sliders to animate when opening/closing
>(note: This setting is in //addition// to the general option for enabling/disabling animation effects:
><<option chkAnimate>> enable animations (entire document)
>For slider animation to occur, you must also allow animation in general.

Debugging messages for 'lazy sliders' deferred rendering:
<<option chkDebugLazySliderDefer>> show debugging alert when deferring slider rendering
<<option chkDebugLazySliderRender>> show debugging alert when deferred slider is actually rendered
<<<
!!!!!Usage
<<<
When installed, this plugin adds new wiki syntax for embedding 'slider' panels directly into tiddler content.  Use {{{+++}}} and {{{===}}} to delimit the slider content.  You can also 'nest' these sliders as deep as you like (see complex nesting example below), so that expandable 'tree-like' hierarchical displays can be created.  This is most useful when converting existing in-line text content to create in-line annotations, footnotes, context-sensitive help, or other subordinate information displays.

Additional optional syntax elements let you specify
*default to open
*cookiename
*heading level
*floater (with optional CSS width value)
*transient display (clicking elsewhere closes panel)
*custom class/label/tooltip/accesskey
*alternate label/tooltip (displayed when panel is open)
*panelID (for later use with {{{<<DOM>>}}} macro.  See [[DOMTweaksPlugin]])
*automatic blockquote style on panel
*deferred rendering of panel content
The complete syntax, using all options, is:
//{{{
++++(cookiename)!!!!!^width^*{{class{[label=key|tooltip][altlabel|alttooltip]}}}#panelID:>...
content goes here
===
//}}}
where:
* {{{+++}}} (or {{{++++}}}) and {{{===}}}<br>marks the start and end of the slider definition, respectively.  When the extra {{{+}}} is used, the slider will be open when initially displayed.
* {{{(cookiename)}}}<br>saves the slider opened/closed state, and restores this state whenever the slider is re-rendered.
* {{{!}}} through {{{!!!!!}}}<br>displays the slider label using a formatted headline (Hn) style instead of a button/link style
* {{{^width^}}} (or just {{{^}}})<br>makes the slider 'float' on top of other content rather than shifting that content downward.  'width' must be a valid CSS value (e.g., "30em", "180px", "50%", etc.).  If omitted, the default width is "auto" (i.e., fit to content)
* {{{"*"}}} //(without the quotes)//<br>denotes "transient display": when a click occurs elsewhere in the document, the slider/floating panel will be automatically closed.  This is useful for creating 'pulldown menus' that automatically go away after they are used.
* {{{{{class{[label=key|tooltip][altlabel|alttooltip]}}}}}}<br>uses label/tooltip/accesskey.  {{{{{class{...}}}}}}, {{{=key}}}, {{{|tooltip}}} and {{{[altlabel|alttooltip]}} are optional.  'class' is any valid CSS class name, used to style the slider label text.  'key' must be a ''single letter only''.  altlabel/alttooltip specifiy alternative label/tooltip for use when slider/floating panel is displayed.
* {{{#panelID:}}}<br>defines a unique DOM element ID that is assigned to the panel element used to display the slider content.  This ID can then be used later to reposition the panel using the {{{<<DOM move id>>}}} macro (see [[DOMTweaksPlugin]]), or to access/modify the panel element through use of {{{document.getElementById(...)}}}) javascript code in a plugin or inline script.
* {{{">"}}} //(without the quotes)//<br>automatically adds blockquote formatting to slider content
* {{{"..."}}} //(without the quotes)//<br>defers rendering of closed sliders until the first time they are opened.  //Note: deferred rendering may produce unexpected results in some cases.  Use with care.//

//Note: to make slider definitions easier to read and recognize when editing a tiddler, newlines immediately following the {{{+++}}} 'start slider' or preceding the {{{===}}} 'end slider' sequence are automatically supressed so that excess whitespace is eliminated from the output.//
<<<
!!!!!Examples
<<<
simple in-line slider: 
{{{
+++
   content
===
}}}
+++
   content
===
----
use a custom label and tooltip: 
{{{
+++[label|tooltip]
   content
===
}}}
+++[label|tooltip]
   content
===
----
content automatically blockquoted: 
{{{
+++>
   content
===
}}}
+++>
   content
===
----
all options combined //(default open, cookie, heading, sized floater, transient, class, label/tooltip/key, blockquoted, deferred)//
{{{
++++(testcookie)!!!^30em^*{{big{[label=Z|click or press Alt-Z to open]}}}>...
   content
===
}}}
++++(testcookie)!!!^30em^*{{big{[label=Z|click or press Alt-Z to open]}}}>...
   content
===
----
complex nesting example:
{{{
+++[get info...=I|click for information or press Alt-I]
	put some general information here,
	plus a floating panel with more specific info:
	+++^10em^[view details...|click for details]
		put some detail here, which could in turn contain a transient panel,
		perhaps with a +++^25em^*[glossary definition]explaining technical terms===
	===
===
}}}
+++[get info...=I|click for information or press Alt-I]
	put some general information here,
	plus a floating panel with more specific info:
	+++^10em^[view details...|click for details]
		put some detail here, which could in turn contain a transient panel,
		perhaps with a +++^25em^*[glossary definition]explaining technical terms===
	===
===
<<<
!!!!!Installation
<<<
import (or copy/paste) the following tiddlers into your document:
''NestedSlidersPlugin'' (tagged with <<tag systemConfig>>)
<<<
!!!!!Revision History
<<<
''2007.07.26 - 2.3.1'' in document.onclick(), propagate return value from hijacked core click handler to consume OR bubble up click as needed.  Fixes "IE click disease", whereby nearly every mouse click causes a page transition.
''2007.07.20 - 2.3.0'' added syntax for setting panel ID (#panelID:).  This allows individual slider panels to be repositioned within tiddler content simply by giving them a unique ID and then moving them to the desired location using the {{{<<DOM move id>>}}} macro.
''2007.07.19 - 2.2.0'' added syntax for alttext and alttip (button label and tooltip to be displayed when panel is open)
''2007.07.14 - 2.1.2'' corrected use of 'transient' attribute in IE to prevent (non-recursive) infinite loop
''2007.07.12 - 2.1.0'' replaced use of "*" for 'open/close on rollover' (which didn't work too well).  "*" now indicates 'transient' panels that are automatically closed if a click occurs somewhere else in the document.  This permits use of nested sliders to create nested "pulldown menus" that automatically disappear after interaction with them has been completed.  Also, in onClickNestedSlider(), use "theTarget.sliderCookie", instead of "this.sliderCookie" to correct cookie state tracking when automatically dismissing transient panels.
''2007.06.10 - 2.0.5'' add check to ensure that window.adjustSliderPanel() is defined before calling it (prevents error on shutdown when mouse event handlers are still defined)
''2007.05.31 - 2.0.4'' add handling to invoke adjustSliderPanel() for onmouseover events on slider button and panel.  This allows the panel position to be re-synced when the button position shifts due to changes in unrelated content above it on the page.  (thanks to Harsha for bug report)
''2007.03.30 - 2.0.3'' added chkFloatingSlidersAnimate (default to FALSE), so that slider animation can be disabled independent of the overall document animation setting (avoids strange rendering and focus problems in floating panels)
''2007.03.01 - 2.0.2'' for TW2.2+, hijack Morpher.prototype.stop so that "overflow:hidden" can be reset to "overflow:visible" after animation ends
''2007.03.01 - 2.0.1'' in hijack for Slider.prototype.stop, use apply() to pass params to core function
|please see [[NestedSlidersPluginHistory]] for additional revision details|
''2005.11.03 - 1.0.0'' initial public release
<<<
!!!!!Credits
<<<
This feature was implemented by EricShulman from [[ELS Design Studios|http:/www.elsdesign.com]] with initial research and suggestions from RodneyGomes, GeoffSlocock, and PaulPetterson.
<<<
!!!!!Code
***/
//{{{
version.extensions.nestedSliders = {major: 2, minor: 3, revision: 1, date: new Date(2007,7,26)};
//}}}

//{{{
// options for deferred rendering of sliders that are not initially displayed
if (config.options.chkDebugLazySliderDefer==undefined) config.options.chkDebugLazySliderDefer=false;
if (config.options.chkDebugLazySliderRender==undefined) config.options.chkDebugLazySliderRender=false;
if (config.options.chkFloatingSlidersAnimate==undefined) config.options.chkFloatingSlidersAnimate=false;

// default styles for 'floating' class
setStylesheet(".floatingPanel { position:absolute; z-index:10; padding:0.5em; margin:0em; \
	background-color:#eee; color:#000; border:1px solid #000; text-align:left; }","floatingPanelStylesheet");
//}}}

//{{{
config.formatters.push( {
	name: "nestedSliders",
	match: "\\n?\\+{3}",
	terminator: "\\s*\\={3}\\n?",
	lookahead: "\\n?\\+{3}(\\+)?(\\([^\\)]*\\))?(\\!*)?(\\^(?:[^\\^\\*\\[\\>]*\\^)?)?(\\*)?(?:\\{\\{([\\w]+[\\s\\w]*)\\{)?(\\[[^\\]]*\\])?(\\[[^\\]]*\\])?(?:\\}{3})?(\\#[^:]*\\:)?(\\>)?(\\.\\.\\.)?\\s*",
	handler: function(w)
		{
			lookaheadRegExp = new RegExp(this.lookahead,"mg");
			lookaheadRegExp.lastIndex = w.matchStart;
			var lookaheadMatch = lookaheadRegExp.exec(w.source)
			if(lookaheadMatch && lookaheadMatch.index == w.matchStart)
			{
				// var defopen=lookaheadMatch[1]
				// var cookiename=lookaheadMatch[2]
				// var header=lookaheadMatch[3]
				// var panelwidth=lookaheadMatch[4]
				// var transient=lookaheadMatch[5]
				// var class=lookaheadMatch[6]
				// var label=lookaheadMatch[7]
				// var openlabel=lookaheadMatch[8]
				// var panelID=lookaheadMatch[9]
				// var blockquote=lookaheadMatch[10]
				// var deferred=lookaheadMatch[11]

				// location for rendering button and panel
				var place=w.output;

				// default to closed, no cookie, no accesskey, no alternate text/tip
				var show="none"; var cookie=""; var key="";
				var closedtext=">"; var closedtip="";
				var openedtext="<"; var openedtip="";

				// extra "+", default to open
				if (lookaheadMatch[1]) show="block";

				// cookie, use saved open/closed state
				if (lookaheadMatch[2]) {
					cookie=lookaheadMatch[2].trim().slice(1,-1);
					cookie="chkSlider"+cookie;
					if (config.options[cookie]==undefined)
						{ config.options[cookie] = (show=="block") }
					show=config.options[cookie]?"block":"none";
				}

				// parse label/tooltip/accesskey: [label=X|tooltip]
				if (lookaheadMatch[7]) {
					var parts=lookaheadMatch[7].trim().slice(1,-1).split("|");
					closedtext=parts.shift();
					if (closedtext.substr(closedtext.length-2,1)=="=")	
						{ key=closedtext.substr(closedtext.length-1,1); closedtext=closedtext.slice(0,-2); }
					openedtext=closedtext;
					if (parts.length) closedtip=openedtip=parts.join("|");
					else { closedtip="show "+closedtext; openedtip="hide "+closedtext; }
				}

				// parse alternate label/tooltip: [label|tooltip]
				if (lookaheadMatch[8]) {
					var parts=lookaheadMatch[8].trim().slice(1,-1).split("|");
					openedtext=parts.shift();
					if (parts.length) openedtip=parts.join("|");
					else openedtip="hide "+openedtext;
				}

				var title=show=='block'?openedtext:closedtext;
				var tooltip=show=='block'?openedtip:closedtip;

				// create the button
				if (lookaheadMatch[3]) { // use "Hn" header format instead of button/link
					var lvl=(lookaheadMatch[3].length>6)?6:lookaheadMatch[3].length;
					var btn = createTiddlyElement(createTiddlyElement(place,"h"+lvl,null,null,null),"a",null,lookaheadMatch[6],title);
					btn.onclick=onClickNestedSlider;
					btn.setAttribute("href","javascript:;");
					btn.setAttribute("title",tooltip);
				}
				else
					var btn = createTiddlyButton(place,title,tooltip,onClickNestedSlider,lookaheadMatch[6]);
				btn.innerHTML=title; // enables use of HTML entities in label

				// set extra button attributes
				btn.setAttribute("closedtext",closedtext);
				btn.setAttribute("closedtip",closedtip);
				btn.setAttribute("openedtext",openedtext);
				btn.setAttribute("openedtip",openedtip);
				btn.sliderCookie = cookie; // save the cookiename (if any) in the button object
				btn.defOpen=lookaheadMatch[1]!=null; // save default open/closed state (boolean)
				btn.keyparam=key; // save the access key letter ("" if none)
				if (key.length) {
					btn.setAttribute("accessKey",key); // init access key
					btn.onfocus=function(){this.setAttribute("accessKey",this.keyparam);}; // **reclaim** access key on focus
				}
				btn.onmouseover=function(event) // mouseover on button aligns floater position with button
					{ if (window.adjustSliderPos) window.adjustSliderPos(this.parentNode,this,this.sliderPanel,this.sliderPanel.className); }

				// create slider panel
				var panelClass=lookaheadMatch[4]?"floatingPanel":"sliderPanel";
				var panelID=lookaheadMatch[9]; if (panelID) panelID=panelID.slice(1,-1); // trim off delimiters
				var panel=createTiddlyElement(place,"div",panelID,panelClass,null);
				panel.button = btn; // so the slider panel know which button it belongs to
				btn.sliderPanel=panel; // so the button knows which slider panel it belongs to
				panel.defaultPanelWidth=(lookaheadMatch[4] && lookaheadMatch[4].length>2)?lookaheadMatch[4].slice(1,-1):"";
				panel.setAttribute("transient",lookaheadMatch[5]=="*"?"true":"false");
				panel.style.display = show;
				panel.style.width=panel.defaultPanelWidth;
				panel.onmouseover=function(event) // mouseover on panel aligns floater position with button
					{ if (window.adjustSliderPos) window.adjustSliderPos(this.parentNode,this.button,this,this.className); }

				// render slider (or defer until shown) 
				w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
				if ((show=="block")||!lookaheadMatch[11]) {
					// render now if panel is supposed to be shown or NOT deferred rendering
					w.subWikify(lookaheadMatch[10]?createTiddlyElement(panel,"blockquote"):panel,this.terminator);
					// align floater position with button
					if (window.adjustSliderPos) window.adjustSliderPos(place,btn,panel,panelClass);
				}
				else {
					var src = w.source.substr(w.nextMatch);
					var endpos=findMatchingDelimiter(src,"+++","===");
					panel.setAttribute("raw",src.substr(0,endpos));
					panel.setAttribute("blockquote",lookaheadMatch[10]?"true":"false");
					panel.setAttribute("rendered","false");
					w.nextMatch += endpos+3;
					if (w.source.substr(w.nextMatch,1)=="\n") w.nextMatch++;
					if (config.options.chkDebugLazySliderDefer) alert("deferred '"+title+"':\n\n"+panel.getAttribute("raw"));
				}
			}
		}
	}
)

// TBD: ignore 'quoted' delimiters (e.g., "{{{+++foo===}}}" isn't really a slider)
function findMatchingDelimiter(src,starttext,endtext) {
	var startpos = 0;
	var endpos = src.indexOf(endtext);
	// check for nested delimiters
	while (src.substring(startpos,endpos-1).indexOf(starttext)!=-1) {
		// count number of nested 'starts'
		var startcount=0;
		var temp = src.substring(startpos,endpos-1);
		var pos=temp.indexOf(starttext);
		while (pos!=-1)  { startcount++; pos=temp.indexOf(starttext,pos+starttext.length); }
		// set up to check for additional 'starts' after adjusting endpos
		startpos=endpos+endtext.length;
		// find endpos for corresponding number of matching 'ends'
		while (startcount && endpos!=-1) {
			endpos = src.indexOf(endtext,endpos+endtext.length);
			startcount--;
		}
	}
	return (endpos==-1)?src.length:endpos;
}
//}}}

//{{{
window.onClickNestedSlider=function(e)
{
	if (!e) var e = window.event;
	var theTarget = resolveTarget(e);
	var theLabel = theTarget.firstChild.data;
	var theSlider = theTarget.sliderPanel
	var isOpen = theSlider.style.display!="none";

	// toggle label
	theTarget.innerHTML=isOpen?theTarget.getAttribute("closedText"):theTarget.getAttribute("openedText");
	// toggle tooltip
	theTarget.setAttribute("title",isOpen?theTarget.getAttribute("closedTip"):theTarget.getAttribute("openedTip"));

	// deferred rendering (if needed)
	if (theSlider.getAttribute("rendered")=="false") {
		if (config.options.chkDebugLazySliderRender)
			alert("rendering '"+theLabel+"':\n\n"+theSlider.getAttribute("raw"));
		var place=theSlider;
		if (theSlider.getAttribute("blockquote")=="true")
			place=createTiddlyElement(place,"blockquote");
		wikify(theSlider.getAttribute("raw"),place);
		theSlider.setAttribute("rendered","true");
	}
	// show/hide the slider
	if(config.options.chkAnimate && (theSlider.className!='floatingPanel' || config.options.chkFloatingSlidersAnimate))
		anim.startAnimating(new Slider(theSlider,!isOpen,e.shiftKey || e.altKey,"none"));
	else
		theSlider.style.display = isOpen ? "none" : "block";
	// reset to default width (might have been changed via plugin code)
	theSlider.style.width=theSlider.defaultPanelWidth;
	// align floater panel position with target button
	if (!isOpen && window.adjustSliderPos) window.adjustSliderPos(theSlider.parentNode,theTarget,theSlider,theSlider.className);
	// if showing panel, set focus to first 'focus-able' element in panel
	if (theSlider.style.display!="none") {
		var ctrls=theSlider.getElementsByTagName("*");
		for (var c=0; c<ctrls.length; c++) {
			var t=ctrls[c].tagName.toLowerCase();
			if ((t=="input" && ctrls[c].type!="hidden") || t=="textarea" || t=="select")
				{ ctrls[c].focus(); break; }
		}
	}
	var cookie=theTarget.sliderCookie;
	if (cookie && cookie.length) {
		config.options[cookie]=!isOpen;
		if (config.options[cookie]!=theTarget.defOpen)
			saveOptionCookie(cookie);
		else { // remove cookie if slider is in default display state
			var ex=new Date(); ex.setTime(ex.getTime()-1000);
			document.cookie = cookie+"=novalue; path=/; expires="+ex.toGMTString();
		}
	}
	return false;
}
//}}}

//{{{
// click in document background closes transient panels 
document.nestedSliders_savedOnClick=document.onclick;
document.onclick=function(ev) { if (!ev) var ev=window.event; var target=resolveTarget(ev);
	// call original click handler
	if (document.nestedSliders_savedOnClick)
		var retval=document.nestedSliders_savedOnClick.apply(this,arguments);
	// if click was inside transient panel (or something contained by a transient panel)... leave it alone
	var p=target;
	while (p)
		if ((p.className=="floatingPanel"||p.className=="sliderPanel")&&p.getAttribute("transient")=="true") break;
		else p=p.parentNode;
	if (p) return retval;
	// otherwise, find and close all transient panels...
	var all=document.all?document.all:document.getElementsByTagName("DIV");
	for (var i=0; i<all.length; i++) {
		 // if it is not a transient panel, or the click was on the button that opened this panel, don't close it.
		if (all[i].getAttribute("transient")!="true" || all[i].button==target) continue;
		// otherwise, if the panel is currently visible, close it by clicking it's button
		if (all[i].style.display!="none") window.onClickNestedSlider({target:all[i].button}) 
	}
	return retval;
};
//}}}

//{{{
// adjust floating panel position based on button position
if (window.adjustSliderPos==undefined) window.adjustSliderPos=function(place,btn,panel,panelClass) {
	if (panelClass=="floatingPanel") {
		var left=0;
		var top=btn.offsetHeight; 
		if (place.style.position!="relative") {
			var left=findPosX(btn);
			var top=findPosY(btn)+btn.offsetHeight;
			var p=place; while (p && p.className!='floatingPanel') p=p.parentNode;
			if (p) { left-=findPosX(p); top-=findPosY(p); }
		}
		if (findPosX(btn)+panel.offsetWidth > getWindowWidth())  // adjust position to stay inside right window edge
			left-=findPosX(btn)+panel.offsetWidth-getWindowWidth()+15; // add extra 15px 'fudge factor'
		panel.style.left=left+"px"; panel.style.top=top+"px";
	}
}

function getWindowWidth() {
	if(document.width!=undefined)
		return document.width; // moz (FF)
	if(document.documentElement && ( document.documentElement.clientWidth || document.documentElement.clientHeight ) )
		return document.documentElement.clientWidth; // IE6
	if(document.body && ( document.body.clientWidth || document.body.clientHeight ) )
		return document.body.clientWidth; // IE4
	if(window.innerWidth!=undefined)
		return window.innerWidth; // IE - general
	return 0; // unknown
}
//}}}

//{{{
// TW2.1 and earlier:
// hijack Slider animation handler 'stop' handler so overflow is visible after animation has completed
Slider.prototype.coreStop = Slider.prototype.stop;
Slider.prototype.stop = function()
	{ this.coreStop.apply(this,arguments); this.element.style.overflow = "visible"; }

// TW2.2+
// hijack Morpher animation handler 'stop' handler so overflow is visible after animation has completed
if (version.major+.1*version.minor+.01*version.revision>=2.2) {
	Morpher.prototype.coreStop = Morpher.prototype.stop;
	Morpher.prototype.stop = function()
		{ this.coreStop.apply(this,arguments); this.element.style.overflow = "visible"; }
}
//}}}
<<tabs "asderwq"
"3.5.1" "Adding a New Network" "Adding a New Network - Network Management - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3.5.2" "Switching Networks" "Switching Networks - Network Management - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq">>
For every item requiring attention, decide what is the next action that can be physically taken on that item. 

!!!Example:
If the item is, "Write a Report", the next action might be, "Email Fred for meeting minutes," or, "Call Mary to ask questions about requirements."  

Though there may be many steps and actions required to complete the item, there will always be something that needs to be done //first//, and this step should be recorded in the next actions list.  Preferably, these spteps are organized by the context in which they can be done, such as "in the office", "by the phone," or "at the store."
Just finished putting this site up today.  I think it turned out nice.  [[Click here to see it.|http://www.foleybf.com/]].

I myself would have gone with a different color scheme, but the company logo dictated that green and blue would be what I used.
Asking my boss...when I can schedule my ophthalmologist apt.
{{{Andy,

It doesn't really matter to me.  You have accrued 54 hours of paid time off and you can use some of that or schedule the appointment so that you can still get 8 hours of work in that day.}}}
Allen describes a suggested set of lists which can be used to keep track of items awaiting attention:
*[[Next Actions - Organize - GTD]]
*[[Projects - Organize - GTD]]
*[[Waiting for - Organize - GTD]]
*[[Someday/Maybe - Organize - GTD]]

A calendar is important for keeping track of appointments and commitments;  however, Allen specifically recommends that the calendar be reserved for the [[hard landscape|Hard Landscape - GTD]].

@@To-do items should be reserved for the next action lists.@@

A final key organizing component of GTD is the filing system.  A filing system must be easy, simple, and fun.  Even a single piece of paper, if needed for reference, should get its own file if it doesn't belong in an existing folder.  Allen suggests a single, alphabetically organized filing system, in order to make it as quick and easy as possible to store and retrieve the needed information.
Some followers of GTD advocate a //'back-to-basics'// approach to personal management, and a rejection of over-engineered, high-tech solutions in favor of simple, less-expensive tools such as preprinted cards, index cards, the Hipster PDA, or even the Moleskine paper pad.

David Allen himself says he relies on a "vanilla" Palm PDA and records "events of the day" on paper to be processed later.
PhraseExpress is a great little macro/textexpander program I discovered one day after Lifehacker's Autohotkey simplification program Texter was thrown by the way side by it's developer Adam Pash.  

I needed to find a new textexpander and what I found was so much better than Texter, mainly because of it's automation of keyboard shortcuts, and it's ability to organize macros/textexpansions called phrases in a folder structure.  

Now one thing that annoyed me off the bat with PhraseExpress was that while it has this incredible macro language for automating keystrokes and other things it had a seemingly clunky user interface, which really "appeared" to bog down it's usefulness in writing macros, considering the process of macro writing is a bit of a trail and error process.  Opening the window for editing the textexpansions appeared to only be possible by using the mouse, breaking the productivity sin of taking your hands off the keyboard and moving them to the mouse (which is clearly an inferior device to the keyboard and second only to the touch screen!).  

However, rooting around the settings today, I came across a shortcut for opening the PhraseExpress window in a timely manner using the keyboard.  

#Right click on your trusty PhraseExpress Tray Icon, and select {{{settings}}} from the context menu.
##Now in the resulting PhraseExpress window, click {{{Tools->Settings}}}
###In the resulting {{{Settings}}} window look at the left hand tree-panel and click {{{Options->HotKeys}}}.
###Finally in the right hand panel there will be a label, followed by a couple of buttons and a dropdown, in the second group of these there will be labeled {{{Edit the last used phrase}}}, set a keyboard shortcut for opening the last edited textexpansion and click {{{OK}}}.

Now when you press the keyboard shortcut you set above, you will be able to quickly edit your macros into submission.

{{{
{#insert selectFieldAll}{#clipboard -copy}{#END}{#sleep 300}{#insert newTid}{#clipboard -paste}
}}}  
When processing a bucket, a strict workflow is followed:
#Start at the top
#Deal with one item at a time
#Never put anything back into "in".
#If an item requires action:
**Do it (if it takes less than two minutes), OR
**Delegate it, OR
**Defer it.
#If an item does not require action:
**File it for reference, OR
**Throw it away, OR
**Incubate it for possible action later.

If it takes under two minutes to do something, it should be done immediately.  The two-minute rule is a guide-line, encompassing roughly the time it would take to formally defer the action.
Every [[open loop|Open Loop - GTD]] in one's life or work which requires more than one physical action to achieve becomes a [[project|Project - GTD]].

These projects are tracked and periodically reviewed to make sure that every project has a next action associated with it, and thus can be moved forward.
#Desired Job Location
**In or around the Philadelphia area.
#Desired Salary or Hourly Rate:
**$40,000-$50,000/per year
**$25/per hour
#Date Available:
**{{{01/11/2008}}}
#US Citizen / Clearance Status
**US Citizen, received a security clearance during my software developer position at Mobilvox.
Is alot like a cable hookup. 

>At the one end of the ''cable hookup'', you have the ''cable company''.  At the opposite end of the ''cable hookup'' you have a ''television''.  In between the two you have ''a cable''.

[img[http://i9.photobucket.com/albums/a58/Maskkkk/path2808.png]]

>Similarly, with RSS, there is an ''RSS Blog'' which sends out the RSS content of a blog or podcast, through an RSS XML Stream (accessed by a URL).  Now the websites in which that content will be posted recieve that RSS XML Stream where it is displayed on the websites.
http://www.odinjobs.com
[[http://groups.google.com/group/tiddlywiki/browse_thread/thread/a3138414434e9a9b?hl=en|http://groups.google.com/group/tiddlywiki/browse_thread/thread/a3138414434e9a9b?hl=en]]

And if a plugin such as this does not exist, maybe I'll have to develop it myself...
The people at the Java Ranch Saloon answered my question concerning the transfer of settings from one Eclipse installation to another.  I tried it out this afternoon and it worked! :-D
In order to rejoin split objects together at a later stage, simply highlight the individual parts and select the command:

{{{edit->forming group}}} to join the selected objects together alone group.

[[also see Splitting Objects|Splitting Objects]]
/***
| Name:|RenameTagsPlugin|
| Description:|Allows you to easily rename or delete tags across multiple tiddlers|
| Version:|3.0 ($Rev: 1845 $)|
| Date:|$Date: 2007-03-16 15:19:22 +1000 (Fri, 16 Mar 2007) $|
| 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) {
			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);
		},

		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();

//}}}
These actions are assigned to an object.  Responsibilities should be described with short verb phrases.  Again, it is important to use the right words.
[img[http://i9.photobucket.com/albums/a58/Maskkkk/RestBreak.png]]<<gradient vert #cecece #ffa500 #ffffff>>Take a Restbreak>>
During a RestBreak you first do exercises that help to avoid [[RSI|http://en.wikipedia.org/wiki/Repetitive_strain_injury]].  These exercises are displayed on the screen by [[Workrave|http://www.workrave.org/]].

Once you've completed these exercises, you need to go and take a walk, and get away from your computer for a bit.

Upon returning from your [[Restbreak]], the Workrave timers will not start again until your mouse is moved or keys on the keyboard are pressed.  This is a great feature since you might get tied up on your [[Restbreak]] talking to your fellow employees on the way back.  
The lists of actions and reminders will be of little use if not reviewed at least daily, or when ever possible.  Given the time, energy and resources available at a particular moment, one must decide the most important task to be done immediately, and do it.  

If one is inclined to procrastinate, one may end up always doing the easy tasks and avoiding the difficult ones.  

To solve this, one can decide to do the actions of the list one by one, following their order, just like processing an inbox.

At least weekly, the discipline of GTD requires that all outstanding actions, projects and [[waiting for|Waiting for - Organize - GTD]] items are reviewed, making sure that any new tasks or forthcoming events are entered into one's system, and that everything is up to date.  Allen suggests the creation of a [[Tickler File|Tickler File - GTD]] in order to help refresh one's memory each week with the outstanding tasks and projects.
Term for the area of the world where Route 6 radio will be selling
*Home
*Music/local artists
**Country
**Accoustic
*Weather
**County A
**County B
**Etc...
*Local Events (Route 6 Hometown Calendar)
**Winter Events
**Spring Events
**Summer Events
**Fall Events
*History
**History of Route 6 in PA
**History of area
*Advertising (maybe a link at the bottom not in the top menu)
*Outdoors
**Hunting
**Fishing
*Delectable Delicacies
**Wineries
**Cheeseries
**Maple Syrup
*Local ‘happy news’
**Birthdays
**Anniversaries
Robin

5:00-8:00 SL Time
>Hello fellow Carpies!
>
>I just received an email from a relative that contains a link to a Carpatho Rus radio show that is played on the air in Pittsburgh.  The Radio show host however is in debt to the radio station ($700) and needs support to keep 
>the show on ([[listen to the very end of this episode to find out more|http://jj.wedo810.com/12-06-09%20Carpatho-Rus%27%20Living%20Tradition%20Program.mp3]]).  His name is Jerry Jumba and I'm sure I've heard of him on the radio before. 
>
>So everybody enjoy, [[listen|http://JJ.WEDO810.com]] and donate!  :)
>
>(By the way the link is just a directory of mp3's as I'm pretty sure Jerry isn't too computer savy...but be grateful that he at least got these on the Internet and help him preserve our heritage)
>
>The most recent radio show contains the address to send donations to.

{{{
Dear Radio Listeners on the WEB, 
 
              Vitajte! Welcome!  
 Enjoy Carpatho-Rus' Radio on the WEB by entering:    http://JJ.WEDO810.com     in your search engine. Click in,  and click on the titles and dates of the broadcasts. 
 
              Recent dates: November 29 and December 6 are also Christmas broadcasts of Carpatho-Rus' 

roždestvenýj koljadý, koljadký, and ščedrivký.  
 
Best Regards,  
Jerry Jumba
 
 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

                   

                       Saving and Growing - Carpatho-Rus' Chant and Hymnology

 

        There is a great need to rescue of the living tradition of vocal prayer chant and hymnology knowledge of Carpatho-Rus' Eastern Christianity. The best standards of vocal cultural transmission into American English need far more continuous examination, a paying of attention to the details of the sacred artistry that is at work in the original living tradition chant. This trusted congregational musical life lives the knowledge and the energy of shared prayer, and is the best evolved chant source of musical integrity by which congregations chant successfully and communally harmonize to realize the loving presence of God in Divine Liturgy. 
 
          For over four decades I applied myself to learn as much as I could find in my continuous search of this living tradition chant. I have hundreds of field recordings and wrote more than 45 volumes in C-Rus' Chant curriculum in careful collaborations. Since the 1980's I schooled over 140 cantors, and these students have various levels of accomplishment within their ongoing commitment. Some have much chant learning to accomplish in order to complete and fulfill their commitment to these studies that bring the fullness of chant knowledge forward in Eastern Christian liturgical prayer life.
 
        I work for the opportunities to save, grow, and share this divine prayer vocal knowledge of the Eastern Christian Carpatho-Rus' Chant. To look and listen for the best practices of this vocal knowledge in all our churches, is sacred musicology that respects the evolved melodic and harmonic integrity of sacred vocal music. To hear the range of great Carpatho-Rus' vocal prayer music involves the field work is to listen and record objectively, and participate personally to study and know the melodic integrity and artistry from numerous successful cantor practitioners who live to demonstrate chant by strong faith and the love of God, and by faithfulness to a vocal knowledge standard that is a successful vocal connection, so that each person in the congregation might be embraced and inspired to join their energy in singing divine chant, to bring God's loving presence forward within each of us. To reveal this chant with accurate music writing, is to save an innocent sacred chant from a terrible oblivion. 
 
              The duty of our living generation is to renew its artistic integrity in the communal Eastern Christian nurture by which our people's inspiration to seek God's love, has lived to realize victories over sin (!) and found God's love!  To renew our participation in Divine Liturgy at this highest possible standard is the work at the center of my life, so that we, in a great enlightened collaboration of spirit and grace, apply the finest and proven chant education principles in the accuracy of the transmission of the vocal knowledge so that we may achieve in our present day a renewal of the musical integrity of the Carpatho-Rus' vocal prayer chant that we have earned from generations who prayed successfully, and taught us to pray.
 
            I hope most sincerely that we may let  the work and healing begin anew in those chant education principles and in the fullness of Carpatho-Rusin Chant research to the highest possible standard, to realize and know God's love and healing and hope continuously in good measure.
 
         Those generations before us found God's love by in the deepest commitments to prayer chant standards that bonded their grace and spirit within their community in prayer - living  the spiritual intelligence and energy within this Carpatho-Rus' Chant.  Learning the trusted vocal chant standard gives our people the confidence that God's love is continuous and available by our reaching for God's inspiration. Their chant learning is the prayerful work of learning the living tradition chant melodies with faithful pitch and rhythm in focused stylization, not distorted by unfocused stylization. Their learning is the careful handiwork of prayer music artisans who pay attention to the integrity of musical and vocal details, in grace and spirit realized. Through this prayer they showed the strength of spiritual development to live in grace and resist sin, and build and support churches wherever they needed to build. Our time to re-invest in the education of this vocal prayer knowledge is now. Our time to realize excellent education and act on behalf of the living spiritual life of this vocal prayer knowledge, with the artistic intelligence within its dynamic communal melody and harmony, is now.
 
           I live simply, not with a big budget, and work on my C-R Chant research publications with Grants in The Arts. I cantor, teach chant and instrumentalists, and play numerous musical job scenarios, sing along and instrumental. I hope to keep our connection real, and connect as a co-steward and a cultural citizen with discerning standards for the greater good that we may share and live well in the continuity and development of this worthy, long standing, trans-generational effort to earn and realize the grace and spirit of God in our lives.   

 

Cantor, Cantor Teacher,

Jerry Jumba

 


Subj: 	C-RS This Saturday and Sunday Holiday Ethnic Celebration 
Date: 	11/20/2009 8:31:22 P.M. Eastern Standard Time
To: 	jerryjumba-*at*-aol.com
Sent from the Internet (Details)
 

Dear Jerry Jumba                                                                                November 20, 2009

 

Holiday Ethnic Celebration

Heinz Regional History Center

Smallman Street, Pittsburgh

 

Featuring displays of Ethnic Holiday displays, food and entertainment

 

Saturday, Nov. 21 and Sunday, Nov. 22

11 a.m. - 3 p.m.

 

C-RS is sponsoring the Rusyn Christmas display, and will be selling Rusyn ethnic items, palachinki and cheregi

 

Jerry Jumba will perform Rusyn Carols - 2:10 p.m. Saturday and 11:40 a.m. Sunday

 

For more information, contact the Heinz History Center at <span class="skype_pnh_print_container">412-454-6411</span><span tabindex="-1" dir="ltr" class="skype_pnh_container"><span class="skype_pnh_mark"> begin_of_the_skype_highlighting</span>&nbsp;<span dir="ltr" title="Call this phone number in United States of America with Skype: +14124546411" class="skype_pnh_highlighting_inactive_common"><span skypeaction="skype_dropdown" class="skype_pnh_left_span">&nbsp;&nbsp;</span><span skypeaction="skype_dropdown" title="Skype actions" class="skype_pnh_dropart_span"><span skypeaction="skype_dropdown" style="background-position: -5849px 1px ! important;" class="skype_pnh_dropart_flag_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>&nbsp;&nbsp;&nbsp;</span><span class="skype_pnh_textarea_span"><span class="skype_pnh_text_span">412-454-6411</span></span><span class="skype_pnh_right_span">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span>&nbsp;<span class="skype_pnh_mark">end_of_the_skype_highlighting</span></span> 

 

 

http://www.heinzhistorycenter.org/events.aspx?EventID=8

 

 

The Carpatho-Rusyn Society is a non-profit, 501(c)(3) organization dedicated to manifesting Carpatho-Rusyn culture in the United States and supporting Rusyn culture in the Homeland in east central Europe.  It works to educate Rusyns and non-Rusyns about Rusyn culture and history, and to support the development of Rusyn culture on both sides of the Atlantic.   As a membership organization, it boasts over 1,800 members worldwide who support the organization's work through their annual contributions of dues as well as voluntary contributions to funds that support Rusyn cultural development abroad as well as humanitarian aid for Rusyn communities in Europe.  For more information, please visit www.c-rs.org

 

++++++++++++++++++++++++++++++++++++++++++++++++++

 

Subject: Question about the Heinz History Center performances Nov 21, 22, 2009
Date: 11/23/2009 10:02:19 A.M. Eastern Standard Time
From: Jerry Jumba 
 

                                                            Report From The Heinz History Center

 
          Saturday and Sunday, it was at the Western PA Heinz History Center in the Strip District. Each day  I chanted Carpatho-Rus' Christmas Carols bilingually with accordion accompaniment to give the full harmonization of the melody and narrated the Bethlehem Play (Viflejemska Ihra ) story in between the progression of carols. It went well !  Within me, this is a strong area of studied knowledge and life experience and teaching in classrooms with a well prepared energized and rational teaching method for the mystery of grace and spirit that comes forward in the revelation of Christ's birth. I had taught these carols in Byzantine Catholic day schools for twenty years, and in the Metropolitan Cantor's Institute in the Archieparchy of Pittsburgh (1984 - 1992), and in Byzantine Catholic and Orthodox churches since the early 1980's. 
 
          On Saturday I included a talented ten year old Alexandra Plummer who was dressed in costume and attending the C-RS Rusyn sales and information table with her mom Mary Huzinec and three more Carpatho-Rusyn Society workers. Alexandra danced for Jesus when I played the Shepherd's Palichki Tanec music, and she chanted - in a strong and clear child's voice - O Kto Kto Nikolaja Ljubit' bilingually with me to close the presentation. I introduced the hymn explaining how God sent the gift of His Son for the salvation of souls and how Nicholas of Myra earned sainthood and came along to epitomize the spirit of giving and help those in need for the greater good of nurture realized in our physical tangible needs and in our spiritual needs.
 
   On Sunday, toward the end of the presentation, I noticed an excellent cantor in the audience - Gerry Pozonsky Rhoads - who is an accomplished Cantor at St. Pius Byzantine Catholic Church in the Carrick section of Pittsburgh - just beyond South Side, and asked her to join me on stage for the closing carols which were Divnaja Novina, and Nebo I Zemlja. She chanted strong and true and I harmonized with her and the response was good.   
 
Jerry Jumba

 

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
}}}
!Automatic

!Manual
Makes cuts only after confirmation at each scene transition.  The preview always displays the end of the previous scene and the beginning of the new scene.  

This option is helpful, for example, if a camera flash was captured in the source footage.  The flash from the camera would cause a sudden brightness modification even though there was no actual scene change.

''Separate at this point: ''  Select this option when there is significant variation between two images in the display.

''Next Scene: '' This option enables you to skip a point with-out cutting in the event that the scene was identified incorrectly.  Use this option to deliberately skip scene transitions and treat several scenes as a unit.

''Automatically cut all further scenes: '' 
This ends the manual scene recognition.  All future points will be automatically cut to create a new scene.

//Tip: You can also use the cut menu for cutting scenes.  Place the s-marker where you wish to performa a cut, and then select the "Cut Scene" command.//
!Cutting up a scene
This command cuts a scene at the point where the Start marker is positioned.

//Shortcut: t//


!Delete Scene start
This command cuts a scene at the point where the Start marker is positioned, and deletes all material that precedes the start position simultaneously.

//Shortcut: Ctrl+t//


!Delete Scene end
This command cuts a scene at the point where the Start marker is positioned, and deletes all material that follows the start position simultaneously.

//Shortcut: Shift+z//


!Divide Film
This command splits a movie at the point where the start marker is positioned, making two self-standing movies.

// Shortcut: Alt+t//
[[How to search Stackoverflow|http://stackoverflow.com/search]]

Oh and as a side note, to search your own tags you can use:

{{{user:me [tag1] [tag2]...}}}
/***
Quick and dirtly palette switcher for 2.1.x
<<selectPalette>>
WARNING this will overwrite your ColorPalette tiddler.
***/

//{{{

merge(config.macros,{

	setPalette: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var paletteName = params[0] ? params[0] : tiddler.title;
			createTiddlyButton(place,"apply","Apply this palette",function(e) {
				config.macros.selectPalette.updatePalette(tiddler.title);
				return false;
			});
		}
	},

	selectPalette: {

		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			createTiddlyDropDown(place,this.onPaletteChange,this.getPalettes());
		},

		getPalettes: function() {
			var result = [
				{caption:"-select palette-", name:""},
				{caption:"(Default)", name:"(default)"}
			];
			var tagged = store.getTaggedTiddlers("palette","title");
			for(var t=0; t<tagged.length; t++)
				result.push({caption:tagged[t].title, name:tagged[t].title});
			return result;
		},

		onPaletteChange: function(e) {
			config.macros.selectPalette.updatePalette(this.value);
			return true;
		},

		updatePalette: function(title) {
			if (title != "") {
				store.deleteTiddler("ColorPalette");
				if (title != "(default)")
					store.saveTiddler("ColorPalette","ColorPalette",store.getTiddlerText(title),
								config.options.txtUserName,undefined,"");
				this.refreshPalette();
				if(config.options.chkAutoSave)
					saveChanges(true);
			}
		},

		refreshPalette: function() {
			config.macros.refreshDisplay.onClick();
		}
	}
});

//}}}
The "Editing" menu lets you set a play marker at the current position of the Start marker.  The 3 markers can be set using the number keys 1-2-3.  This allows you to jump to a particular position of a longer video immediately, with out scrolling and searching.
Snap points (HotOffsets) server to mark certain positions in the movie to doc other objects there "magnetically".  For instance, you can set a snap point at the position of a door falling shut, in order to position an audio object of a door closing there.

!How to use snapoints
*Select a Video Object
*Set the start marker to the position where you would like to set the snap point.
*In the {{{Edit}}} menu select the option {{{Edit snap points->Set snap points}}}

A vertical line will now appear at the position of the start marker.  You can now drag & drop any other object to this position (audio objects, titles, fades, etc...)
+++[Setting up the Refactoring Tool]
You can download the [[refactor.vim|http://vim.sourceforge.net/scripts/script.php?script_id=208]] tool from vim's sourceforge site
===

+++[Setting up exuberant ctags]
The next two plugins I'm going to go over, both require that you have [[exuberant ctags|http://ctags.sourceforge.net/]] installed.  So lets install that first.

Go to their website: [[http://ctags.sourceforge.net/]] and download a copy, 
===

+++[Setting up the taglist.vim plugin]
>The "Tag List" plugin is a source code browser plugin for Vim and provides an overview of 
#Install taglist.vim by unziping it's contents into the various directories 
===
#Went to [[this website|http://www.microsoft.com/express/download/#webInstall]] and downloaded ''Visual Web Developer 2008 Express Edition''
#Closed all other programs and braced for installation.
#Opened the executable and installed.
**Installed the MSDN Express Library for Visual Studio 2008 (DL Size: 297 MB).
**Installed MS SQL Server 2005 Express Edition (x86) (DL Size: 36 MB)
**Installed MS Silverlight Runtime (DL Size: 1.4 MB)
**Told installer to install it all in {{{C:\ndev\Microsoft Visual Studio 9.0\}}}
***//(Disk Space Requirements 2.8 GB!?!??!) - Are you kidding me?!?! Oh well here we go...//
***It seems to me it's going to be a while...
#Hmm has an entire day passed?  Oh look it's done!
<<tabs "dasfewafeasce323"
"4.1" "Adding Names to dnsmasq" "Adding dns names to dnsmasq - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"4.2" "Adding an equivalent virtual host to Apache" "Adding a Virtual Host to Apache - Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
>>
#You need both libjson and mia packages.
#Packages that mia needs:
##iptables-mod-ipopt
##kmod-ipt-ipopt
##iptables-mod-nat-extra
##kmod-ipt-nat-extra
##libpthread
#Choose the appropriate ipk file for your openwrt firmware
#Modify /etc/init.d/mia script, change the {{{WAN_IF}}} and {{{LAN_IF}}} variables to your wan and lan interfaces if needed.
#Enable mia initscript.
#Access your router's UI: http://<ip-address>/mia/index.html

(Password) Authentication for uhttp:
#Create a file /etc/httpd.conf
#Put the following line in httpd.conf:
{{{
/mia:<username>:<password>
}}}

Where username and password are the credentials that you want to log in as.

!!!Setting up a domain for dnsmasq
The root domain that we will be serving pages up from is {{{leerdomain.localLAN}}}, this will be the suffix that we add to any machines that we have on our network.  In order to do this look for the line in the configuration file that reads
{{{
# Set the domain for dnsmasq this is optional but if it is set it 
# does the following things
# 1) Allows DHCP hosts to have fully qualified domain names as long
#      as the domain part matches this setting
# 2) Sets the "domain" DHCP option thereby potentially setting the 
#      domain of all systems configured by DHCP
# 3) Provides the domain part for "expand-hosts"
}}}
And below it make sure the {{{domain}}} setting is commented out and set to the domain suffix of your choice.
{{{
domain=leerdomain.localLAN
}}}
<<slider "Introduction - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq" "Introduction - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq" "+Introduction" >>

<<tabs "sdfaerqwer"
"0" "1 - Introduction" "1 - Introduction - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"1" "Writing the Deployment Mechanism" "Deployment - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"2" "Putting Version Control in Place with GIT" "GIT - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"3" "Local Setup" "Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"4" "Setting up Accessible Virtualhosts on Apache" "Setting up Accessible Virtualhosts - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
"5" "Deploying Settings" "Deploying Settings - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq"
>>

Now this will serve as our setup for the current network.  Once the settings are deployed all we need to do is point each of the clients towards the dns server when we want to test them for development using a testing framework like 



!Pointing our clients at the dnsmasq dns server

Now this step will have to occur everytime we setup 

[[dom inspect link|http://www.itworld.com/mobile-wireless/349853/how-remotely-inspect-dom-mobile-device]]

{{{
git branches
git checkout <branch-name>

dig @8.8.8.8 yields no result....
dig @127.0.0.1 yields an answer.
}}}

#Downloaded and installed [[xampplite|http://sourceforge.net/project/downloading.php?groupname=xampp&filename=xampplite-win32-1.7.0.exe&use_mirror=internap]]
#
!@@color(red):Draft@@
!!Open the Firefox Profile Editor (for both Firefox 2 and 3)
{{{
"%FF_HOME%\firefox.exe" -profilemanager -no-remote
}}}

!!Opening a Profile So that it's opened in either FF2 or FF3 using a Windows Shortcut...

!!!Opening a Profile in FF3
> Just be sure the executable for Firefox 3 is being executed in the shortcut.
{{{
"C:\Program Files\Mozilla Firefox 3\firefox.exe" -P "WebDevFF3" -no-remote
}}}
{{{
import freemind.main.Tools.BooleanHolder 

 new File('file.csv').splitEachLine(',') { fields ->  println fields[0] + " " + fields[1] + " " + fields[2] + " " + fields[3];   

	def newNode = c.addNewNode(node, 0,  true)  newNode.setText(fields[0]); 
}
}}}
leeand00's blog journal
leeand00's Blog
*[[CyberCoders.com|http://www.cybercoders.com]]
*[[dice.com|http://www.dice.com]]
*[[jobster|http://www.jobster.com/]]
*[[monster.com|http://www.monster.com]]
*[[collegegrad.com|http://www.collegegrad.com]]
Software was specifically suggested by Allen as helpful and important for implementing GTD, including:
*digital outlining
*brainstorming
*project planning

However in 2001, Allen bemoaned the general lack of "good 'project management' tools, " concluding:

>...less structured and more functional applications will emerge in the coming years, based on the wys we naturally thing and plan.

Since that prediction, a virtual explosion of GTD-supporting software has emerged; in April 2008, more than 100 applications provided the core features for implementing [[Getting Things Done]] These tools now range from simple list managers to collaborative web services, both free and commercial, for all popular platforms and devices.  Much of this software specifically automates or reinforces the GTD methodology of collecting, processing, organizing, reviewing, and doing.
Things to be done at some point, but not right now. 

!!!Examples:
*Learn Chinese
*Take a diving holiday
<html>
<body>
<table>
<tr>
<td>
<a href="http://twitpic.com/4f7wm" title="Awesome Coffeeshop at 
109 E High St, Womelsdorf, PA where I... on Twitpic"><img src="http://twitpic.com/show/thumb/4f7wm.jpg" width="150" height="150" alt="Awesome Coffeeshop at 
109 E High St, Womelsdorf, PA where I... on Twitpic"></a><br/>
<a href="http://www.crave8.com/">The Crave Website</a>
</td>
<td>
<iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.com/maps?q=crave8&amp;oe=utf-8&amp;client=firefox-a&amp;ie=UTF8&amp;hl=en&amp;ll=40.372901,-76.177139&amp;spn=0.006442,0.014119&amp;z=14&amp;iwloc=A&amp;cid=7402259740998695190&amp;output=embed"></iframe><br /><small><a href="http://maps.google.com/maps?q=crave8&amp;oe=utf-8&amp;client=firefox-a&amp;ie=UTF8&amp;hl=en&amp;ll=40.372901,-76.177139&amp;spn=0.006442,0.014119&amp;z=14&amp;iwloc=A&amp;cid=7402259740998695190&amp;source=embed" style="color:#0000FF;text-align:left">View Larger Map</a></small>
</td>
</tr>
</table>
</body>
</html>
If you ever work for a bunch of people who refuse to use the STL or string libraries of C++ here is some code for splitting strings apart and returning them as 2D character array.  

''If you use it send me some love!  (leave a comment)''

!Code
<<tabs "7/16/20082:07 PMs" 
     "main.cpp" "main.cpp - Split for C++ Test Case" "main.cpp - Split for C++ Test Case"
      "split.cpp" "split.cpp" "split.cpp"
      "split.h" "split.h" "split.h"

>>

!Output:
{{{
Original String: pe|butter|jelly|cheese|log|beef|regano|tea
pe
butter
jelly
cheese
log
beef
regano
tea
Press any key to continue
}}}
Objects may be split to separate each individual component into an independent object for editing.  

To use this function, you select the option {{{edit->splitting objects}}}

[[also see|Rejoining Objects]]
''Definition:''
>A sequence of visible tiddlers.
/*{{{*/
div.viewer {
   font-family:Verdana;
   line-height:190%;
   font-size: 16px;
   text-indent:1.5em;
}

div.viewer li {
   text-indent:0em;
}

/*}}}*/
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}

a {color:[[ColorPalette::PrimaryMid]];}
a:hover {background-color:[[ColorPalette::PrimaryMid]]; color:[[ColorPalette::Background]];}
a img {border:0;}

h1,h4,h5,h6 {color: #401F1C; background:transparent;}
h2 {color: #733630; background: transparent;}
h3 {color: #00FF00; background: transparent;}
h1 {border-bottom:2px solid #3D4025;}
h2,h3 {border-bottom:1px solid #3D4025;}

.button {color: #401F1C; border:1px solid [[ColorPalette::Background]];}
.button:hover {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::SecondaryLight]]; border-color:[[ColorPalette::SecondaryMid]];}
.button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::SecondaryDark]];}

.header {background:[[ColorPalette::PrimaryMid]]; border-bottom: 10px solid #733630;}
.headerShadow {color:[[ColorPalette::Foreground]];}
.headerShadow a {font-weight:normal; color:[[ColorPalette::Foreground]];}
.headerForeground {width: 100%; background-color: #401F1C;  color: #FFF;}
.headerForeground a {font-weight:normal; color:[[ColorPalette::PrimaryPale]];}

.tabSelected{color:[[ColorPalette::PrimaryDark]];
	background: #8C8564;
	border-left:1px solid [[ColorPalette::TertiaryLight]];
	border-top:1px solid [[ColorPalette::TertiaryLight]];
	border-right:1px solid [[ColorPalette::TertiaryLight]];
}
.tabUnselected {color:#D9BEA7; background-color:#401F1C; border-bottom: 1px solid [[ColorPalette::TertiaryLight]]}
.tabContents {color:[[ColorPalette::PrimaryDark]]; background: #8C8564; border:1px solid [[ColorPalette::TertiaryLight]];}
.tabContents pre {
color: black;
}
.tabContents .button {border:0;}

#sidebar {}
#sidebarOptions input {border:1px solid [[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel {background-color: #8C8564;}
#sidebarOptions .sliderPanel a {border:none;color:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:hover {color:[[ColorPalette::Background]]; background:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:active {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::Background]];}

.wizard {background: #8C8564; border:1px solid [[ColorPalette::PrimaryMid]];}
.wizard h1 {color:[[ColorPalette::PrimaryDark]]; border:none;}
.wizard h2 {color:[[ColorPalette::Foreground]]; border:none;}
.wizardStep {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];
	border:1px solid [[ColorPalette::PrimaryMid]];}
.wizardStep.wizardStepDone {background::[[ColorPalette::TertiaryLight]];}
.wizardFooter {background-color: #8C8564;}
.wizardFooter .status {background:[[ColorPalette::PrimaryDark]]; color:[[ColorPalette::Background]];}
.wizard .button {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryLight]]; border: 1px solid;
	border-color:[[ColorPalette::SecondaryPale]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryPale]];}
.wizard .button:hover {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Background]];}
.wizard .button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::Foreground]]; border: 1px solid;
	border-color:[[ColorPalette::PrimaryDark]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryDark]];}

#messageArea {border:1px solid [[ColorPalette::SecondaryMid]]; background:#8C8564; color:[[ColorPalette::Foreground]];}
#messageArea .button {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::SecondaryPale]]; border:none;}

.popupTiddler {background:[[ColorPalette::TertiaryPale]]; border:2px solid [[ColorPalette::TertiaryMid]];}

.popup {background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]]; border-left:1px solid [[ColorPalette::TertiaryMid]]; border-top:1px solid [[ColorPalette::TertiaryMid]]; border-right:2px solid [[ColorPalette::TertiaryDark]]; border-bottom:2px solid [[ColorPalette::TertiaryDark]];}
.popup hr {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::PrimaryDark]]; border-bottom:1px;}
.popup li.disabled {color:[[ColorPalette::TertiaryMid]];}
.popup li a, .popup li a:visited {color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:active {background:[[ColorPalette::SecondaryPale]]; color:[[ColorPalette::Foreground]]; border: none;}
.popupHighlight {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
.listBreak div {border-bottom:1px solid [[ColorPalette::TertiaryDark]];}

.tiddler .defaultCommand {font-weight:bold;}

.shadow .title {color: #734C29;}

.title {color: #333333;}
.subtitle {color:[[ColorPalette::TertiaryDark]];}

.toolbar {color:[[ColorPalette::PrimaryMid]];}
.toolbar a {color:[[ColorPalette::TertiaryLight]];}
.selected .toolbar a {color:[[ColorPalette::TertiaryMid]];}
.selected .toolbar a:hover {color:[[ColorPalette::Foreground]];}

.tagging, .tagged {border:1px solid [[ColorPalette::TertiaryPale]]; background-color:#8C8564;}
.selected .tagging, .selected .tagged {background-color:[[ColorPalette::TertiaryLight]]; border:1px solid [[ColorPalette::TertiaryMid]];}
.tagging .listTitle, .tagged .listTitle {color: #401F1C;}
.tagging .button, .tagged .button {border:none;}

.footer {color:[[ColorPalette::TertiaryLight]];}
.selected .footer {color:[[ColorPalette::TertiaryMid]];}

.sparkline {background:[[ColorPalette::PrimaryPale]]; border:0;}
.sparktick {background:[[ColorPalette::PrimaryDark]];}

.error, .errorButton {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Error]];}
.warning {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryPale]];}
.lowlight {background:[[ColorPalette::TertiaryLight]];}

.zoomer {background:none; color:[[ColorPalette::TertiaryMid]]; border:3px solid [[ColorPalette::TertiaryMid]];}

.imageLink, #displayArea .imageLink {background:transparent;}

.annotation {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border:2px solid [[ColorPalette::SecondaryMid]];}

.viewer .listTitle {list-style-type:none; margin-left:-2em;}
.viewer .button {border:1px solid [[ColorPalette::SecondaryMid]];}
.viewer blockquote {border-left:3px solid [[ColorPalette::TertiaryDark]];}

.viewer table, table.twtable {border:2px solid [[ColorPalette::TertiaryDark]];}
.viewer thead td, .twtable th, .twtable thead td {background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::Background]];}

.viewer th {
   background-color: #401F1C;
   color: white;
   font-weight: strong;
}

.viewer td, .viewer tr, .twtable td, .twtable tr {border:1px solid [[ColorPalette::TertiaryDark]];}

.viewer pre {border:1px solid [[ColorPalette::SecondaryLight]]; background:[[ColorPalette::SecondaryPale]];}
.viewer code {color:[[ColorPalette::SecondaryDark]];}
.viewer hr {border:0; border-top:dashed 1px [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::TertiaryDark]];}

.highlight {background-color: yellow;}

.marked {background:yellow;}

.editor input {border:1px solid [[ColorPalette::PrimaryMid]];}
.editor textarea {border:1px solid [[ColorPalette::PrimaryMid]]; width:100%;}
.editorFooter {color:[[ColorPalette::TertiaryMid]];}

#backstageArea {background-color: black; color: white;}
#backstageArea a {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstageArea a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; }
#backstageArea a.backstageSelTab {background:[[ColorPalette::Background]]; color:black;}
#backstageButton a {background:none; color:[[ColorPalette::Background]]; border:none;}
#backstageButton a:hover {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstagePanel {background:[[ColorPalette::Background]]; border-color: [[ColorPalette::Background]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]];}
.backstagePanelFooter .button {border:none; color:[[ColorPalette::Background]];}
.backstagePanelFooter .button:hover {color:[[ColorPalette::Foreground]];}
#backstageCloak {background:[[ColorPalette::Foreground]]; opacity:0.6; filter:'alpha(opacity:60)';}
/*}}}*/
''Definition:''
>The Tiddler that provides the tiddlywiki with it's stylesheets/CSS information.
[[article link|http://www.ceti.pl/~tss/smce/help.htm]]

!Learn proceeds in three stages:
#Repeating items scheduled for the current day (REPETITION).
#MEMORIZING new items.  Before you start this stage, you will be asked {{{Do you want to learn new material?}}}
#Repeating items that caused recall problems in stages 1-2 (FINAL DRILL).

Here is the best algorithm for using SuperMemo (tried successfully by thousands of users in several dozen countries of the world):
#Choose the daily working time from 5 to 45 minutes.
##If {{{To repeat}}} in your database(s) is different from zero, repeat outstanding items until {{{To Repeat}}} equals zero (use Learn).
##If you have got some time left for work with SuperMemo, and if {{{Pending}}} in your database is different from zero, memorize new items until Pending equals zero or until your time is up (whichever comes first).
##If you have got some time left for work with SuperMemo, add new items collected in (the step below) {{{use Add New}}}.  If your time is limited, select only the most important items.  Keep unused items for later use.  Continue appending new items until your time is up.
#In the course of your ordinary daily activities collect items that you want to remember (facts, figures, rules, vocabulary, names, phones, etc...).  For examples, see sample databases.

!Summary
the key to effective learning is minimizing the number of repetitions necessary to retain knowledge in your memory.  SuperMemo minimizes time needed for learning by approximating optimal intervals that should separate individual repetitions.  Knowledge memorized with SuperMemo must be split into smallest possible pieces called items.  Using SuperMemo, you must not forget that the quality of learning will depend on the selection of the material and the way it is split into individual items.

The remainder of the screen is divided into five parts:
#''Question'' field, which displays the current question (this field can be used to edit the question)
#''Answer'' field, which displays the current answer (this field is blank at times when the learner is supposed to recall the answer during a repetition cycle).
#''Statistics'' field, which contains the following data:
*Collection name - name of collection in use.
*Total number of items in the collection.
*Memorized - number of memorized items in the collection.
*Pending - number of pending items in the pending queue.
*To repeat: number of items to repeat and to drill.
**For example, if there are 48+5 items to repeat, you still have 48 outstanding items repeated again in the final drill.
***In other words there are at least 48+5=53 repetitions to be made on the present day.
#''Item'' statistics field with item parameters which characterize the currently displayed item:
*''Number'' - number of currently displayed item.
*''Last rep'' - date of a previous repetion of the current item.
*''Interval'' - interval between the last and the next repetion.
*''Next rep.'' - date of next repetition.
*(x) - number of repetitions which indicates that the displayed item has been repeated x times since it has been introduced into the collection or since it has been reset.
#Below the Answer window there is some place for miscellaneous button sets (quick buttons).  When there is no collection opened, there are up to three buttons with recent collection names.  So you can quickly open a recently used collection.

!SuperMemo CE/SP Basics
The main function of SuperMemo is to supervise the process of learning pairs of questions and answers
[[edit|Switching Networks - Network Management - Local Setup - Setting up a mobile-mobile development environment in linux with GIT and DNSMasq]]
>Alot of times I sync my files between work and my home computer, mainly my Tiddlywiki's that I use to learn about technology.   I usually copy my directory of personal wiki's to a thumb drive and then go back home, and copy them back onto my home computer, just incase I do a tutorial on the weekend that I could use back at work.  

>Of course I could just make a new copy of the entire directory, but after my Intranet of personal wiki's grew over to a size over a gigabyte, it became somewhat cumbersome and slow to copy and entire gigabyte of data between my home and work computer every day. 

>After consulting [[del.icio.us|http://del.icio.us/]] I found a program called SyncBack, which allows you to [[synchronize|synchronizing files]] two directories of files.   SyncBack is available from [[2brightsparks.com|http://www.2brightsparks.com/]].  

>I'm using the freeware edition of SyncBack, and the tutorial that they have on the website is only for SyncBackSE (which consequently isn't freeware), so I'm writing my own tutorial to so I can learn how to use SyncBackSE.  

!Creating a New Profile
#I've started by opening SyncBack freeware and selecting {{{Profiles->New}}} from the menu to begin creating a new profile.  
#Next the Profile type dialog is presented, and I have selected the radio button labeled, "''Synchronization: for keeping the contents of two directories identical''" and clicked "''__O__K''"
#I've given my new profile the name "''AndysIntranet''"
#The setup dialog for "''AndysIntranet''" is now displayed and at the top two browse textboxes are displayed:
**''Source:'' and ''Destination:''<br/><br/>I plan to use ''Source'' for the directory on my home computer, and ''Destination'' for the directory on my thumb drive which I take to work.<br/><br/> So, after plugging in my thumb drive, I select the two directories; 
#Next under the ''"Simple"'' tab, Sync
/***
|Name|TagGridPlugin|
|Source|http://www.TiddlyTools.com/#TagGridPlugin|
|Version|1.6.5|
|Author|Eric Shulman - ELS Design Studios|
|License|http://www.TiddlyTools.com/#LegalStatements <<br>>and [[Creative Commons Attribution-ShareAlike 2.5 License|http://creativecommons.org/licenses/by-sa/2.5/]]|
|~CoreVersion|2.1|
|Type|plugin|
|Requires||
|Overrides||
|Description|Generate a cross-referenced grid of tiddlers, based on tag values|

!!!!!Usage
<<<
Specify which tags should be used for the columns and rows of the grid to ''see a particular cross-section'' of your document, or use //all// tags to ''get an instant 'birds-eye' overview of your entire document''.

Each grid cell contains a label with the number of tiddlers in that grid cell.  Click the number to ''show a popup of cross-indexed tiddler titles''.  Grid cells with no matching tiddlers contain a "-" (dash) that can be clicked to ''create new tiddlers automatically pre-tagged with that cell's combination of tags.''

To keep the grid display from getting very wide, the grid tags used as column headings are not initially displayed.  ''Click directly above the column to show/hide that heading'', or toggle all column headings at once by clicking the {{{>>>}}} symbol in the upper-left corner of the grid display.  Clicking a displayed row/column tag heading opens the tiddler whose title is that tag name.

The macro syntax to include a tag grid in your tiddler content is:
{{{<<tagGrid columntags exclude:tags rowtags exclude:tags startcolor endcolor open inline colorall sortrows sortcolumns>>}}}
where:

''rowtags/columntags'' are each:
* a ''quoted'' space-separated lists of tags: {{{"tag1 tag2 [[tag3 with spaces]] tag4 ..."}}}
* //or,// a tiddler name preceded by "+": {{{+TiddlerName}}} where the specified tiddler contains a space-separated list of tags (same format as DefaultTiddlers)
* //or,// a tiddler name preceded by "@": {{{@TiddlerName}}} to use the same tags as those that are tagging the specified tiddler (i.e., the tiddler is a representative example of the kind of tags you are interested in cross-indexing)
* //or,// a tag name preceded by "=": {{{=tagName}}} to use the group of tags that are themselves, in turn, tagged with the indicated tagName (i.e., useful when you have defined a 'meta-tag'/classification system, a.k.a. "TagglyTagging" techniques)
* //or,// keyword: {{{all}}} (use all tags)
* if only columntags are specified, rows display all tags by default
* if no parameters are provided, both rows and columns display all tags
''exclude:tag tag tag''
* This optional parameter can be placed immediately following the columntags and/or rowtags parameter to selectively omit certain tags from the grid display.  You can exclude several tags at once by enclosing the entire parameter in quotes, e.g.: {{{"exclude:tag tag tag"}}}  
''startcolor/endcolor''
* describes a ''color gradient'' where the grid cell background color is calculated as a combination of  the starting and ending colors, in proportion to the cell value
* colors are specified using 6-digit hex-coded RGB values (e.g., red="FF0000", green="00FF00", blue="0000FF")
* the cells with the lowest number use the starting background color
* the cells with the highest number use the ending background color
* if one or both color values are omitted, all cells have //transparent// backgrounds
''open''
* causes the grid column headings to be shown when the grid is initially displayed (you can hide all the column headings using the &lArr; link, or just toggle one heading by clicking //near// the tag text.  (Note: clicking //on// the tag text will open the tiddler with the same name as the tag.
''inline''
* by default, cells with cross-indexed tiddlers display the total number of tiddlers in the cell.  When this number is clicked, a popup is displayed, containing links to the individual tiddlers in that cell.  However, the popup display makes it difficult to compare the contents of two or more cells because only one popup can be displayed at any given time.  To address this, you can use the ''inline'' keyword parameter to ''display the grid contents directly in the cells'', without using any popups.  While this can make the grid display significantly larger (to fit the text of each cell), it also enables quick comparisons between cells.  Inline rendering of the cell contents also makes it possible to print the entire grid contents for easy off-line reporting and analysis.
''colorall''
* by default, cells with no cross-indexed tiddlers have a //transparent// background (e.g., the tiddler's background colors shows through).  However, this can create a 'patchwork' appearance to the grid.  Add the ''colorall'' keyword parameter to force these 'empty' cells to use the specified startcolor instead of a transparent background.
''sortrows/sortcolumns''
* rowtags and columntags are normally displayed in the order specified in the macro parameters, or in alphabetical order when ''all'' is used to generate the list of tags.  Adding the ''sortrows'' and/or ''sortcolumns'' keyword parameters will sort the tags in decending order so that the most frequently used tags are displayed first (i.e., towards the top-left corner).
<<<
!!!!!Examples
<<<
{{{<<tagGrid +FavoriteTags +FavoriteTags eeeeff 3333ff colorall sortrows sortcolumns>>}}}
<<tagGrid +FavoriteTags +FavoriteTags eeeeff 3333ff colorall sortrows sortcolumns>>
<<<
!!!!!Installation
<<<
import (or copy/paste) the following tiddlers into your document:
''TagGridPlugin'' (tagged with <<tag systemConfig>>)
^^documentation and javascript for this plugin^^
<<<
!!!!!Revision History
<<<
''2007.07.24 [1.6.5]'' corrected handling for @TiddlerName with excluded tags, so that excluded tags are not actually removed from the @TiddlerName source tiddler.
''2007.07.04 [1.6.4]'' fix fatal "unterminated string" popup error caused by tiddlers containing double-quotes (now being encoded using "&quot;")
''2007.03.08 [1.6.3]'' use global flag to replace ALL single-quotes in tiddler titles (fixes popups where more than one tiddler title had a ' in it)
''2007.03.06 [1.6.2]'' removed debugging alert()s... D'oh!
''2007.03.06 [1.6.1]'' fix handling for excluding tags (was only removing last tag in list)
''2007.03.05 [1.6.0]'' added "exclude:tag tag tag..." parameter handling for both rows and columns
''2006.12.20 [1.5.1]'' fixed bordercolor calculation and CSS so grid correctly uses midtone-color for table cell borders
''2006.12.09 [1.5.0]'' added 'inline' keyword parameter to display tiddler titles directly in grid cells (in addition to popup)
''2006.11.03 [1.4.0]'' changed {{{=TiddlerName}}} param usage to {{{@TiddlerName}}} and added {{{=tagName}}} usage for specifying TagglyTagging "meta-tagged" groups of tag (based on ideas by GregWolff)
''2006.11.03 [1.3.3]'' performance optimization: calculate maximum cross-index value while building grid (eliminates extra calc during colormapping)
''2006.10.29 [1.3.2]'' fixes for IE: in decToHex and hexToDec, use substr() instead array indexing.  Also, use {{{>>>}}} and {{{<<<}}} instead of {{{&rArr;}}} and {{{&lArr;}}} for 'toggle headings' link text
''2006.10.29 [1.3.1]'' suppress border around table
''2006.10.21 [1.3.0]'' added {{{=TiddlerName}}} and {{{open}}} parameter handling
''2006.10.17 [1.2.1]'' fixed row/column sorting to properly sort undefined tags to the end of the list
''2006.10.16 [1.2.0]'' added optional row/column sorting and improved parameter parsing
''2006.10.15 [1.1.0]'' added features: background gradients, collapsible column headings, eliminated table borders around row/column headings
''2006.10.06 [1.0.1]'' calls to displayTiddler() use 'this' instead of 'null'
''2006.10.05 [1.0.0]'' initial release (converted from prototype inline script)
<<<
!!!!!Credits
<<<
This feature was developed by EricShulman from [[ELS Design Studios|http:/www.elsdesign.com]]
<<<
!!!!!Code
***/
//{{{
version.extensions.tagGrid= {major: 1, minor: 6, revision: 5, date: new Date(2007,7,24)};
config.macros.tagGrid= {
	verbose:false, // display debugging/performance feedback messages
	warn:true,	// display workload warning message before rendering
	threshold:300000, // workload warning threshold (workload=# of comparisons to perform)
	handler:
	function(place,macroName,params) {

		// get columns
		var columntags=params.shift(); var cols=[];
		if ((!columntags)||(columntags=="all")) // no param (or "all") - use all tags
			{ var all=store.getTags(); for (i=0;i<all.length;i++) cols.push(all[i][0]); }
		else if (columntags.substr(0,1)=="+") // get tag list from tiddler content
			{ var t=store.getTiddlerText(columntags.substr(1)); if (t&&t.length) cols=t.readBracketedList(); }
		else if (columntags.substr(0,1)=="@") // get tag list from tiddler tags
			{ var t=store.getTiddler(columntags.substr(1)); if (t&&t.tags) for (i=0;i<t.tags.length;i++) cols.push(t.tags[i]); }
		else if (columntags.substr(0,1)=="=")  // get names of "tagtiddlers" tagged with meta-tag
			{ var t=store.getTaggedTiddlers(columntags.substr(1)); for (i=0;i<t.length;i++) cols.push(t[i].title); }
		else cols=columntags.readBracketedList();
		if (!cols.length) { wikify("~TagGrid: no columns to display\n",place); return; }

		// exclude specific column tags
		if (params[0]&&params[0].substr(0,8)=="exclude:") {
			var ex=params.shift().substr(8).readBracketedList();
			for (x=0; x<ex.length; x++) {
				var i=cols.indexOf(ex[x]);
				if (i!=-1) cols.splice(i,1); // remove excluded tags
			}
		}

		// get rows
		var rowtags=params.shift(); var rows=[];
		if ((!rowtags)||(rowtags=="all")) // no param (or "all") - use all tags
			{ var all=store.getTags(); for (i=0;i<all.length;i++) rows.push(all[i][0]); }
		else if (rowtags.substr(0,1)=="+") // get tag list from tiddler content
			{ var t=store.getTiddlerText(rowtags.substr(1)); if (t&&t.length) rows=t.readBracketedList(); }
		else if (rowtags.substr(0,1)=="@") // get tag list from tiddler tags
			{ var t=store.getTiddler(rowtags.substr(1)); if (t&&t.tags) for (i=0;i<t.tags.length;i++) rows.push(t.tags[i]); }
		else if (rowtags.substr(0,1)=="=")  // get names of "tagtiddlers" tagged with meta-tag
			{ var t=store.getTaggedTiddlers(rowtags.substr(1)); for (i=0;i<t.length;i++) rows.push(t[i].title); }
		else rows=rowtags.readBracketedList();
		if (!rows.length) { wikify("~TagGrid: no rows to display\n",place); return; }

		// exclude specific row tags
		if (params[0]&&params[0].substr(0,8)=="exclude:") {
			var ex=params.shift().substr(8).readBracketedList();
		 	for (x=0; x<ex.length; x++) {
				var i=rows.indexOf(ex[x]);
				if (i!=-1) rows.splice(i,1); // remove excluded tags
			}
		}

		// get optional flag keywords and/or color gradient endpoints
		var defOpen=false;
		var colorAll=false;
		var sortRows=false;
		var sortColumns=false;
		var showInline=false;
		var p=params.shift();
		while (p) {
			switch (p.toUpperCase()) {
				case "OPEN":
					defOpen=true; break;
				case "COLORALL":
					colorAll=true; break;
				case "SORTROWS":
					sortRows=true; break;
				case "SORTCOLUMNS":
					sortColumns=true; break;
				case "INLINE":
					showInline=true; break;
				default:
					if (startcolor==undefined) var startcolor=p;
					else if (endcolor==undefined) var endcolor=p;
					else alert("unexpected parameter: '"+p+"'");
					break;
			}
			p=params.shift();
		}

		// get the tiddlers
		var tiddlers=store.getTiddlers("modified","excludeLists");

		// show "workload warning"... get permission to proceed...
		if (this.warn) {
			var workload=rows.length*cols.length*tiddlers.length;
			var warning="Cross-indexing %0 tiddlers in %1 row%3 by %2 column%4...\n(up to %5 comparisons MAY be needed)\n\n";
			warning+="This may take a while.  It is OK to proceed?";
			warning=warning.format([tiddlers.length,rows.length,cols.length,rows.length!=1?"s":"",cols.length!=1?"s":"",workload]);
			if (workload>this.threshold&&!confirm(warning)) { wikify("~TagGrid: display cancelled by user\n",place); return; }
		}

		// sort row and column tags in decending order, by frequency of use
		if (sortRows||sortColumns) {
			var tags=store.getTags(); var tagcount={}; for (i=0; i<tags.length; i++) tagcount[tags[i][0]]=tags[i][1];
			if (sortRows) rows.sort(function(a,b){return (!tagcount[a]||tagcount[a]<tagcount[b])?+1:(tagcount[a]==tagcount[b]?0:-1);});
			if (sortColumns) cols.sort(function(a,b){return (!tagcount[a]||tagcount[a]<tagcount[b])?+1:(tagcount[a]==tagcount[b]?0:-1);});
		}

		// cross-index tiddlers by tags, building lists of tiddler titles into grid[i][j] (sparse array)
		var time1=new Date();
		var grid=new Array();
		var max=0;  // track maximum cross-index value
		for (var t=0;t<tiddlers.length;t++) { // for each tiddler
			for (var i=0;i<tiddlers[t].tags.length;i++) { // for each tag in tiddler
				var row=rows.find(tiddlers[t].tags[i]); if (row==null) continue; // this tag not in rows
				if (!grid[row]) grid[row]=new Array(); // create row as needed
				for (var j=0;j<tiddlers[t].tags.length;j++) {  // for each tag in tiddler
					var col=cols.find(tiddlers[t].tags[j]); if (col==null) continue; // this tag not in columns
					if (!grid[row][col]) grid[row][col]=new Array(); // create cell
					grid[row][col].push("[["+tiddlers[t].title+"]]"); // add tiddler title to cell
					if (max<grid[row][col].length) max=grid[row][col].length; // check for new maximum
				}
			}
		}

		// compute gradient color map
		if (startcolor && endcolor) {
			var digits="0123456789ABCDEF";
			function hexToDec(s) // 2-digit conversion
				{ return digits.indexOf(s.substr(0,1).toUpperCase())*16+digits.indexOf(s.substr(1,1).toUpperCase()); }
			function decToHex(d) // 2-digit conversion
				{ return digits.substr(Math.floor(d/16),1)+digits.substr(d%16,1); }
			var steps=max;
			var startR=hexToDec(startcolor.substr(0,2));
			var startG=hexToDec(startcolor.substr(2,2));
			var startB=hexToDec(startcolor.substr(4,2));
			var endR=hexToDec(endcolor.substr(0,2));
			var endG=hexToDec(endcolor.substr(2,2));
			var endB=hexToDec(endcolor.substr(4,2));
			var rangeR=endR-startR;
			var rangeG=endG-startG;
			var rangeB=endB-startB;
			var stepR=rangeR/steps; if (stepR>0) stepR=Math.floor(stepR); else stepR=Math.ceil(stepR);
			var stepG=rangeG/steps; if (stepG>0) stepG=Math.floor(stepG); else stepG=Math.ceil(stepG);
			var stepB=rangeB/steps; if (stepB>0) stepB=Math.floor(stepB); else stepB=Math.ceil(stepB);
			var colors=[];
			colors[0]=startcolor;
			for (var i=1; i<steps; i++)
				colors[i]=decToHex(startR+stepR*i)+decToHex(startG+stepG*i)+decToHex(startB+stepB*i);
			colors[steps-1]=endcolor; // fixup for roundoff error
		}

		// generate HTML table containing popups (and optional inline links)
		var time2=new Date();
		var out="<html><table cellpadding='0' cellspacing='0' style='border:0;border-collapse:collapse'>";
		// column headings
		out+="<tr style='border:0;'><td style='text-align:right;border:0'>";
		out+="<a href='' style='font-size:80%;'";
		out+="	title='show all column headings'";
		out+="	onclick='return config.macros.tagGrid.toggleAllColumns(this,event,"+defOpen+")'>"+(defOpen?"&lt;&lt;&lt;":"&gt;&gt;&gt;")+"</a>";
		out+="</td>";
		for (var i=0;i<cols.length;i++) {
			out+="<td style='text-align:center;cursor:pointer;border:0;padding-left:2px;padding-right:2px' ";
			out+="	title='show/hide column heading' ";
			out+="	onclick='return config.macros.tagGrid.toggleColumn(this,event)'>";
			out+="<a href='' title='open tag tiddler'";
			if (!defOpen) out+="	style='display:none' ";
			out+="	onclick='story.displayTiddler(this,\""+cols[i]+"\");return false'>"+cols[i]+"</a>";
			out+="</td>";
		}
		out+="</tr>";
		for (var i=0;i<rows.length;i++) {
			// row heading
			var rowlink="<a href='' onclick='story.displayTiddler(this,\""+rows[i]+"\");return false'>"+rows[i]+"</a>";
			out +="<tr style='border:0'>";
			out +="<td style='text-align:right;border:0;padding-right:2px'>"+rowlink+"</td>";
			for (var j=0;j<cols.length;j++) {
				var content="";
				var bgcolor="transparent"; // default empty cell background
				if (colors && colorAll) bgcolor="#"+colors[0]; // empty cell background uses startcolor 
				var bordercolor=""; // default border color (inherits current CSS value)
				if (colors) bordercolor="#"+colors[Math.floor(colors.length/2-1)]; // border uses mid-tone color 
				var linkstyle=""; // use default unless background color is very light or very dark
				var cross=(grid[i]&&grid[i][j])?grid[i][j]:null;
				var hdr=rows[i]+(rows[i]!=cols[j]?(" + "+cols[j]):"");
				if (cross) {
					// cross-tagged list of tiddlers (in a popup)
					var label="<b>"+cross.length+"</b>";
					var tip=hdr;
					var list=cross.sort().join(' ').replace(/'/g,"\\'").replace(/"/g,'&quot;');
					var handler="return config.macros.tagGrid.popup(this,event,\'"+rows[i]+"\',\'"+cols[j]+"\',\'"+list+"\')";
					if (colors) {
						var c=colors[cross.length-1];
						bgcolor="#"+c;
						linkstyle="style='color:#000000 !important'";
						// invert link color if background is very light
						if (c.substr(0,2)<"60" || c.substr(2,2)<"60" || c.substr(4,2)<"60")
							linkstyle="style='color:#FFFFFF !important'";
					}
				} else {
					var label="&nbsp;-&nbsp;";
					var tip="create a new tiddler tagged with: "+hdr;
					var list="";
					var handler="var title=config.macros.newTiddler.title;";
					handler+="story.displayTiddler(this,title,DEFAULT_EDIT_TEMPLATE);";
					handler+="story.setTiddlerTag(title,\'"+rows[i]+"\',+1);";
					handler+="story.setTiddlerTag(title,\'"+cols[j]+"\',+1);";
					handler+="story.focusTiddler(title,\'text\');return(false);";
				}
				if (!showInline || !cross)
					content+='<a href="javascript:;" '+linkstyle+' onclick="'+handler+'" title="'+tip+'">'+label+'</a>';
				if (showInline && cross) {
					content+="<div "+linkstyle+"><span style='white-space:nowrap'>";
					content+=hdr+" ("+label+")";
					content+="</span></div><hr>";
					// list tiddler links inline in table cell
					for (t=0; t<cross.length; t++) {
						var title=cross[t].replace(/\[\[/g,'').replace(/\]\]/g,'');
						var handler="story.displayTiddler(null,'"+title+"');return false;"
						var tid=store.getTiddler(title);
						var author=tid.modifier;
						var date=tid.modified.toLocaleString();
						var tip=config.messages.tiddlerLinkTooltip.format([title,author,date]);
						if (t>0) content+="<br>";
						content+='<a href="javascript:;" '+linkstyle+' onclick="'+handler+'" title="'+tip+'">'+title+'</a>';
					}
					content+="<hr>";
					handler="var tids=\'"+list+"\'.readBracketedList();story.displayTiddlers(this,tids); return(false);"
					tip="display all tiddlers tagged with: "+hdr;
					content+='<a href="javascript:;" '+linkstyle+' onclick="'+handler+'" title="'+tip+'">open all...</a><br>';
					handler="var title=config.macros.newTiddler.title;";
					handler+="story.displayTiddler(this,title,DEFAULT_EDIT_TEMPLATE);";
					handler+="story.setTiddlerTag(title,\'"+rows[i]+"\',+1);";
					handler+="story.setTiddlerTag(title,\'"+cols[j]+"\',+1);";
					handler+="story.focusTiddler(title,'text'); return(false);"
					tip="create a new tiddler tagged with: "+hdr;
					content+='<a href="javascript:;" '+linkstyle+' onclick="'+handler+'" title="'+tip+'">new tiddler...</a>';
				}
				out+="<td style='background-color:"+bgcolor+";border:1px solid "+bordercolor+" !important;text-align:center'>"+content+"</td>";
			}
			out+="</tr>";
		}
		out+="</table>";
		out+="</html>";
		createTiddlyElement(place,"span").innerHTML=out;
		var time3=new Date();
		if (this.verbose) displayMessage("TagGrid: scan="+(time2-time1)+", generate table="+(time3-time2));
	},
	popup:
	function(here,event,row,col,list) {
		var tids=list.replace(/&quot;/g,'"').readBracketedList();
		var hdr=row+(row!=col?(" AND "+col):"");
		if (tids.length) {
			var p=Popup.create(here); if (!p) return;
			createTiddlyText(p,hdr);
			createTiddlyElement(p,'hr');
			for(var t=0; t<tids.length; t++) createTiddlyLink(createTiddlyElement(p,'li'),tids[t],true);
			createTiddlyElement(p,'hr');
			createTiddlyButton(createTiddlyElement(p,'li'),
				"open all...", "display all tiddlers tagged with: "+hdr,
				function(){story.displayTiddlers(null,tids); return(false);});
			var a=createTiddlyButton(createTiddlyElement(p,'li'),
				"new tiddler...", "create a new tiddler tagged with: "+hdr,
				function(){
					var title=config.macros.newTiddler.title;
					story.displayTiddler(this,title,DEFAULT_EDIT_TEMPLATE);
					story.setTiddlerTag(title,this.getAttribute("rowtag"),+1);
					story.setTiddlerTag(title,this.getAttribute("coltag"),+1);
					story.focusTiddler(title,"text");
					return(false);
				});
			a.setAttribute("rowtag",row);
			a.setAttribute("coltag",col);
			Popup.show(p,false);
		}
		event.cancelBubble = true;
		if (event.stopPropagation) event.stopPropagation();
		return(false);
	},
	toggleAllColumns:
	function(here,event,defOpen) {
		if (here.expanded==undefined) here.expanded=defOpen;
		var ex=here.expanded=!here.expanded; 
		here.innerHTML=ex?"&lt;&lt;&lt;":"&gt;&gt;&gt;";
		here.title=ex?'hide all column headings':'show all column headings';
		var cells=here.parentNode.parentNode.getElementsByTagName("td");
		for (i=1; i<cells.length; i++) cells[i].firstChild.style.display=ex?"inline":"none";
		event.cancelBubble = true;
		if (event.stopPropagation) event.stopPropagation();
		return(false);
	},
	toggleColumn:
	function(here,event) {
		here.firstChild.style.display=(here.firstChild.style.display=="none")?"inline":"none";
		event.cancelBubble = true;
		if (event.stopPropagation) event.stopPropagation();
		return(false);
	}
};
//}}}
>Takes are handled like other objects within the Timeline mode. (See [[Timeline Mode]])

Takes are references to multimedia files or special objects (visuals, titles, etc...) and in clude the additional characteristics an object may possess:
*Start Point
*End Point
*Fades
*Effects Editing
*Effect Curves

Takes can be used for the following applications:
+++[1. ]
1.Divide your video into takes while loading into the arranger.  
1.1Begin by pressing the {{{Expl}}} button.

The Play/Rewind/Rewind/FF/ transport functions are now active for the selected function video file within the Media Pool.  The Extras button allows you to set the In and Out points for the scene.  The selected scene can subsequently be saved into the [[Takes Directory]].

''Set In/Out Point'' //I/O Keys//:
Determine the start and end of a take.

''Go to In/Out Point'' //Shift+I/Shift+O Keys//:
Skip quickly to the start/end of the take.

''Jump Between In/Out Points'' //Ctrl+K)://
Checkout the scene!

''Save Take'' //Shift+T//: 
The scene is saved to the [[Takes Directory]]
===<br/>
+++[2.]
All scenes found by the automatic scene recognition function can be stored in the [[Takes Directory]], enabling quick assembly of scenes.
===<br/>
+++[3.]
The [[Takes Directory]] may be used to as either a source or destination directory.  Use the [[Takes Directory]] to build complex storyboards:

You can place takes from the directory into the arranger, or drag new scenes into the [[Takes Directory]] - allowing you to build compolex storyboards along the way:

Individual scenes that make up the video are cut first, before being arranged on the tracks.
===<br/>
+++[4.]
Since Takes also contain corresponding effects, one can store different variations of the same movie with differnt effects in the [[Takes directory]].  The [[Takes directory]] uses very little memory in contrast to rendering out the actual video files!
===<br/>
>Today I'm trying to figure out the mysterious inner-workings of the tiddlywiki function [[wikifyStatic|http://trac.tiddlywiki.org/browser/Trunk/core/js/Wikifier.js]]

Typing in the following function call into a Javascript console (with the tiddlywiki code loaded):
{{{
var result = wikifyStatic("plain ''bold'' __underline__ //italic//");
}}}

>Yields the following value in the result variable:
{{{
plain <strong>bold</strong> <u>underline</u> <em>italic</em>
}}}

>Now the big question on my mind is how did we get here?

For this I'm going to peer into the tiddlywiki source code...

*''wikifyStatic [Wikifier.js] (Dependencies)''
**createTiddlyElement
**Tiddler Class [Tiddler.js] (Dependencies)
**Wikifier Class [Wikifier.js] (Dependencies)
***Formatter Class [Formatter.js] (Dependencies)
****createTiddlyText() [???.js]
**** [FormatterHelpers.js]

>Still thinking on this one....
{{{filename.js}}}
| ![[Responsibility|Responsibility CRC]] | ![[Collaborators|Collaborators CRC]] |
|Stores operands, opcode, result.<br/>Performs arithmetic operations<br/>|[[Calculator|Calculator Class]]  |
|Carries out control operations.<br/>Produces quantity stored.<br/>Reports Error.|[[DerivedEngines|Derived Engines Calculator Class]]|
''Definition:''
>A special kind of parameter that can be used to pass a type as an argument.

{{{template <class identifier> function_declaration;}}}
{{{template <typename identifier> function_declaration; }}}

The only difference between both prototypes is the use of either the keyword {{{class}}} or the keyword {{{typename}}}.  Its use is indistinct, since both expressions have exactly the same meaning and behave exactly the same way.
|!Date |! Score |
| [[2/22/2008|22 February 2008]] | 76% |
| [[2/22/2008|22 February 2008]] | 82% |
| [[2/22/2008|22 February 2008]] | 94% |
Testing Halo Scan Trackbacks

''Backtracks''
http://leeand00.wordpress.com/2008/04/23/c-psaccades-13/trackback/
>''Update:'' This is not real transaction processing.  Locking the tables only emulates real transaction processing.  But for small apps it's probably [[good enough|http://stackoverflow.com/questions/804740/testing-for-concurrency-and-or-transactional-integrity-in-a-web-application-with/805187#805187]].

Alright, my tests with JMeter confirm that the table locking worked (I think...)

All the code is contained in [[this zip file|http://drop.io/leeand00/asset/jmeterphptest-zip]].

First I cleared out all of the data from the database using a DELETE FROM query.

There were two data input csv files: 
|! {{{al_csv.cvs}}} - Data for the AL user |!  {{{bl_csv.cvs}}} - Data for the BL user |
| [img[http://i9.photobucket.com/albums/a58/Maskkkk/AL_CSV_Data.png]] | [img[http://i9.photobucket.com/albums/a58/Maskkkk/BL_CSV_Data.png]] |

Each file has seven records within it for it's specified user.

[img[http://i9.photobucket.com/albums/a58/Maskkkk/JMeterCSVSetup.png]]

In JMeter I ran 7 threads each for a dataset of 7 records each (stored in csv files) against the php/mysql code.

[img[http://i9.photobucket.com/albums/a58/Maskkkk/JMeterHTTPRequest.png]]

Then after the tests ran in JMETER I checked the data in the database for both users using the following query where :username is either the username 'AL' or the username 'BL' :

{{{
"SELECT xwu.xwu_username AS usr_name, far.`far_receipt_form` AS rof, far.`far_purge_pre_revisions_clinician` AS pprc, far.`far_purge_pre_revisions_office` AS ppro, far.`far_purge_all_forms` AS paf, far.`far_inserting_new_forms_into_peb` AS infoeb, far.`far_edu_staff_revise` AS esrf, far.`far_edu_staff_revise_date` AS esrf_date
FROM `XebraWebUser` xwu
INNER JOIN `FormAckResponse` far ON xwu.xwu_id = far.xwu_id
WHERE xwu.xwu_username = ':username'"
}}}

|! AL Data  |! BL Data  |
| [img[http://i9.photobucket.com/albums/a58/Maskkkk/AL_Query_Result.png]] | [img[http://i9.photobucket.com/albums/a58/Maskkkk/BL_Query_Result.png]] |

The results that came back from the database perfectly matched the csv files proving that the {{{TABLE LOCKING}}} worked!!!! 

I think so anyway...comments?
!Obituary 
[<img[http://i9.photobucket.com/albums/a58/Maskkkk/PostumsPassing.jpg]]
Today I am in mourning for the death of a 135 year old coffee substitute.   Yes Postum (maybe your grandfather drank it...mine did) has been taken off the market.  I only got to drink one jar of this stuff, it was a powdery brown substance with a consistency similar to Foldger's Crystals.   Since my recent falling out with caffeinated coffee, I needed some where to turn; Postum was my new drink, but alas it died and will be buried in the pages of Coffee Substitute history. Postum is succeeded by it's many drinkers, mostly in the Nevada/Utah areas; and it is noted by CVS News that many of them are suffering from post-postum depression.


!Funeral Services
*Services in morning of Postum will be held at any Mormon or 7th Day Adventist Churches in America.
*Services will also be held in the [[Yahoo Postum Users Group|http://health.groups.yahoo.com/group/Postum/]] and at the [[Facebook Postum Group|http://www.facebook.com/group.php?gid=2432843523]]
*Last jars and regards will be held on [[Ebay|http://www.ebay.com]] for the next few days.  The last jars of Postum will be sold in groups of 3 for between $65 and $175 dollars.
Yup, it appears that the mouse is just too fast to do/stop a fade-in each time a new item is moused over.  I just tired to do that and I found that it caused the other images that were hidden to display for a few seconds.  

So instead I set it up so that the fade in only occurs when the pictures are fading in and out.  When the mouse event fires to change the display, 
''Definition:''
>The tiddler that provides the over-all structure of the tiddlywiki application (html) and contains references to other tiddlers.
Well that was *ahem* interesting...

So I'm using Firefox, and I'm doing a bit of heavy wikiing for my new internship, when I decided that all of these actions are getting to repetitive and that it's time to automate.  I decided to use PhraseExpress (a Text Expander) to automate some of the shortcuts to and make everything go faster.  Well...all is going well, I've got a keyboard shortcut setup and I go to move the cursor from the TiddlyWiki Title field to the tags field, when low and behold I get stuck in the content of the text area leaving nothing but a tab there.  The tab I expected to move the cursor from the content field on to the tab field.  

So trying to figure out what was going on I turned to the Add-Ons one of which is tabinta, thinking that maybe it did something to my tab key.  Nope...no such luck, I closed all my Tiddlers, and nothing. Nothing.  That wasn't the problem.  

So I went to another website to check what happens when pressing the good old reliable shift+tab and tab for moving between fields with a textarea present and it worked as expected there, I could move from one to another with ease.  

So then a thought crossed my mind...maybe the problem was in Tiddlywiki...//and it was!//  The problem was solved by taking a visit to the shadowed [[AdvancedOptions]] tiddler and unchecking the box marked {{{Use the tab key to insert tab characters instead of moving between fields}}} or {{{chkInsertTabs}}} for short (although you won't find it in this old Tiddlyspot blog because it's not not there!)
Recently, I was writing a database for my recent internship at [[IDP|http://www.idpcreative.com/]].  The requirements for the database at the time were just to analyze the many options we had recently been give when selecting a [[Digital Edition Solution Provider|http://english.stackexchange.com/questions/69416/what-is-an-overall-term-for-a-service-that-publishes-digital-publications]] A [[Digital Edition Solution Provider|http://english.stackexchange.com/questions/69416/what-is-an-overall-term-for-a-service-that-publishes-digital-publications]] or a (DESP as I have been calling them),  is one of those massive cloud services that a publisher will use to push a pdf of their publication to a bunch of Android, Kindle and iOS devices for sale on their digital newsstands.  These [[DESPs|http://english.stackexchange.com/questions/69416/what-is-an-overall-term-for-a-service-that-publishes-digital-publications]] also allow you to add features such as audio, video, auto-linking, html5 ads and interactive features, and occasionally will additionally publish a mobile and desktop website as well.  This is scary as hell if you're a web developer like I have been for most of my career since a DESP is like a CMS that somebody injected with steroids, so that even somebody with the technical know how of the equivalent batting average of a team like the Cubs would be able to hit a content home run out of the park and break several windows outside the stadium...but I digress.  The main point I'm trying to make here is that these DESP systems are very, very new, and very very packed with features; however if I may plug for the web developers here, the only thing they are more full of than features is hidden fees, for every tiny bell and whistle you want to add to your page (well most of them are like that...); but anyway that's how I got started doing this database research project in the first place.  But that isn't the point of this post.  The point is that I learned something interesting about SQL (maybe a bit too late for this project, but there's always another one...) and this was the usefulness of SQLs INSERT-IN-SELECT Syntax and SQLs UPDATE-IN-SELECT statements when dealing with weak-entity relationships (i.e. the table that sits on the many end of two 1 to M relationships).  

Strangely these useful statements were never covered in the database class I took in college, but they sure are useful (to be fair we did cover the nested SELECT-IN-SELECT statenent however).  

While adding the feature portion of this database in which there was a many-to-many relation between the DESP table and the Features table, I came upon a problem:

[img[http://i9.photobucket.com/albums/a58/Maskkkk/2012-06-07_16-21-07.png]]

Everytime I read through some new piece of marketing about a DESP and found out it could do X, I had to add (at most) three new records in three different tables to the database:
#If it didn't exist already I would have to add a new record to the {{{DigitalEditionsSolutionProvider}}} table to represent the solution.
#Next, (provided the feature did not already have a record) I would add a new record to the {{{Features}}} table to represent a new feature we didn't know these babies could support.
#And this being a M-to-M relationship, the weak-entity between these two tables with no primary key of it's own the {{{DESP_Features_Weak}}} table, would get a record to connect the aforementioned two tables.  
**This weak-entity would also get a foreign key ({{{fk_dfws_id}}}) to a state table ({{{DESP_Features_Weak_State}}}) to store a record state that would specify:
***...that I didn't yet ask the sales rep if the particular DESP supported the feature yet...
***...that the the particular DESP does/doesn't or will eventually support the feature...

So this covers the cases in which we add a a new DESP or a new Feature, but what happens when we have just added a record to either side of the M-to-M and there is no record between them yet to specify if I have even asked the sales rep about that feature yet?  The relationship just isn't there between the tables...and my believe is that if we don't want to leave anybody out in the cold and have to use an OUTTER JOIN to find the missing features when we do a full comparsion using queries later, we have to find a way to create the missing records everytime we add a new record to either the {{{DigitalEditionSolutionProvider}}} or the {{{Features}}} table; because of course we want to know if a DESP does, doesn't or will eventually support the features so we can compare and choose one of them using queries.  

Myself being more of a programmer than a database administrator, wrote an entire OpenOffice macro to do just this...although it worked, it wasn't anywhere near as elegant as it would have been to use an [[SQL-INSERT-IN|http://www.databasejournal.com/features/mysql/article.php/3887386/MySQL-INSERT-Statement-Variations.htm]] to make this happen.  Using an [[SQL-INSERT-IN|http://www.databasejournal.com/features/mysql/article.php/3887386/MySQL-INSERT-Statement-Variations.htm]], could have saved me alot of trouble and a day or so of thought, failure, and debugging.  I realize this now...but I sure wish I would have thought to google the words INSERT-IN and UPDATE-IN earlier, as it would have been a much easier statement to write, and combined with a STORED PROCEDURE, could have made adding a new {{{DigitalEditionsSolutionProvider}}}, or {{{Features}}} record much more simple, elegant and compact.  But what can I tell you...I've spent most of my career on the front-end doing Javascript or working in MVC Frameworks, so some of this is just starting to rear it's elegant head to me.

!Tools and Techniques

A file that helps refresh one's memory each week with the outstanding tasks and projects.

One device that Allen suggests is the 
''Ticker File'' for organizing paperwork (also known as ''The 43 Folders'').  

Twelve folders are used to represent each month and an additional 31 folders are used to represent each day.  The folders are arranged to help remind the user of activities to be done by that day.
[[Story]]
>This is just an article that I am reading, __I did not write it!__
[[article link|http://softwareas.com/tiddlywiki-internals-1-of-3-architectural-concepts]]
!Overview
A Tiddlywiki is a collection of "tiddlers", small blocks of content typically a paragraph or so in length.  At any time, a subset of these tiddlers is displayed in the UI (between zero and the total number of stored tiddlers).

A special property of Tiddlywiki is that the entire application resides in a single HTML/Javascript/CSS file (it's the quintessential SPA [[Single Page Application|http://softwareas.com/code.google.com/p/trimpath/wiki/SinglePageApplications]].)  This is why you can save a Tiddlywiki locally and run it off a file:// URL and stick it on your iPod or novelty hamburger USB stick.

In the file, all the tiddlers are stored inside invisible DIVs, which are read on startup into a TiddlyWiki data structure.  When you invoke the save feature, for example by hitting the //"Save Changes"// control, the invisible DIVs are refreshed with the latest content from memory, and the entire file is written out to the hard drive.

TiddlyWiki is much more than a specialised wiki - due to its flexible architecture and the possibility of plugins, it is more like a platform.  [[Examples of apps built on TiddlyWiki|http://osmosoft.com/#Products]].

[[TiddlyWeb|http://www.tiddlywiki.org/wiki/TiddlyWeb]] though not discussed specifically here, marks an important step in the future of TiddlyWiki development.  It's a RESTful server of Tiddlers, which would allow for great flexibility in the kinds of UIs you end up with, as well as allowing non-UI clients.

!Anatomy of a Tiddlywiki
The image below shows an Tiddlywiki in editable mode.  As for the UI, you can see it consists a main area with two sidebars.  The main area is a [[Story]] - a story is a sequence of visible tiddlers.  

[img[http://img.skitch.com/20080811-kkjw7cg9brkrigncj4epec43gx.jpg]]

A lot of this is configurable by changing special tiddlers.  In particular, the tiddler called [[PageTemplate|The PageTemplate Tiddler]] provides the overall structure, with references to other tiddlers, and [[Stylesheet|Stylesheet Tiddler]] the CSS styles.

!Object-Oriented Concepts in Tiddlywiki
There are may ways to deal with classes, objects, and prototypes in JS - see [[Javascript:The Good Parts|http://www.amazon.com/JavaScript-Good-Parts-Douglas-Crockford/dp/0596517742/ref=pd_sim_b_1/102-7069230-4404147]] by Doug Crockford and [[Pro Javascript Design Patterns|http://www.amazon.com/JavaScript-Design-Patterns-Recipes-Problem-Solution/dp/159059908X]] by Ross Harmes and Dustin Diaz.

Tiddlywiki's OO relies on the constructor function pattern, where you create new objects using the {{{new}}} keyword.

{{{
var tiddler = new Tiddler();
}}}
''Example Constructor Function Pattern in Javascript.''

In JS, {{{new Fn()}}} will magically does a couple of things that let us use the familiar (from C++, Java, etc) idiom above.  It sparks the creation of a blank object, then it conducts a special execution of {{{Fn()}}} in which {{{this}}} is superfrajalistically tied to the new-born object.  This leads us to an idiom that is both called and implemented as if it were, for the most part, a constructor in OO languages like C++ and Java.  The {{{Tiddler}}} construction function is defined as follows:

{{{
function Tiddler(title)
{
    this.title = title;
    this.text = "";
   ...
   return this;
}
}}}

In addition, the new Tiddler has a number of standard Tiddler methods associated with it, so I can call them in typical OO fashion, e.g. {{{tiddler.isTagged("happy")}}}.  The implementations refer to the specific instance using the {{{this}}} keyword.  In Javascript, this can easily be achieved via prototypes.  Therefore, subsequent to the constructor definition, we encounter in Tiddler.js a menagerie of method definitions like:

{{{
Tiddler.prototype.isTagged = function(tag)
{
     return this.tags.indexOf(tag) != -1;
}
}}}

All of the attributes above are public, but Tiddlywiki also uses closures to ensure some attributes are only available externally via declared methods.  For example, the tiddlers of a Tiddlywiki is declared as a local variable, so there's no direct reference to it outside the methods declared in the same scope.

{{{
function TiddlyWiki()
{
    var tiddlers = {} // Hashmap by name of tiddlers
    this.tiddlersUpdated = false;
    ...

    this.fetchTiddler = function(title) {
       var t = tiddlers[title];
       return t instanceof Tiddler ? t : null;
    };
}
}}}
''Fetching a tiddler''


The above methods will also be available on each instance created with {{{new}}}, just as with those declared using the prototype assignment.  They are used in exactly the same way.

The only difference is that all these functions are re-created with each new instance, so they will consume more memory.  That's the price we pay for the encapsulation.

You will also find static methods present (i.e. global functions attached to a constructor purely for the same of namespacing them) For example:
{{{
TiddlyWiki.isStandardField = function(name) 
{
    return TiddlyWiki.standardFieldAccess[name] != undefined;
}
}}}
''Sample static method''

Typically, a class will be contained in a single, dedicated, Javascript file (within the source code from which a Tiddlywiki is built).  However, the previous example was actually contained in [[TiddlerFields.js]] rather than [[TiddlyWiki.js]], so it seems that class definitions may be distributed across multiple files in some limited cases.

And that's how Tiddlywiki handles basic OO.

You'll also see some parts of TiddlyWiki enhancing built-in Javascript types by extending their prototype - for example, [[BasicTypes.js]] endows all Arrays with a contains method, and [[Dates.js]] sticks a {{{getAmPm()}}} method onto each Date that's created.  Number, Array, and Date receive a dozen or so new methods.

Last but not least, there's also a healthy does of inheritance in Tiddlywiki. JS inheritance is a whole new can of worms.  We see an example in AdaptorBase, which serves as the base class for server adaptor subclasses.  AdaptorBase looks very normal, like Tiddler above.  FileAdaptor, a subclass, looks like this:
{{{
   function FileAdaptor() {

   }

  FileAdaptor.prototype = new AdaptorBase();
}}}
''Inheritance in Tiddlywiki''

Basically, JS has a concept of protoype chains.  The assignment means that any instance of FileAdaptor will now have all methods present in a new instance of AdaptorBase.  FileAdaptor goes on to define its own methods, using the standard prototype pattern.  If so inclined, it can override AdaptorBase's methods by defining them on its own prototype method.  (This is why we say {{{new AdaptorBase()}}} - if we had assigned {{{FileAdaptor.prototype}}} to {{{AdaptorBase.prototype}}}, anything we set on FileAdaptor would also be set on AdaptorBase.

!URL Arguments
Tiddlywiki uses the fragment identifier patter ([[described here|http://ajaxpatterns.org/Unique_URLs]]) to provide flexible loading strategies.  

Normally, the //DefaultTiddlers// are shown on startup.  However, this can be overridden via URL params.  For example, use http://www.tiddlywiki.com/#Examples to load with jsut the Examples tiddler showing.  Or, for multiple tiddlers, just separate with a space (%20 in URL 5peak)  http://www.tiddlywiki.com/#Examples%20Plugins. (An interesting possibility would be for Tiddlywiki to keep updating the URL to ensure its sync'd with the state of the app, so you could bookmark it at anytime to save that configuration.)

But maybe you don't want to manually list all the tiddlers - instead, you might want to show all tiddlers matching some criteria.  Then you'd want an automated mechanism for auto-selecting theose criteria (think iTunes Smart Playlist for dramatic effect.)  This would make the URL shorter, easier to understand the true purpose of the configuration, and future-proof it against any changes to the set of tiddlers we're interested in.

In Tiddlywiki, that mechanism is achieved with a URL "filter" prefix.  For example, show all tiddlers with "systemConfig" tag - 

{{{
http://tiddlywiki.com/#filter:[tag[systemConfig]]
}}}
''URL string to open all the tiddler's tagged systemConfig''

Other things you can do - 
{{{
http://tiddlywiki.com/#newTiddler:tiddlername
}}}
''Create a new Tiddler named tiddlername'' on startup.

The URL is modelled as a map, i.e. key-value pairs.  In the case of 

{{{
http://www.tiddlywiki.com/#Examples%20Plugins
}}},
that's just an alias for the cononical map form, 

{{{
http://www.tiddlywiki.com/#open:Examples%20open:Plugins
}}}
All this is managed by the [[Paramifiers|Paramifiers Class]] class.
[[article link|http://softwareas.com/tiddlywiki-internals-2-of-3-list-of-javascript-files]]

>Continuing the series, below is a list of all core JS files, organized into functional groups

+++[+Initialization]
*{{{main.js}}} - Runs the initialization sequence.
*{{{Paramifiers.js}}} - Handles URL params.
===<br/>
+++[+Generic (non-animation)]
*{{{BasicTypes.js}}} - Augments built-in Javascript Number and Array.
*{{{Crypto.js}}} - Crypto functions (Tiddlers can generate fingerprints)
*{{{Dates.js}}} - Augments built-in Javascript Date class.
*{{{Dom.js}}} - Supports DOM manipulations.
*{{{FileSystem.js}}}
*{{{Strings.js}}} - Augments built-in Javascript Number and Array.
*{{{Http.js}}} - Supports XmlHttpRequest based remoting.
*{{{RGB.js}}} - CSS color manipulation.
===<br/>
+++[+Generic (Specifically Animation )]
>See also [[(2005) TiddlyWiki animation write-up|http://ajaxpatterns.org/One-Second_Mutation#TiddlyWiki_2]]
*{{{Animator.js}}} - Runs the dynamic flow of stepping through an animation, delegating to specific strategies.
*{{{Morpher.js}}} - Morphin animation strategy.  Cool - smoothly animates between two CSS styles.
*{{{Scroller.js}}} - Scroller animation strategy.  Scrolls window to show an element. <br/>(The way the page smoothly scrolls to show a tiddler when you click its link.)
*{{{Slider.js}}} - Slider animation strategy.  Slides elements opening and closed.<br/>(e.g. Closing tiddlers or the Options box on right sidebar.).
*{{{Zoomer.js}}} - Zoomer animation strategy<br/>(the way a tiddler "jumps out" from it's link).
===<br/>
+++[+Tiddlywiki-Specific Utilities]
*{{{FormatterHelpers.js}}} - Utilities specifically for Formatters.
*{{{Refresh.js}}} - Mechanism for notifying and updating elements based on changes, e.g. if stylesheet shadow tiddler is updated.
*{{{Utilities.js}}} - Miscellaneous TiddlyWiki-specific utility functions.
===<br/>
+++[+Data Structures]
*{{{Tiddler.js}}} - Data structure representing a tiddler, i.e. a block of text with a title.
*{{{TiddlerFields.js}}} - Augments TiddlyWiki to manage tiddler fields.
*{{{TiddlyWiki.js}}} - Data structure representing a collection of tiddlers.
===<br/>
+++[+Data Import/Export]
*{{{AdaptorBase.js}}} - Adaptors convert from various wiki formats (e.g. Mediawiki) to TiddlyWiki.  This is the base class for Adaptors.
*{{{FileAdaptor.js}}} - Subclass of AdaptorBase which reads the default/standard Tiddlywiki format.
*{{{Import.js}}} - Marco to import tiddlers from another TiddlyWiki.
*{{{LoaderSaver.js}}} - Converts between HTML and a list of tiddlers.<br/>(I think the main purpose is to get a clean HTML list of tiddlers.)
*{{{Saving.js}}} - Saves the Tiddlywiki - main case is serialising everything to DOM elements and saving to local file system.
*{{{SavingRSS.js}}} - Serves Tiddlywiki as RSS format (e.g. Tiddlywiki.com RSS feed) showing time-sorted list of recently updated tiddlers.
*{{{Sync}}} - Syncs
*{{{TW21Loader.js}}} - Standard implementation of LoadBase (defined in LoadSaver.js
*{{{TW21Saver.js}}} - Standard implementation of SaverBase (defined in LoadSaver.js).
===<br/>
+++[+Strategies]
>This is a broad category of options and control-type functions.  The control-type functions are here because they are designed using flexible mechanisms which make them easily overrideable by plugin developers.
*{{{Config.js}}} - General Tiddlywiki config - controls capacities, names of shadow tiddlers, which options can be set, other stuff.
*{{{Commands.js}}} - Handlers for menus and toolbar.
*{{{Macros.js}}} - Defines built-in macros.
*{{{Formatter.js}}} - Formatters are strategies for locating regexp patterns in wiki text (wiki words, image URLs, etc.) and rendering them.
*{{{Options.js}}} - Options are cookie-based preferences.  The user can generally set them directly on the Tiddlywiki UI.  This is in contrast to Config.js settings, which are fixed unless the user cares to dive into the source code.
*{{{Wikifier.js}}}
===<br/>
+++[+UI Elements]
*{{{Backstage.js}}} - The backstage area of the page, with access to advanced features and acting as an escape route after over-enthusiastic bouts of customization.
*{{{ListView.js}}} - A table-like list, e.g. shows all options when you hit {{{Backstage|Tweak}}}.
*{{{Manager.js}}} - Plugin manager (accessible from {{{Backstage|Plugins}}}.
*{{{Messages.js}}} - Simple status notifications.
*{{{NewTiddler.js}}} - Macro for a new tiddler, e.g. when user hits "New Tiddler" menu option, and also "New Journal".
*{{{Popup.js}}} - Popup menu (e.g. when you click the name of a tiddler in the list of shadow tiddlers.)
*{{{Search.js}}} - Search implementation - allows user to search for a term.
*{{{Sparkline.js}}} - Generates CSS based [[sparkline|http://softwareas.com/en.wikipedia.org/wiki/Sparkline]] graphic.
*{{{Story.js}}}  - Manages the container of all visible UI elements.
*{{{Tabs.js}}} - A UI element for handling tabs.
*{{{Toolbar.js}}} - The toolbars shown at the top of a tiddler (with "close", "close others" etc controls - or "done"-"cancel"-"delete" if open).
*{{{Wizard.js}}} - Multi-step wizard UI framework.
===<br/>
+++[+Miscellaneous]
*{{{Deprecated.js}}} - Deprecated functions.
*{{{Guide.js}}} - A short readme file.
*{{{Lingo.js}}} - Internationalization-localization support - contains string keys and their English values.
*{{{Upgrade.js}}} - Support for upgrading Tiddlywiki version.
*{{{Version.js}}} - Short file with info about his version of TiddlyWiki.
===<br/>
>Concluding this series, below is a list of all core Javascript files, organized into functional groups.

!main.js
>{{{main()}}} is the function that runs onload.

!!Key functions:
*creates a new tiddlywiki data store (new TiddlyWiki()) - this is the collection of tiddlers users are exposed to.  The store is populated using TiddlyWiki.prototype.loadFormDiv(), which loads all the tiddlers from the "storeArea" div, which is an invisible lock on the page (and rendered back in an nice and visible manner later on).
*Creates a second TiddlyWiki data store to hold "shadow tiddlers" - these are the meta/config tiddlers holding data such as CSS styling.  Populated from invisible "shadowArea" div (which at compile time is defined in the Shadow/directory).
*Creates a new "Story div", a div which will show tiddlers to the user, and themes it according to {{{config.options.txtTheme}}}
*sets up {{{Popup.onDocumentClick}}} (removes popup menus when user clicks outside of the menu).
*Sets up event propagation - certain tiddlers are notified when certain actions occur.  The mappings are defined in {{{Refresh.js}}} (e.g. {{{{name:"StyleSheetLayout", notify:refreshStyles}}}})
*Sets up and renders backstage
*Loads plugins (plugins are evidently supposed to get a global ''plugin problem'' value if a problem occurs.

!!General
*Calls several lifecycle event handlers as it loads - the wiki config can provide hook functions which run upon particular lifetime events.
*Benchmarks most of the above (the benchmarking was possibility a quick fix - relies on variable t1,t2...t10 -> this could be optimised for conciseness using function wrappers, but maybe startup would be too slow that way.)
*After initial setup ensures tiddlywiki data structures and other initialization/config pieces are in place, it blats and shows the display with {{{restart()}}} and {{{refreshDisplays()}}}.

!Plugins

Tiddlywiki has a strong plugin architecture.  Each plugin is included as a regular (non-shadow) tiddler, one that must b e tagged //systemConfig//.  (For all intents and purposes, "system config" is synonymous with "plugin".)  There's an example shipping with the default tiddlywiki instance on tiddlywiki.com (and a more detailed example in the source code - {{{association/plugins/SparklinePlugin/SparklinePlugin.js}}}).  (Also of interest, [[the latest plugin template at the tiddlywiki.org wiki|http://www.tiddlywiki.org/wiki/Plugin_specs#Template]].)  

{{{
<div title="ExamplePlugin" modifier="JeremyRuston" modified="200609212329" tags="systemConfig">
<pre>/***
|''Name:''|ExamplePlugin|
|''Description:''|To demonstrate how to write a TiddlyWiki Plugins|
|''Version:''|2.03|
|''Date:''|Sep 22, 2006|
|''Source:''|http://www.tiddlywiki.com/#ExamplePlugin|
|''Author:''|JeremyRuston (jeremy (at) osmosoft (dot) (com))|
|''License:''|[[BSD open source license]]|
|''~CoreVersion:''|2.1.0|
|''Browser:''|Firefox 1.0.4+; Firefox 1.5; Internet Explorer 6.0|
***/

//{{{

// Uncomment the following line to see how the PluginManager deals with errors in plugins
// deliberateError();

// Log a message
pluginInfo.log.push(&quot;This is a test message from &quot; + tiddler.title);

</pre>
</div>
}}}

A plugin is esentially just a Javascript block which gets executed on page load.  All the biosketch info is optional (although in some cases, it does effect the processing, e.g. there is a check against the requried TiddlyWiki version).  "Just some Javascript" did you say?  [[This post on JQuery plugins|http://ejohn.org/blog/jquery-plugins-size-and-storage/]] by JQuery daddy John Resig is instructive.  His point is that a plugin architecture needs explicit points for plugins to hook into - i.e. an API - and the existance of a plugin catalogue.  Tiddlywiki doesn't have a plugin API //per se//, but it is structured with plenty of extension pointers to naturally hook into.  As for the catalogue, there's also a [[plugin wiki area|http://www.tiddlywiki.org/wiki/Plugins]] with a grander-scale plugin repo project in progress.

Incidentally, note that you don't have to register the Javascript  block as you might do in some other frameworks. (e.g. {{{runOnInit(myPlugin);}}})  It executes automatically when plugins are loaded.

Okay, so about those plugin extension points.  I'm still learning that.  In the case of sparklines, the purpose is to create a new macro (e.g. {{{<<sparkline 100 200 300>>), so it defines 
{{{config.macros.sparkline.handler(place, macroName, params)}}}, and it's "output" is to populate the {{{place}}} element with sparkline content.

Another popular pasttime for plugin developers is szhusing the global Formatter object to shape how stuff gets rendered.  e.g. if your formatter locates the built-in formatter named "heading", it could easily overwrite its handler method to MAKE ALL THE HEADING SHOUT AT UNSUSPECTING READERS.

To install a plugin, users use the import dialog, accessible from Backstage.  It's also possible to manually include plugins via cut-and paste into tiddlywiki.

There's much more to be said about plugins.  The bottom line is that Tiddlywiki's architecture lets you bend the core product into many things.  (By "architecture", I refer to both the plugin mechanism and the flexible nature in which the overall architecure is structured.)

!Tiddlers
Tiddlers are the atomic content blocks that make up a TiddlyWiki, typically about a paragraph in length.  A tiddler is simply a block of text, with extra info like a title, a list of tags, and a time stamp.  There's also a {{{fields}}} hash where you could store any arbitrary properties.  (This seems suitable for plugins, but the core also makes use of it, and I don't really get that.  Even for plugins, why can't they just make new fields dynamically?)

{{{Tiddler}}} is a Javascript class, so you get a new instance with {{{new Tiddler()}}}.  @@Internally, it uses a publish-subscribe mechanism, where a {{{changed()}}} method is called after any mutation.  This basically ensures the {{{links}}} property is up to date, as {{{links}}} is a redundant (and presumably there for performance) collection of links inside the tiddler.@@

A Tiddler also has a collection of "slices", though the collection is managed by {{{TiddlyWiki}}} rather than {{{Tiddler}}} (This relates to the fact that shadow tiddlers are mere text blocks - using TiddlyWiki to extract slices ensures shadow tiddlers can also be sliced up...and slices are a major feature of most shadow tiddlers, since they are config-related.

There's a string->string map from name to slice.  This is similar to the fields has, insofar as it's a free-form map.  In this case, though, it's something that can easily be changed by the user in real time.as the slice collection is sync'd to the tiddler content.  For example: |"slicename:"|"some slice content"|.  Slices allow for easily edited meta-data, e.g. stylesheet tiddler can have a slice called "backgroundColour".  Users then edit the backgroundColor slice content to set the background colour.  

A Tiddler also has a set of notification handlers - this is also managed by TiddlyWiki rather than the Tiddlers themselves. (again, this ensures the mechanism works for shadow tiddlers).  These are listeners/observers that are notified each time a tiddler is changed.

A file closely related to Tiddler is [[TiddlerFields.js]].  It actually alters the TiddlyWiki definition rather than the Tiddler definition, but in any event it deals with accessing the Tiddler's fields map.

!Shadow Tiddlers
Shadow tiddlers are a particular type of tiddler.  There's no separate "ShadowTiddler" class, but they are held in a seprate store and treated in special ways.  Indeed, shadow tiddlers aren't actually of class Tiddler (which is slightly confusing).  They are simly a title-text pairing;  the data structure is a map from title to text.  In contrast, regular tiddlers are mapped from title to Tiddler.

In particular, TiddlyWiki has a fallback mechanism when asked to return a tiddler - if the tiddler didn't exist, it will attempt to revert back to a shadow tiddler of the same name.  Shadow tiddlers are immutable (unless you hack source code), whereas tiddlers are of course easily edited.  You can override shadow tiddlers with regular tiddlers of the same name, but the original shadow still lurks (in a good way) in the background.

To see this, open an editable Tiddlywiki, choose a shadow tiddler from the right sidebar Contents menu (e.g. SiteUrl), edit it, and save it.  Then re-open it to verify your changes were affected.  Then delete it, and notice that it's still in the list of shadow tiddlers.  When you open it again, you'll see it now contains the original content.  (The shadow tiddler itself never changed).

Shadow tiddlers are used for config stuff like stylesheets.  The fail safe mechanism ensures you can easily restore factory defaults at any time.

!TiddlyWiki is essentially a hash of Tiddlers, keyed on their title.  More precisely, it's a wrapper around this hash.  Here's a (slightly refactored) look at the relevent code for managing tiddlers, which looks like any other hash wrapper:

{{{
function TiddlyWiki()
{
   var tiddlers = {}; // Hashmap by name of tiddlers
   ...
   this.clear = function() { tiddlers = {}; };
   this.fetchTiddler = function(title) {return tiddlers[title]; };
   this.deleteTiddler = function(title) { delete tiddlers[title]; };
   this.addTiddler = function(tiddler) { tiddlers[tiddler.title] = tiddler; };
}
}}}

There is also a set of similar methods which wrap around these to provide more intelligent behavior.  e.g. {{{createTiddler()}}} wraps around {{{addTiddler()}}} to provide "Add or retrieve if exists" functionality.  {{{getTiddler()}}} wraps {{{fetchTiddler()}}} to ensure null is returned if no such tiddler exists.  {{{removeTiddler()}}} wraps {{{deleteTiddler()}}} to delete only if the tiddler exists, and also notifies the tiddler's listeners.  Most other methods also do "general stuff" with the tiddlers hash.  A lot of them also run operations on behalf of Tiddlers themselves (this is mostly so it can endow shadow tiddlers - which are just strings - with certain behavior, as metntioned in the previous section.)

!Story
Story is the sovereign UI elemetn in TiddlyWiki - its the container of all visible Tiddlers which you'll usually see occupying the main, middle, column.  Theoretically, there could be more than one Story instance on the apge, but I'm told that there are some hard coding shenanigans that rule it out in the project's current state.  (Specifically, direct references to the "story" instance that main.js creates.)  So Story is a singleton class in practice.

One gotcha here is with the nomenclature - a "tiddler" inside Story.js is conceptually a DOM element, whereas in most other places it is a data structure.  Obviously, the tiddler UI element is a rendering of the tiddler data structure.  @@However, the implementation isn't entirely symmetrical because the data structure has a dedicated class (Tiddler), while the UI element doesn't; tiddler rendering is handled purely by the Story class.@@  In on case ({{{displayTiddler()}}}), either form is valid as the "tiddler" argument, similar to $() functions that accept either the element or the ID ({{{title = (tiddler instanceof Tiddler) ? tiddler.title | tiddler}}}).

Story's key properties are a container ID, which points to the container DOM element, and an idPrefix, the prefix for all tiddler IDs.  The container already exists on the page when a Story object is created to manage it.
!What is Time-line mode?

In the Timeline mode, your movies and scenes are chronologically displayed according to the duration of the file.

The length of an active object in the track reflects by its length in the overall movie project.  Each scene or file is as long as the representative "object(s)" in the track.  Simply use the TAB key to switch to timeline mode.
*==Fix The addresses (bigger font)==
*==Fix the email address as well so that there isn't so much blue on the bottom.==
*==Crop the Pill bottle and put it bellow the "...Then Contact us"==
*==Add the lady that is talking to the Contact us page.==
*Stock Forms and Labels a new link for that...
*Computer Products Wording
*same
<html>
<body>
<a href="http://stackexchange.com/users/ca5b0c1dd62a41bba4972992b4c5efcb"  title="profile for leeand00 on Stack Exchange, a network of free, community-driven Q&A sites">
<div style="text-align: left; width: 165px; height: 58px; background: url('http://stackexchange.com/users/flair/ca5b0c1dd62a41bba4972992b4c5efcb.png');">

</div>
</a>
</body>
</html>
MAGIX Movie Edit Pro II offers 16 tracks for object placement.   In princliple, any object type may be placed on any of the tracks.  Mute a single audio track by clicking on the "Mute" button or play individual tracks separately ("Solo or S") to emphasize a particular scene.
/***
Contains the stuff you need to use Tiddlyspot
Note you must also have UploadPlugin installed
***/
//{{{

// edit this if you are migrating sites or retrofitting an existing TW
config.tiddlyspotSiteId = 'leeand00';

// 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)

// 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(/^/,"[[Welcome to Tiddlyspot]] ");
	MainMenu = MainMenu.replace(/^/,"[[Welcome to Tiddlyspot]] ");
}

// create some shadow tiddler content
merge(config.shadowTiddlers,{

'Welcome to Tiddlyspot':[
 "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?// &nbsp;&nbsp;@@ 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// &nbsp;&nbsp;@@ 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// &nbsp;&nbsp;@@ 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!// &nbsp;&nbsp;@@ Find out more about ~TiddlyWiki at [[TiddlyWiki.com|http://tiddlywiki.com]].  Also visit [[TiddlyWiki Guides|http://tiddlywikiguides.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 :)// &nbsp;&nbsp;@@ 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"),

'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/]], [[announcements|http://announce.tiddlyspot.com/]], [[blog|http://tiddlyspot.com/blog/]], email [[support|mailto:support@tiddlyspot.com]] & [[feedback|mailto:feedback@tiddlyspot.com]], [[donate|http://tiddlyspot.com/?page=donate]]|"
].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"),

'TspotOptions':[
 "tiddlyspot password:",
 "<<option pasUploadPassword>>",
 ""
].join("\n")

});
//}}}
!!!Making sure we don't have to reconfigure this if it moves to a new vm...
Next I make sure that the {{{listen-address=}}} line is  commented it out since
doing so binds it to single address instead of all the addresses.

{{{ 
#listen-address=
}}}
    
Also note that 'interface=' must also be commented out for this to function
correctly, since 'interface=' causes only a single nic to be used by dnsmasq,
and we want to use all of them just incase this VM moves to another machine.

{{{
#interface=
}}}
I'm trying to figureout how to unzip a file from within a C++ program.  For a summary of what questions I'm asking about this so far, please visit:

[[http://delicious.com/leeand00/xetex-unzip|http://delicious.com/leeand00/xetex-unzip]]
<html>
<head>
    <meta content="text/html; charset=ISO-8859-1" http-equiv="Content-Type">
  </head>
<body bgcolor="#FFFFFF" text="#000000">
    If you do a preview of the page in Timeline format, it will display
    all of the likes, posts, and comments (and anything else that you
    and your users have added to the business page).&nbsp; Doing a Preview of Timeline <b>will not </b>
switch your page over to Timeline. <br><br>When you login to the BCL Facebook Business page click the blue "Preview" button (see below):<br>
    <br>
    <img style="max-width: 100%" src="" alt=""><br>
    <br>Once<b> </b>
you enter the preview, <u><i><b>DO NOT</b>
</i>
</u>
<i> </i>
CLICK THE "Publish Now" BUTTON, that will switch your Business page over before it is setup.<br>
    <br>The very top of the "Preview" will display the Admin Panel (which your users will never see see below:&nbsp; <br><br><img src="" alt="" style="max-width:100%"><br><br><br>And if you scroll down on the page below the admin panel, you will see a preview of what the page will look like on the 30th of March when Facebook switches to Timeline View (see below):<br><br><img src="" style="max-width: 100%" alt=""><br><br><br>You'll note in the preview image below that the photos, likes and comments (posts) remain intact within the preview, and you won't have to worry them disappearing when the 30th comes:<br>
    <br>
    <img src="" alt="" style="max-width: 100%"><br><br>Please let me know if you have any more questions about the transition.<br>
    <br>Thank you, <br>&nbsp; Andrew J. Leer<br>
    <br>
</body>
</html>
Okay so the other day I downloaded the update to OpenOffice.org 3.1.0 

The first time I tried it, it didn't work, and then I read in a forum somewhere that if you install all of it, you can make it work.  And so I did.

Now one thing I hadn't anticipated was that the series of StarBasic Macros I've been using on the [[jobdb|http://jobdb.sourceforge.net/]] project weren't going to work after the installation.  

>Okay fine, so I did anticipate it...I use Virtualbox to develop [[jobdb|http://jobdb.sourceforge.net/]], and I took a snapshot of my VM right before I downloaded the update to OOo.  However this really does little to change the fact that people downloading [[jobdb|http://jobdb.sourceforge.net/]] are most likely going to want to use the latest version of OOo.  And I [[already have a job|http://www.xebra.com/]], so I'd like to get it working for them.

Anywho...even though I can revert back to the OOo before the update, I'd still like to press forward with the latest version if OOo.   Upon installing it last night, and opening [[jobdb|http://jobdb.sourceforge.net/]] I was presented with a screen which asked me if I'd like to perform some Macro Migration.  //"Sure!"// I though, believing that maybe the Migration would be a smooth and easy process...and so I clicked //next//, and after a brief progress bar, I received a nice text-based summary of exactly what the Macro Migration had done:

{{{
=== Database Document ===
saved copy to C:\Users\leeand00\Desktop\dev-jobdb\job_db.backup.odb

=== Form 'JobDashBoard' ===
migrated OpenOffice.org Basic library 'Standard' to 'Form_JobDashBoard_Standard'
migrated OpenOffice.org Basic library 'DBLib' to 'Form_JobDashBoard_DBLib'
migrated dialog library 'Standard' to 'Form_JobDashBoard_Standard'
migrated dialog library 'DBLib' to 'Form_JobDashBoard_DBLib'
}}}

And afterwards my modules kinda looked like this:

[img[http://i9.photobucket.com/albums/a58/Maskkkk/OOoMigration.png]]

Okay that's pretty straight forward, right?   When I tried to run the {{{JobDashBoard}}} everything appeared to be fine.  Then I tried to add a new job to a company (which requires making a call to a macro and displaying a dialog); well at this point nothing happened.  

So I figured, //"oh well, that's because the name of the libraries have changed..."// so I went though all of the statements that look like this:

{{{
	Dim oDialogModel As Object
	BasicLibraries.loadLibrary( "DBLib" )
}}}

and changed them to:

{{{
	Dim oDialogModel As Object
	BasicLibraries.loadLibrary( "Form_JobDashBoard_DBLib" )
}}}

Just has the Macro Migration Wizard had changed their names....

Shortly thereafter I came across [[this article|http://wiki.services.openoffice.org/wiki/Base/New_features_in_3_1#Macros_in_database_documents]] which gave me a nice overview in more detail of what has changed in Base 3.1.0

And no...changing the libraries did not completely fix the problem...

And about the time I came back to write this post, re-doing a search to write about where I changed the names of the libraries, I noticed that the dialog libraries were still being loaded from the Standard:

{{{
	DialogLibraries.LoadLibrary("Standard")
	myLib = DialogLibraries.getByName("Standard")
	
	Dlg = myLib.getByName("AssociateExistingCompanyContactWithJob")
}}}

Which probably means they have to be changed to:

{{{
	DialogLibraries.LoadLibrary("Form_JobDashBoard_Standard")
	myLib = DialogLibraries.getByName("Form_JobDashBoard_Standard")
	
	Dlg = myLib.getByName("AssociateExistingCompanyContactWithJob")
}}}

This too did not fix the problem...thus I thought to myself that I had forgotten the manner in which I called the macros in the first place from the form and that's when I came across this lovely snippet:

{{{
	' This gets the currently selected row in the company table.
	CurrentCompanyRow = "" & Frm.Row
	
	' Select the currently selected company 
	' for a job initialiy.
	Dim cMacroUrlString As String
	Dim oURL As Object
	Dim oUrlParser As Object
	Dim oFrame As Object
	Dim oDispatcher As Object
	
	cMacroUrlString = "macro://JobDashBoard/Standard.NewJobWizardModule.Main(" & CurrentCompanyRow & ")"
	'cMacroUrlString = " .uno:About"
	
	oURL = createUnoStruct( "com.sun.star.util.URL" )
	oURL.Complete = cMacroUrlString
	
	oUrlParser = createUnoService("com.sun.star.util.URLTransformer")
	oUrlParser.parseStrict( oURL )
	
	oFrame = StarDesktop.getCurrentFrame()
	'XRay oFrame
	oDispatcher = oFrame.queryDispatch( oURL, "_self", 0 )
	'XRay oDispatcher
	oDispatcher.dispatch(oURL, Array())	
}}}

Now if the case is that the macros are no longer contained in the Form's themselves, but rather in the database file....how would I access them using the {{{macro://}}} protocol?

And so I asked my question [[here|http://user.services.openoffice.org/en/forum/viewtopic.php?f=45&t=20104&p=91306#p91306]].
| 09/01/2008 13:57:42 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . | ok |
| 25/11/2013 13:56:14 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 08/12/2013 19:25:27 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 09/12/2013 16:19:45 | YourName | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 28/01/2014 16:26:27 | YourName | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 17/05/2014 14:09:59 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 05/06/2014 14:09:17 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . | ok |
| 05/06/2014 14:09:51 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . | ok |
| 05/06/2014 14:21:47 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 24/06/2014 15:23:47 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
| 23/09/2014 22:04:43 | leeand00 | [[/|http://leeand00.tiddlyspot.com/]] | [[store.cgi|http://leeand00.tiddlyspot.com/store.cgi]] | . | [[index.html | http://leeand00.tiddlyspot.com/index.html]] | . |
/***
|''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"
	});
*/
//}}}

/***
|''Name:''|UploadPlugin|
|''Description:''|Save to web a TiddlyWiki|
|''Version:''|4.1.0|
|''Date:''|May 5, 2007|
|''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 (#3125)|
|''Requires:''|PasswordOptionPlugin|
***/
//{{{
version.extensions.UploadPlugin = {
	major: 4, minor: 1, revision: 0,
	date: new Date("May 5, 2007"),
	source: 'http://tiddlywiki.bidix.info/#UploadPlugin',
	author: 'BidiX (BidiX (at) bidix (dot) info',
	coreVersion: '2.2.0 (#3125)'
};

//
// 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
		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}
				
			]);
	},
	refreshOptions: function(listWrapper) {
		var uploadOpts = [
			"txtUploadUserName",
			"pasUploadPassword",
			"txtUploadStoreUrl",
			"txtUploadDir",
			"txtUploadFilename",
			"txtUploadBackupDir",
			"chkUploadLog",
			"txtUploadLogMaxLine",
			]
		var opts = [];
		for(i=0; i<uploadOpts.length; i++) {
			var opt = {};
			opts.push()
			opt.option = "";
			n = uploadOpts[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 = 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,null,null,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 = Array(uploadParams[0],rssPath,uploadParams[2],'',uploadParams[4],uploadParams[5]);
		bidix.upload.httpUpload(rssUploadParams,convertUnicodeToUTF8(generateRss()),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 == httpStatus.NotFound)
			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; 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');


/* don't want this for tiddlyspot sites

// Backstage
merge(config.tasks,{
	uploadOptions: {text: "upload", tooltip: "Change UploadOptions and Upload", content: '<<uploadOptions>>'}
});
config.backstageTasks.push("uploadOptions");

*/


//}}}
{{{
 
  // Overide displayTiddler function to also Google Analytics urchin.
  var TiddlyLock = {}; // Create a namespace for our new function.
  TiddlyLock.displayTiddler = story.displayTiddler;
  story.displayTiddler = function(srcElement,titles,template,unused1,unused2,animate,unused3)
  {
    if (urchinTracker) { urchinTracker('/' + titles); }
    TiddlyLock.displayTiddler.apply(this,arguments);
  }
 
}}}
<<tabs ""
            "Usecase Screen 1" "Usecase Screen 1" "Usecase Screen 1"
            "Usecase Screen 2" "Usecase Screen 2" "Usecase Screen 2"
            "Usecase Screen 3" "Usecase Screen 3" "Usecase Screen 3"
          >>
<html>
<body>
<form>
<label for="line 1">line 1</label>
<input id="line1" /><br/>
<label for="line2">line 2</label>
<input id="line2" /><br/>
<button>Send</button>
</form>
</body>
</html>
<html>
<body>
<form>
<label for="line 1">line 1</label>
<input id="line1" value="bob" /><br/>
<label for="line2">line 2</label>
<input id="line2" /><br/>
<button>Send</button>
</form>
</body>
</html>
<html>
<body>
<form>
<label for="line 1">line 1</label>
<input id="line1" value="bob" /><br/>
<label for="line2">line 2</label>
<input id="line2" value="joe"/><br/>
<button>Send</button>
</form>
</body>
</html>
<html>
<body>
<object width="425" height="344"><param name="movie" value="http://www.youtube.com/v/dtyv3lAsz60&hl=en&fs=1"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/dtyv3lAsz60&hl=en&fs=1" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="344"></embed></object>
</body>
</html>
!Create another library...
#{{{Tools->Macros->Organize Dialogs...}}}
#Click the ''Libraries'' Tab
#Select your document from the list of locations.
#Click ''New'', and give it a name, for instance well call ours ''"DBLib"''

!Create a macro in that library
{{{
REM  *****  BASIC  *****

TYPE RSR
	ConnString As String
	
End TYPE

Function RSRFactory()
	DIM newRSR As RSR

	newRSR.ConnString = "about:blank"

	RSRFactory = newRSR
End Function
}}}

!Main Program (not in the module)
{{{
Sub Main
	BasicLibraries.loadLibrary("DBLib")
	
	RSRTest = DBLib.RSRFactory()
	
	MsgBox("bob:" & RSRTest.ConnString)
	
End Sub
}}}
/***
| Name:|ViewPalettePlugin|
| Description:|Defines the viewPalette macro for use in ViewTemplate|
| Version:|2.0.0|
| Date:|26-Sep-2006|
| Source:|http://mptw.tiddlyspot.com/#ViewPalettePlugin|
| Author:|Simon Baird <simon.baird@gmail.com>|
| CoreVersion:|2.1.x|
***/
//{{{
merge(config.macros,{
	viewPalette: {
		title: 'Palette Preview',
		handler: function(place,macroName,params,wikifier,paramString,tiddler) {
			var title = params[0] ? params[0] : tiddler.title;			
			var colors = store.calcAllSlices(title);
			var keys = [];
			for (c in colors) keys.push(c);
			var output = '';
			var prefix;
			var lastPrefix;
			output += ""+
				//'<h2>'+this.title+'</h2>'+
				'<table align="right" cellspacing="0" style="border-collapse:collapse;"><tr>'+
				'<td style="border:1px solid #555;font-size:50%;padding:0 2em;background:'+colors[keys[0]]+'">&nbsp;</td>'+
				'<td rowspan="'+keys.length+'">'+
				'<table cellspacing="0" style="border:1px solid #555;width:22em;background:%8;margin-left:2em;">'+
				'<tr><td colspan="2" style="font-size:120%;background:%0;width=200px;padding:1em;font-weight:bold;color:%1">'+
				'TiddlyWiki'+
				'</td>'+
				'<td style="background:%0;font-size:90%;text-align:right;">'+
				'<span style="background:%4;margin-right:1em;padding:0 1em;">message</span>'+
				'</td>'+
				'</tr>'+
				'<tr>'+
				'<td rowspan="3" style="color:%0;vertical-align:top;padding:4px;">Hello<br/>Started<br/>Monkey</td>'+
				'<td style="padding:0.7em;color:%3;"><b style="color:%5;font-size:120%;">HelloThere</b><br/>'+
				'Lorem ipsum <b style="color:%0">dolor</b> sit amet, consectetuer adipiscing elit. </td>'+
				'<td rowspan="3" style="vertical-align:top;font-size:80%;">search<br/>new tiddler<br/>options<br/>'+
				'<div style="background:%6;margin-top:0.5em;padding:2px;color:%7">'+
				'<span style="background:%7;color:%3;">Timeline</span>&nbsp;Tags</div>'+
				'<div style="background:%7;color:%0;padding:4px;">Ninja<br/>Dolphin<br/>FooBar<br/>BazQux</div>'+
				'</td>'+
				'</tr>'+
				'<tr>'+
				'<td style="padding:0.7em;color:%3;"><b style="color:%5;font-size:120%;">GettingStarted</b><br/>'+
				'Proin vel felis vel ipsum <b style="color:%0">fermentum</b> eleifend. </td>'+
				'</tr>'+
				'<tr>'+
				'<td style="padding:0.7em;">'+
				'<span style="padding:0 2px;background:%9;color:3%;">error</span>'+
				'</td>'+
				'</tr>'+
				'</table>'+
				'</td>'+
				'</tr>';

			for (var i=1;i<keys.length;i++)
				output += '<tr><td style="border:1px solid #ccc;font-size:50%;padding:0 2em;background:'+colors[keys[i]]+'">&nbsp;</td></tr>';

			output+= '</table>';
		
			wikify("<html>"+output.format([
				colors.PrimaryMid, //0
				colors.PrimaryPale, //1
				colors.PrimaryDark, //2
				colors.Foreground, //3
				colors.SecondaryMid, //4
				colors.SecondaryDark, //5
				colors.TertiaryMid, //6
				colors.TertiaryPale, //7
				colors.Background, //8
				colors.Error, //9
				''])+"</html>",place);
		}
	}
});

setStylesheet(''+
	'.viewPalette div { text-align:right; vertical-align:top; float:left; padding:2px; width:80px; height:50px; }\n'+
	'.viewPalette div span { padding:0 0.5em;background:white; border:1px solid black; font-size:80%; }\n'+
	'',"showPaletteStyles");

//}}}
<!--{{{-->
<div class='toolbar' macro='toolbar closeTiddler closeOthers +editTiddler > fields syncing permalink references jump'></div>
<div class='title' macro='view title'></div>
<div class='subtitle'><span macro='view modifier link'></span>, <span macro='view modified date'></span> (<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>
<div class='tagging' macro='tagging'></div>
<div class='tagged' macro='tags'></div>
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<div></div>
<!--}}}-->
When an action has been delegated to someone else, or when one is waiting for some external event before a project can be moved forward, this is tracked in the system and periodically checked to see if action is due, or a reminder needs to be sent.
[[article|http://www.fastcompany.com/magazine/134/made-to-stick-sell-handcuffs.html]]

|!Wants |!Shoulds |
| | |
|<<slider zx3q34q3ck "Washing Machine Ordeal - Topload" "Top Load">>|<<slider zx3q34q3ck "Washing Machine Ordeal - Frontload" "Front Load">>|
<<tabs wreadack 
	   "Topload - Pros" "" "Washing Machine Ordeal - Frontload - Pros"
	   "Topload - Cons" "" "Washing Machine Ordeal - Frontload - Cons"
>>
*Requires a $pecial type of detergent ($//high-efficiency detergents//$)
**Cost more
**''Might not be available everywhere...''
*Front load machines cost more.
**Usually cost 30% to 40% more.
*Some do not allow you to add an item of clothing once the cycle has started.
**You have to wait until the next load if you forget to put something like a sock in.
*Cycle times run longer than that of a top-loader
**60-80 minutes for a Front-Loader
----
[[Edit Tiddler|Washing Machine Ordeal - Frontload - Cons]]
----
*Several Models boot the ability to wash 20 pounds in one load
*Uses less water which lowers utility bills
*Spin clothes faster than top-load, extracting more water.
**Hence, lower energy bills in dryer.
*Uses a wash process that is gentler on clothing.
**Clothes last longer.
----
[[Edit Tiddler|Washing Machine Ordeal - Frontload - Pros]]
----
<<tabs wreadack 
	   "Topload - Pros" "" "Washing Machine Ordeal - Topload - Pros"
	   "Topload - Cons" "" "Washing Machine Ordeal - Topload - Cons"
>>
----
[[Edit Tiddler|Washing Machine Ordeal - Topload - Cons]]
----
*Lower Price
*__''Proven Reliablity'' - Toploaders have been around alot longer than Front-Loaders...__
**@@//(I don't know about this...they probably make the new toploaders just as cheap as anything else that is new)//@@
*Uses regular detergent
**More models are available.

----
[[Edit Tiddler|Washing Machine Ordeal - Topload - Pros]]
----
He wants a retro, look from like the 1940's, with some sort of old time radio look to it, and pictures with a theme of two dudes in the background that are water color (old timey) or painted and some person up front that looks not so old, like 2007 in a photo graph, doing things like motorcycling/fishing.
#Logged in using:
**''Username:'' leeand00
**''Password:'' The usual
#Clicked Maintenance->Backup/Restore
##Clicked back up to backup the current configuration.
***And if I click the first restore button I should be able to get that configuration back.
#Took a look at this [[vaguely related document|http://www.dslreports.com/faq/13600]]
#Went into {{{Configuration->VC Configuration}}}
##Saw a VC with a protocol of {{{PPPoE}}} which was {{{enabled}}}, and had a {{{VPI}}} of {{{0}}} and a {{{VCI}}} of 35.
###{{{Bridge Broadcast}}} was checked.
###{{{Bridge Multicast}}} was also checked.
##Clicked {{{Edit}}} beside said {{{VC}}}.
###New {{{VC 1 Configuration}}} window popped up.
####Looked like this:[img[img/ ]]...initially
####Noted this from said [[related document|]]http://www.dslreports.com/faq/13600: //When the Westell is bridged, it will have no router functions at all, no subnet, no IP, and no default gateway. The router connected to the Westell will acquire and hold the Public IP address and will determine the LAN IP addresses and subnet.//
*****Presently mine has an ip, so it must not be bridged.
####Changed {{{Protocol}}} field to {{{Bridge}}}
####Changed {{{Mode}}} to {{{Bridge}}}
####Clicked {{{set VC}}}
###Next was prompted to restart the modem...clicked {{{ok}}} and waited for it to restart.
#Visited {{{Configuration->DHCP Configuration}}}
##In the {{{DHCP Server}}} dropdown I selected {{{Off}}}
###Clicked {{{Save}}}
###Was prompted {{{Save and reconfigure DHCP?}}}, I clicked {{{ok}}}
#Plugged the modem into the Buffalo routers uplink port
#Tested Internet...No Internet.
#Logged into the Buffalo Router...
#Clicked {{{Setup}}} tab.
#Selected a {{{Connection Type}}} of {{{PPPoE}}}
#Clicked {{{Apply Settings}}}
#Appears to work!!!
I've been having some problems with my Palm TX as of late, so I went out to look for an alternative to Palm as they only seem to be manufacturing smart-phones now.  For instance, I bought my Palm TX 2 years ago and I went to the store today to ask if they had any and after a brief sales pitch (which I shot down), they directed me to their three remaining models of PalmOS PDAs.  The trouble for me was that they all looked just about as poor a quality as the TX, so I'm not really into getting another one of those.

However, I would like to have something with the following features:
*Ability to Sync with Quicken
*Ability to connect to wifi (I don't wanna pay some telco an extra $30 a month for my internet access)
*An SD Card Slot - Considering so many of my other devices support it, and I already have a bunch of SD cards.
*Finally I would like (maybe) if the device could run some form of PalmOS emulator (mainly because there are a couple of programs I rely on and would really like if the pda thing would support them.

This is going to be a really, really difficult decision, so I am writing this blog entry to set all of my ducks in a row as it were.
The proof is in the pudding, there's one huge database called "the registry" where most Windows programs store their settings, and when you uninstall a program the settings are usually never removed; this slows your system down to a crawl the more programs you install and uninstall over time.

Linux software on the other hand stores it's settings just plain old config files, so "the registry" problem does not occur.

The question you have to ask yourself before installing windows is: Do I want to be penalized for installing and uninstalling software?  

Seems pretty clear to me...

[[http://superuser.com/questions/74932/best-way-to-avoid-os-rot-in-windows-7/74941#74941]]
<<tabs "12/3/20073:09 PMs" 
      "Defaults" "Workrave - Defaults" "Workrave - Defaults"
      "RSI Recovery" "Workrave - RSI Recovery" "Workrave - RSI Recovery"
      "RSI Avoidance" "No problems yet but if you are trying to avoid RSI" "Workrave - RSI Avoidance"
>>

[[Workrave|http://www.workrave.com]] comes with it's own @@color(red):*@@default settings but you can tailor its settings to your own needs.  

Depending on who you are and if you are actually recovering from RSI or if are just trying to avoid it, the [[Workrave website|http://www.workrave.com]] gives the above advice for how to set your installation up. Which I have summarized in the tables above.

>@@color(red):*@@ Default settings are in the tab marked ''default''.
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time Before End: </strong></td>
    <td>4</td>
    <td>:</td>
    <td>00</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Postpone Time: </strong></td>
    <td>00</td>
    <td>:</td>
    <td>20</td>
    <td>:</td>
    <td>00</td>
</tr>
</table>
</body>
</html>

<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>2</td>
    <td>:</td>
    <td>30</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>0</td>
    <td>:</td>
    <td>25</td>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Postpone Time: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>2</td>
    <td>:</td>
    <td>30</td>
</tr>
</table>
</body>
</html>
<<tabs "12/3/200712:09 PMs" 
      "Microbreak" "Microbreak Settings Chart - Defaults" "Workrave - Microbreak Settings Chart - Defaults"
"Rest Break" "Rest Break - Defaults" "Workrave - Rest Break - Defaults"
"Daily Limit" "Daily Limit - Defaults" "Workrave - Daily Limit - Defaults"
>>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>3</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>0</td>
    <td>:</td>
    <td>30</td>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Postpone Time: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>2</td>
    <td>:</td>
    <td>30</td>
</tr>
</table>
</body>
</html>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>10</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>0</td>
    <td>:</td>
    <td>10</td>
</tr>
</table>
</body>
</html>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>2</td>
    <td>:</td>
    <td>30</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>0</td>
    <td>:</td>
    <td>25</td>
</tr>
</table>
</body>
</html>
<<tabs "12/3/200712:09 PMs" 
      "Microbreak" "Microbreak Settings Chart - RSI Avoidance" "Workrave - Microbreak Settings Chart - RSI Avoidance"
"Rest Break" "Rest Break - RSI Avoidance" "Workrave - Rest Break - RSI Avoidance"
"Daily Limit" "Daily Limit - RSI Avoidance" "Workrave - Daily Limit - RSI Avoidance"
>>
<<tabs "12/3/20073:28 PMs" 
	"Micropause" "Micropause - RSI Recovery" "Workrave - Micropause - RSI Recovery"
	"Rest Break" "Rest Break - RSI Recovery" "Workrave - Rest Break - RSI Recovery"
      	"Daily Limit" "Daily Limit - RSI Recovery" "Workrave - Daily Limit - RSI Recovery">>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>45</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>10</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Postpone Time: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>3</td>
    <td>:</td>
    <td>00</td>
</tr>
</table>
</body>
</html>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>1</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>00</td>
    <td>:</td>
    <td>05</td>
    <td>:</td>
    <td>00</td>
</tr>
</table>
</body>
</html>
<html>
<body>
<table>
<tr style="background-color: #cecece; color: white;">
    <th></th>
    <th>hrs</th>
    <th>:</th>
    <th>min</th>
    <th>:</th>
    <th>sec</th>
</tr>
<tr style="background-color: #90dee2;">
    <td><strong>Time between breaks: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>20</td>
    <td>:</td>
    <td>00</td>
</tr>
<tr style="background-color: #cecece">
    <td><strong>Break Duration: </strong></td>
    <td>0</td>
    <td>:</td>
    <td>10</td>
    <td>:</td>
    <td>00</td>
</tr>
</table>
</body>
</html>
!!What is it for?
>The purpose of [[Workrave|http://www.workrave.org/]] is to prevent you from getting [[Repetitive Strain Injury|http://en.wikipedia.org/wiki/Repetitive_strain_injury]] or to [[help in recovering from it|http://www.workrave.org/faq/]].

''[[Workrave|http://www.workrave.org/]] splits your day using three types of timers:''
<<tiddler "Workrave Timer Chart">>
|bgcolor(#d5ccbb):[img[http://i9.photobucket.com/albums/a58/Maskkkk/MicroBreak.png]]|bgcolor(#ffa500):[[Microbreak]]|bgcolor(black):|bgcolor(#FFFFCC):A short, quick rest of the eyes that occurs during your work.|
|bgcolor(#d5ccbb):[img[http://i9.photobucket.com/albums/a58/Maskkkk/RestBreak.png]]|bgcolor(#ffa500):[[Restbreak]]|bgcolor(black):|bgcolor(#FFFFCC):This is a longer more serious type of break.|
|bgcolor(#d5ccbb):[img[http://i9.photobucket.com/albums/a58/Maskkkk/Leave.png]]|bgcolor(#ffa500):[[Daily Limit]]|bgcolor(black):|bgcolor(#FFFFCC):Timer which helps you remember to leave at the end of the day!|
You've probably clicked this link because you were unable to hear the radio station.

With that, lets try some things.  

#Check the [[Speakers|Check the Speakers]] or [[Headphones|Check the Headphones]]
#[[Check the Sound Settings]]
#[[Be Sure you are Using Internet Explorer]]
Wow. Wow.  This is really cool.

I was reading [[this article|http://softwareas.com/as-we-may-think-url-trails]] on "Trails" when I came across the creator of Tiddlywiki on a blog comment talking about his ZUI version of Tiddlywiki

If you don't know what a ZUI is, it's likely the next generation of GUI's, a Zoomable User Interface.  

Checkout the [[demo|http://www.osmosoft.com/cecily/]] here, it's really really cool and it seems with a little work could be used to create the trails they spoke of in the blog.

Oh yeah and if you are going to try out the demo make sure you use Google Crome!

Occurs when a person has not only met some prior expectation or satisfied a need or a desire but also gone beyond what they were programmed to do and achieved something unexpected, perhaps something never imagined before.
{{{
<?php
   /**
    * Helper class for Hello World! module.
    *
    * @package Joomla.Tutorials
    * @subpackage Modules
    * @link http://dev.joomla.org/component/option,com_jd-wiki/Itemid,31/id,tutorials:modules/
    * @license        GNU/GPL, see LICENSE.php
    * mod_helloworld is free software. This version may have been modified pursuant
    * to the GNU General Public License, and as distributed it includes or
    * is derivative of works licensed under the GNU General Public License or
    * other free or open source software licenses.
    */
   class modHelloWorldHelper 
   {
      function getHello( $params )
      {
         return 'Hello, World!';
      }
   }
?>
}}}
We next need to provide a configuration file to store the configuration for the particular Virtualhost we are setting up.  A dns-name with no site doesn't amount to much more than something we can just ping provided the host is up.

But before we do that let's add a seperate entry to include just the configuration for our Virtualhost in the main configuration of Apache 2:

{{{
...
Include etc/extra/httpd-<virtual-hostname>.conf
}}}
''/opt/lampp/etc/httpd.conf''

In the next step we will create this file so that it can point to a basic directory that contains html or php that our site will run when the particular {{{<virtual-host>}}} is requested from a web browser.
{{{
#include <stdio.h>
#include "split.h"
#include <string.h>

int main(char * args)
{

	const unsigned ROWS = 10;
   const unsigned COLUMNS = 10;

	// Tokenize this string.
	char* tokenizeMe = new char[100];

	// Setup the String to tokenize.
	memset(tokenizeMe, 0, strlen(tokenizeMe));
	strcpy(tokenizeMe, "pe|butter|jelly|cheese|log|beef|regano|tea");

	printf("Original String: %s\n", tokenizeMe);

	int numTokens = 0;

	char **strArrays;

	strArrays = split(tokenizeMe, "|", numTokens);

	for(int j = 0; j < numTokens; j++)
		printf("%s\n", strArrays[j]);
	
	// Cleanup
	//delete tokenizeMe; (Crashes the program for some reason...not an issue, this is the client.)
	delete strArrays;   // Cleanup strArrays per instructions in 
							  // documentation of split funciton.

  return 0;
}
}}}
{{{
<?php

   // no direct access
   defined( '_JEXEC') or die( 'Restricted access' );
   
   // Include the syndicate functions only once
   require_once( dirname(__FILE__).DS.'helper.php' );
   
   $hello = modHelloWorldHelper::getHello( $params );
	require( JModuleHelper::getLayoutPath( 'mod_helloworld' ));
   
?>
}}}
{{{
<?xml version="1.0" encoding="utf-8"?>
<install type="module" version="1.5.0">
   <name>Hello, World</name>
   <author>John Doe</author>
   <version>1.5.0</version>
   <description>A simple, Hello, World! module.</description>
   <files>
           <filename>mod_hello.xml</filename>
           <filename module="mod_helloworld">mod_helloworld.php</filename>
           <filename>index.html</filename>
           <filename>helper.php</filename>
           <filename>tmpl/default.php</filename>
           <filename>tmpl/index.html</filename>
   </files>
   <params> 
   </params>
</install>
}}}
Permalinks make it easier for humans and search engines to read and pass around links on your website.  Here is how I set them up on my lampp-based test environment.
----
Went into {{{wp-admin}}} and selected {{{Settings->Permalinks}}}.

Then from {{{Common settings}}} I selected the {{{Month and name}}} radio button.

Clicked {{{Save Changes}}}


----
In the {{{httpd-hostnameTestSite.conf}}} file, 
I added the MultiViews option to my directory
{{{
Alias /hostnameTestSite/ /home/leeand00/hostnameTestSite/
<Directory /home/leeand00/hostnameTestSite/>
     Options Indexes FollowSymLinks MultiViews
     AllowOverride All
     Order allow,deny
     Allow from All
</Directory>
...
}}}
''httpd-hostnameTestSite.conf''
----
In the actual test directory I added the following to the {{{.htaccess}}} file:
{{{
<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.php$ - [L]
  RewriteCond %{REQUEST_FILENAME} ! -f
  RewriteCond %{REQUEST_FILENAME} ! -d
  RewriteRule . /index.php [L]
</IfModule>
}}}
''.htaccess'' - Pulled from the Wordpress Admin panel.


{{{
#include <string.h>
#include "split.h"

/**
 * Splits a string into delimited characters.
 * 
 * @Author: Andrew J. Leer 2008
 *
 *
 *	@param tokenizeMe:   String to tokenize 
 *                      (This function does not modify this variable)
 * @param delim:		   Delimiter character which 
 *                      separates each of the strings.
 * @param &numOfItems:  The number of items found 
 *                      in the string after it was,
 *                      split.
 *
 * @returns a 2D array of char *. (See http://www.cplusplus.com/forum/beginner/2967/ 
 *											  for more information.)
 *          NOTE: Be sure to delete the returned variable 
 *                as it is allocated on the fly inside 
 *                this function!!!!
 *
 **/
char ** split(char* tokenizeMe, const char* delim, int &numOfItems)
{
	// First count the number of character
	// occurrences in the string.
   unsigned int delimOccurrences = countCharacterOccurances(tokenizeMe, delim);

	const unsigned ROWS    = delimOccurrences+1;
	const unsigned COLUMNS = strlen(tokenizeMe);

	char* dup_tokenizeMe = new char[COLUMNS];

	// Duplicate our string so 
	// it is not modified by the strTokenizer function.
	strcpy(dup_tokenizeMe, tokenizeMe);

	// Calculate the number of columns needed 
	// for each token in the string to tokenize.
	unsigned int* colSizes = getStringSizes(tokenizeMe, delim, ROWS);

	// Next Setup an array to store 
	// the tokens in.  Make sure that each of them 
	// are sized to exactly the right length. 
	// strArrays will be returned when split completes.    
   char **strArrays;
	strArrays = new char*[ROWS];

   for(unsigned int i = 0; i < ROWS; i++){
		strArrays[i] = new char[colSizes[i]];
		memset(*strArrays, 0, colSizes[i]);
	}

	int numTokens = 0;
	int posLastSearchStop = 0;

	char *token = (char *) "\0";

	do
	{
		token = strTokenizer(dup_tokenizeMe, delim, posLastSearchStop);
		if(token != NULL) { 
			strcpy(strArrays[numTokens], token); 
			numTokens++;
		}
	}
	while(token != NULL);

	// Set the number of tokens 
	// so that it can be returned to 
	// the user.
	numOfItems = numTokens;

	

	// Clean up 
	delete colSizes; // Clean up colSizes per documentation of 
						  // getStringSizes function.

	

	return strArrays;
}

/**
 * NOTE: This method is not meant to be called from anything 
 *       except the split function above. 
 *
 * Starts searching for the specified delim argument at the 
 * posStoppedLastSearchAt postion in the tokenizeThisString.
 * Returns a substring from the posStoppedLastSearchAt to 
 * one minus the next specified delim char found.  
 * 
 *
 * @Author: Andrew J. Leer 2008
 * 
 * @param tokenizeThisStr: The string to search for the next delimiter.
 *
 *
 *	@param delim: The delimiter to search for within the tokenizeThisStr argument.						 
 *
 *
 *	@param posStoppedLastSearchAt: The position in the string to 
 *										    start searching for the next 
 *											 delim char.
 *											 This argument is passed by reference 
 *											 so that this function may be called 
 *											 more than once picking up 
 *											 at the position one after the 
 *											 last position it found a delim char.
 *
 *	@returns a char* containing the next token found in the 
 *                  string from the 
 */
char* strTokenizer(char* tokenizeThisStr, const char* delim, 
						 int &posStoppedLastSearchAt)
{
	unsigned int strLen = strlen(tokenizeThisStr);
	char d = delim[0];

	int wordPosStart = posStoppedLastSearchAt;

	int wordPosEnd = 0;

	for(unsigned int i = posStoppedLastSearchAt; 
		 i <= strLen; i++)
	{
	
		if(tokenizeThisStr[i] == d)
		{
			wordPosEnd = i-1;
			posStoppedLastSearchAt = i+1;
			break;
		}
		else if(tokenizeThisStr[i] == 0)
		{
			wordPosEnd = i-1;
			posStoppedLastSearchAt = i+1;
			break;
		}
	}

	char* subStr = NULL;

	subStr = substr(tokenizeThisStr, wordPosStart, wordPosEnd);

	return subStr;
}

/**
 *	A simple sub string function for parsing out part of a string.
 *
 *	@Author: ImmaGNUman (http://www.gamedev.net/community/forums/topic.asp?topic_id=20759)
 *          and modified by Andrew J. Leer
 *
 * @param string: The char* string from which to parse the sub string.
 * 
 * @param begin: The beginning character of the substring.
 *
 *	@param end: The ending character of the substring.
 *
 * @returns NULL if invalid arguments, xor the substring specified.
 */
char* substr(char* string, int begin, int end)
{
	if ((string == NULL) || (end < 0) || (begin < 0) || (end < begin)) return NULL;

	char* temp = new char[end-begin+1];
	
	

	//(char *) malloc(sizeof(char)*(end-begin+1));
	
	if(temp != NULL)
	{
		strncpy(temp,string+begin,end-begin+1);
		temp[end-begin+1] = '\0';
	}
	return temp;
}

/**
 * Calculates the size of each token string separated by the delim char 
 * in the str argument passed.
 *
 *
 * @Author Andrew J. Leer 2008
 *
 * @param str:			 The string from which we wish to obtain the 
 *                    sizes of each of the strings.
 *							 (This function does not modify this variable)
 *
 * @param delim:      Delimiter character which 
 *                    separates each of the strings.
 * @param numOfItems: The number of items (strings) contained in our 
 *                    string.  See the function countCharacterOccurances 
 *                    and add one to what it returns.
 * 
 * @returns: An array of the sizes of the strings delimited by char delim in the
 *           string str.
 *           NOTE: Be sure to delete the returned variable 
 *                 as it is allocated on the fly inside 
 *                 this function!!!
 **/
unsigned int* getStringSizes(char* str, const char* delim, unsigned int numOfItems)
{
	unsigned totalStringLen = strlen(str)+1;
	unsigned int* arrayOfSizes = new unsigned int[numOfItems];
	
	char d = delim[0];

	unsigned int listItem = 0;
	unsigned int strLen = 0;

	// Loop through all the characters in the string,
	// and compare each of the items in the string to 
	// the delimiter.  
	for(unsigned int i = 0; i < totalStringLen; i++)
	{
		// If the delimiter matches or we've reached the end of the string.
		if(str[i] == d ||
			str[i] == '\0')
		{
			arrayOfSizes[listItem] = strLen-1; // Store the size of that string.
			listItem++;	// move the the next item 
			strLen = 0; // reset the strLen to 0.
		}
		// If it doesn't match, increment the size of the 
		// string.
		else
		{
			strLen++; 
		}
	}

	return arrayOfSizes;
}


/**
 *	Counts the number of times the delim argument 
 * occurs in the string argument and returns it.
 *
 * @Author: Andrew J. Leer 2008
 *
 * @param str:   The string to search for 
 *               occurrences of delim.
 *					  (This function does not modify this variable)
 *
 * @param delim: The char to search str
 *               for number of occurrences.
 *
 * @returns:	  The number of occurrences of 
 *               character delim in char* str.
 */
unsigned int countCharacterOccurances(char* str, const char* delim)
{
	int totalStrLen = strlen(str);
	unsigned int charOccrances = 0;
	char d = delim[0];

	for(int i = 0; i < totalStrLen; i++)
	{
		if(str[i] == d)
		{
			charOccrances += 1;
		}
	}

	return charOccrances;
}

}}}
{{{
char ** split(char* tokenizeMe, const char* delim, int &numOfItems);
unsigned int countCharacterOccurances(char* tokenizeMe, const char* delim);
unsigned int* getStringSizes(char* str, const char* delim, unsigned int delimOccurrences);
char* strTokenizer(char* tokenizeThisStr, const char* delim, int &posStoppedLastSearchAt);
char *substr(char *string, int begin, int end);
}}}
''Definition:'' 
//(taken from [[the syncyourlaptop tutorial|http://www.2brightsparks.com/tutorials/syncyourlaptop/2.html]] at 2brightsparks.com)//
>When synchronizing files you are copying files between two computers or storage mediums.  For example, you have a desktop computer and a notebook computer and have copies of the same files on both computers.  

>You may be changing those files either on your desktop or on your notebook depending on the situation. 

>For example, you may go on a business trip with your notebook and change the files while away.  When you return you want to make sure your desktop and notebook have the latest copies of those files.  To do this you would synchronize the files.  

>With synchronization files copied from one to the other based on when they were last changed.  Files may also be deleted, e.g. you deleted a file on your notebook and so want the same file on your desktop to also be deleted.
bob
Type the text f
{{{
<?php


	// no direct access
	defined( '_JEXEC' ) or die ('Restricted access');

	require_once( dirname(__FILE__).DS.'helper.php');
	
	$hello = modHelloWorldHelper::getHello( $params );
	require( JModuleHelper::getLayoutPath( 'mod_helloworld' ));

?>
}}}
Well here is our file that we create in the ''/opt/lampp/etc/extra/{{{httpd-<virtual-hostname>.conf}}}'':

{{{
Alias /<virtual-hostname>/ /home/<username>/<virtualhost-name>.com/

<Directory /home/<username>/<virtualhost-name.com/
      Options Indexes FollowSymLinks
      AllowOverride All
      Order allow,deny
      Allow from All
</Directory>

NameVirtualHost *:80

<VirtualHost *:80>
     ServerName <virtualhost-name>.<suffix>
     ServerAlias <virtualhost-name>
     DocumentRoot /home/<username>/httpd-<virutalhost-name>.com/
</VirtualHost>

#Compression Section (optional)
#Compress all text & html
AddOutputFilterByType DEFLATE text/html text/plain text/xml

#Or, compress certain file types by extension:
<Files *.js>
SetOutputFilter DEFLATE
</Files>

<Files *.php>
SetOutputFilter DEFLATE
</Files>

#ModRewrite Logging (Optional)
<IfModule mod_rewrite.c>
RewriteLog "/home/leeand00/logs/andrew_mod_rewritelog.log"
</IfModule>
}}}
''/opt/lampp/etc/extra/{{{httpd-<virtual-hostname>.conf}}}''

Personally I like to store the sites from my development environment in my home directory, so when I deploy a site locally in my development environment it's easy to find it later if something goes wrong during deployment.

I'll make an alias to it so I can access it directly on the webserver to try it out in it's own directory before trying it as a Virtualhost.

{{{
Alias /<virtual-hostname>/ /home/<username>/<virtualhost-name>.com/

<Directory /home/<username>/<virtualhost-name.com/
      Options Indexes FollowSymLinks
      AllowOverride All
      Order allow,deny
      Allow from All
</Directory>
}}}

If you restart Apache2 and visit the ip of your server we specified in the previous 

----

Now comes the Virtualhost part:

{{{
NameVirtualHost *:80

<VirtualHost *:80>
     ServerName <virtualhost-name>.<suffix>
     ServerAlias <virtualhost-name>
     DocumentRoot /home/<username>/<virutalhost-name>.com/
</VirtualHost>
}}}

This specifies that when our web browser requests the dns-name from dnsmasq and is repointed to our servers ip address, this Virtualhost will be loaded up based on the dns-name that we initially requested.  

----

The rest of the configuration file specifies that some of our text-based files are compressed when they are sent and that mod rewrite writes out a log based on the url string it receives.

{{{
#Compression Section (optional)
#Compress all text & html
AddOutputFilterByType DEFLATE text/html text/plain text/xml

#Or, compress certain file types by extension:
<Files *.js>
SetOutputFilter DEFLATE
</Files>

<Files *.php>
SetOutputFilter DEFLATE
</Files>

#ModRewrite Logging (Optional)
<IfModule mod_rewrite.c>
RewriteLog "/home/leeand00/logs/andrew_mod_rewritelog.log"
</IfModule>
}}}

8-bit abs