27 November 2014

Only Connect Missing Vowels Game

PublishedActual
Birmingham New Street 06:10 06:13
London Euston 07:34 07:40

On a recent edition of Only Connect Series 10, Episode 12: Coders vs. Romantics there was a team called ‘Coders’ whose team members were described such:

  • Richard, a software engineer…
  • Zoe, a managing director…
  • Captain, David, a software developer…

Victoria Coren Mitchell then continued with the initial interchange

VCM: "United by a soft spot for software, they are the Coders. You lost to the Gamesmasters in your first heat. Have you developed some software to make sure that you win this one?"
David: "We did try to find some software online to see if we could win, but the only missing vowels apps out there are only suitable for three-year-olds.

"If the words like 'pig' and 'hat' come up, I think we will be sorted."

Now, I found it ironic that they are called coders, they have a self professed soft spot for software and there is an engineer and developer on the team yet they looked for missing vowel games? This triggered the following conversation between my wife and me

Me: "If they are coders why don't they just write a program to test themselves"
Wife: "yeah... can that be done"
Me: "oh yeah, it'd be super easy to do the missing vowels game"
Wife: "can you write one?..."

I should add at this point that my wife’s favourite part of the show is the missing vowels round, her opinion of OC is that it’d be great if the whole show was missing vowels. I’d just told her that to create that game would be super easy and she set me a challenge.

So, here is the discussion of the result :)

Design

The main premise of the missing vowels game is that a word is presented on screen with all the vowels removed, if the word contains spaces then they are relocated within the answer for example:

FRD = FORD
L PHRM = ALPHA ROMEO

In the first example only the letter O is removed, in the second example A, E and O are removed and the space relocated behind the L.

As well as implementing the above algorithm I also wanted the ability to add new categories easily, for this reason I chose to store the data in JSON files in a directory that is scanned on instantiation, this keeps the program small and simple.

V1

The initial implementation of the program was in Java, this is primarily because I was writing the software on the train on the way home and as other West Coast Mainline users will know internet access is poor, therefore I wasn’t able to download dependencies with other technologies.

At the end of the journey I had a working version of the application which I could show my wife to get her ‘customer’ reaction.

Please see the GitHub project for the source.

Categories for the game are stored in separate JSON files, a list of JSON files is generated and a random file chosen, this is read in using Jackson. Each category has an ID, a display title and a number of answers e.g.

{
"id":"capital_cities",
"display":"Capital Cities",
"answers":[
    "Abu Dhabi",
    "Abuja"
]
}

Within the application a random answer is chosen and passed through a processing method, this strips the word of vowels, rejigs spaces and returns to the calling method. The user receives the scrambled text and presses enter when ready to go onto the next word, the answer is then displayed along with the next processed word.

Here is a small example of the output:

Categories and their words will be presented, press enter for the answer and  or the next clue

British PMs Since 1900
MRGRT THTCHR
Margaret Thatcher

JM SCLLGHN
James Callaghan

CLMNTT TL

In general V1 was well received however the limitation of having to use the command line and run on a JRE meant that the customer experience wasn’t brilliant, this was expected. My wife then gave me the next set of requirements… “it’d be great if I could play this on my phone”

V2

The simplest way to allow the game to run on the phone was to turn it into a website, this would make the game platform agnostic, and it also meant I needed to work using a client/server paradigm so that the phone can contact a server as html etc cannot be saved locally. Initially I thought about using Spring or Wicket but then decided that JavaScript technologies would make quicker development, smaller server footprint and would allow me to learn a few things.

The technology stack I decided on was:

  • Node.js - run time for server side JavaScript
  • Express - server side node package to simplify routing and provide support for templates; can easily create a server
  • Bootstrap - client display library, provides an easy way to define layouts which are adaptable for multiple form factors

The JSON files were reused from the java project and many of the Java methods were turned into JS functions.

Please see the GitHub project for the source.

With the web version of the game the user is presented with a page that contains a scrambled work and a button, pressing the button reveals the answer and pressing the button again presents the next scrambled word. For each category, 5 random words are chosen and once all categories have been processed the application starts again with all categories and the next chosen at random.

This is the scrambled word screen

Pressing show presents the reveal screen

Pressing next presents the next word again

V3
This is a potential work in progress, my wife has more requirements and I have a few ideas, these include:

  • Checklist of available categories to choose from instead of just scrolling through all categories all the time
  • Install on my QNAP for easy access from multiple clients
  • Store categories in a database, probably Mongo (even though the scale isn’t needed)
  • Add better logic for deciding on the next word, would probably want to use a bloom filter to see if a word for a category has already been used before

20 February 2014

jEdit Markdown plug-in hack

PublishedActual
Birmingham New Street 06:50 06:50
London Euston 08:15 08:15

I have posted in the past about jEdit and Markdown and how I use jEdit to write my Markdown and preview using the Markdown plug-in. There is an annoying bug in the Markdown plug-in from the jEdit plug-in manager (v0.1), that also exists in the latest version on the authors website (0.1.1), which affects nested lists so that when they are generated they only display the first word of the top level list items, this can be replicated and seen as follows:

Firstly create an .md file in jEdit with this content:

1. This is list item 1
    1. This is list item 1.1
    1. This is list item 1.2
1. This is list item 2
1. This is list item 3
    1. This is list item 3.1
        1. This is list item 3.1.1
1. This is list item 4

Next, use the Markdown plug-in in jEdit to preview the text, the following will be shown:

You can see that item 1, 3 and 3.1 only display a single word for their list item.

The original author of the plug-in hosts it in an Atlassian Bitbucket and I could see from the commit history that the dependencies have been updated recently however there was no binary version of the latest project. Using Mercurial I downloaded the project into Eclipse but encountered some issues, these were most likely because my environment isn’t set up correctly for the build but I didn’t have time/inclination to investigate further. As the plug-in is distributed under the GNU GPL I decided to upgrade the plug-in libraries myself by doing the following:

  • Close jEdit
  • Download pegdown-1.4.2.jar, this relies on parboiled
  • Download parboiled-java-1.1.6.jar which relies on parboiled-core-1.1.6.jar and asm-all-4.0.jar
  • Using 7-Zip open the MarkdownPlugin.jar file and edit the MarkdownPlugin.props file within the plug-in so that the following properties change.
    • plugin.ua.pico.jedit.markdown.MarkdownPlugin.jars=parboiled4j-0.9.9.0.jar pegdown-0.8.5.4.jar
      Becomes
      plugin.ua.pico.jedit.markdown.MarkdownPlugin.jars=asm-all-4.0.jar parboiled-java-1.1.6.jar parboiled-core-1.1.6.jar pegdown-1.4.2.jar
  • Copy the modified MarkdownPlugin.jar, parboiled-java-1.1.6.jar, parboiled-core-1.1.6.jar, pegdown-1.4.2.jar and asm-all-4.0.jar to the jars directory of the jEdit install,
  • Start jEdit.

Now when I preview or render a Markdown file I get the lists correctly returned to me:

One of the downsides to this approach is that new features in pegdown that may be supported in the Bitbucket project will not be available.