Conifer Productions

From ideas to apps. From mobile to global.

Photos framework and HipStyles

HipStyles was removed from the App Store over a year ago, but from time to time I still think it could be resurrected. However, after taking a long hard look at Apple’s new Photos framework in iOS 9, I think it is just not feasible anymore. HipStyles and the Assets Library Framework HipStyles was a photo finder for Hipstamatic and Oggl photos, looking for snaps taken with some Hipstamatic lens, film or flash of your choosing. Read more →

Learning Clojure

About one year ago I wrote a multi-part tutorial on Clojure programming, describing how I wrote a small utility called ucdump (available on GitHub). Here are links to all the parts: Part 1: The Clojure REPL Part 2: Definitions Part 3: Higher-order functions Part 4: Logic Part 5: Project However, Carin Meier’s Living Clojure is excellent in many ways. Get it from O’Reilly (we’re an affiliate): My little tutorial started with part zero, in which I lamented how functional programming is made to appear unlearnable by mere mortals, and it kind of snowballed from there. Read more →

BusMonTRE-sovelluksen tulevaisuus

BusMonTRE on pysäkkiavustinohjelma älypuhelimille. Se on tehty tarjoamaan helppo tapa selvittää milloin kulkee bussi käyttäjää lähellä olevalta pysäkiltä Tampereen joukkoliikenteen toiminta-alueella (johon kuuluu Tampereen lisäksi useita ympäristökuntia). Tähän tarkoitukseen se käyttää Tampereen kaupungin tarjoamaa avointa dataa sekä Tampereen joukkoliikenteen ylläpitämää sinistä virtuaalimonitoria. BusMonTRE on tällä hetkellä saatavana iOS-, Android- ja Windows Phone -älypuhelimille. Tässä kirjoituksessa kerron hieman ohjelman taustoista sekä tulevaisuuden kehitysnäkymistä.

Virtuaalimonitori omaan tarpeeseen

Nettisivupalveluna toimiva sininen virtuaalimonitori on ollut käytössä Tampereella jo pitkään. Tavaratalot ja pienemmät liikkeet ovat käyttäneet sitä tiloissaan esimerkiksi näyttämällä isolla televisioruudulla asiakkailleen lähimmältä pysäkiltä kulkevien bussien tietoja. Kaikiilla Tampereen joukkoliikenteen pysäkeillä on sekä nimi että numerokoodi, ja virtuaalimonitorin saa helposti näyttämään yhtä tai useampaa haluttua pysäkkiä tämän numerokoodin avulla.

Sain ajatuksen BusMonTRE:sta jo vuonna 2011, mutta silloin en vielä ryhtynyt suunnittelemaan sovellusta, vaan käytin omissa laitteissani muutamaa valmiiksi leivottua nettiosoitetta, joilla sain kätevästi haluamani monitorinäytön nettiselaimeen. Osallistuin vuosina 2012-2013 useaan avoimen datan tapahtumaan Tampereella, ollessani muutenkin aktiivisesti mukana Tampereen startup-yhteisössä. Eräässä näistä tapahtumista Tampereen joukkoliikenteen edustaja antoi vahvan signaalin siitä, että heidän intresseissään ei ole kehittää sovelluksia itse, mutta he tarjoavat datan ilmaiseksi sovelluskehittäjien käyttöön.

Read more →

Functional programming without feeling stupid, part 5: Project

In the last four installments of Functional programming without feeling stupid I’ve slowly built up a small utility called ucdump with Clojure. Experimentiing and developing with the Clojure REPL is fun, but now it’s time to give some structure to the utility. I’ll package it up as a Leiningen project and create a standalone JAR for executing with the Java runtime.

Creating a new project with Leiningen

You can use Leiningen to create a skeleton project quickly. In my project’s root directory, I’ll say:

lein new app ucdump

Leiningen will respond with:

Generating a project called ucdump based on the 'app' template.

The result is a directory called ucdump, which contains:

.gitignore   README.md    project.clj  src/
LICENSE      doc/         resources/   test/

For now I’m are most interested in the project file, project.clj, which is actually a Clojure source file, and the src directory, which is intended for the app’s actual source files.

Leiningen creates a directory called src/ucdump and seeds it with a core.clj file, but that’s not what actually what I want, for two reasons:

  • I want ucdump to be a good Clojure citizen, so I’m going to put it in a namespace

    called com.coniferproductions.ucdump.

  • My Git repository for ucdump also contains the original Python version of the application, which is in <project-root>/python, and I want the Clojure version to live in <<em>project-root</em>>/clojure.

Read more →

Functional programming without feeling stupid, part 4: Logic

In the previous parts of “Functional programming without feeling stupid” we have slowly been building ucdump, a utility program for listing the Unicode codepoints and character names of characters in a string. In actual use, the string will be read from a UTF-8 encoded text file.

We don’t know yet how to read a text file in Clojure (well, you may know, but I only have a foggy idea), so we have been working with a single string. This is what we have so far:

(def test-str 
  "Na\u00EFve r\u00E9sum\u00E9s... for 0 \u20AC? Not bad!")
(def test-ch { :offset 0 :character \u20ac })
(def short-test-str "Na\u00EFve")

(defn character-name [x]
  (java.lang.Character/getName (int x)))

(defn character-line [pair]
  (let [ch (:character pair)]
    (format "%08d: U+%06X %s"
      (:offset pair) (int ch)
      (character-name ch))))
    
(defn character-lines [s]
  (let [offsets (repeat (count s) 0)
        pairs (map #(into {} {:offset %1 :character %2}) 
          offsets s)]
    (map character-line pairs)))

I’ve reformatted the code a bit to keep the lines short. You can copy and paste all of that in the Clojure REPL, and start looking at some strings in a new way:

user=> (character-lines "résumé")
("00000000: U+000072 LATIN SMALL LETTER R" 
"00000000: U+0000E9 LATIN SMALL LETTER E WITH ACUTE" 
"00000000: U+000073 LATIN SMALL LETTER S" 
"00000000: U+000075 LATIN SMALL LETTER U" 
"00000000: U+00006D LATIN SMALL LETTER M" 
"00000000: U+0000E9 LATIN SMALL LETTER E WITH ACUTE")

But we are still missing the actual offsets. Let’s fix that now.

Read more →