Blog

APT8: Apps und Backup

 

 

Neulich war ich leider der verwerflichen Meinung, dass es viel Interessanter sein könnte, das neue iOS 5 zu installieren, als meine Zeit mit sinnvollem Programmieren zu verschwenden. Hier muss gesagt werden, dass es sich um die „Golden Master“ Version handelt. Ein Begriff, den ich immer glaubte erfunden zu haben – aber auch Apple bezeichnet damit die letzte Version vor einem Release – sozusagen die Testweise Release-Version.

Gesagt, getan, „Do you really want to …“ wird man noch gefragt, es werden ja alle Daten gelöscht, wenn man die Test-Version installiert, aber davor hat man ja wenig Angst, es ist ja alles in einem Backup gespeichert. Allerdings hatte ich das vor sooo vielen Monaten zuletzt gemacht, dass ich etwas zögerte, bevor ich es tat.

Leider ging die Installation schief, ich hatte vergessen, vorher das richtige XCode an zu werfen, Denn die IOS 5 GM-Version funktionierte nicht mit der gerade laufenden Xcode 4.1-Version. Klasse. das iPhone war im Embryonal-Zustand, mir lief die Zeit davon, meine Verabredung würde mich bald erwarten und ich konnte nicht mal anrufen um Bescheid zu sagen, es würde vielleicht später werden… Also: iPhone so schnell wie möglich wieder gesund machen – egal wie!

Kurze Überlegung – jetzt lieber keine Experimente mehr, kein iOS 5, sondern wieder die „alte“ Version 4.3.5 aufspielen. Risikomanagement, wenn auch kein Gutes, weil ja nur noch Schadensbegrenzung.
Eigentlich wollte ich schreiben, „schnell wieder die alte Version installiert“, aber das dauerte alles so lange, da war nur der Entschluss zum Installieren schnell. Ich sah vor meinem Inneren Auge, wie meine Verabredung am Tisch im Restaurant saß und ein ums andere mal dem Kellner sagen musste, nein, ich esse noch nicht…

Endlich war das Telefon wieder benutzbar, da machte ich den nächsten Fehler: Anstatt einfach im Computer die Telefonnummer rauszusuchen und im iPhone einzutippen um dann schnell los zu fahren, warf ich die Synchronisierung an, damit ich alle Telefonnummern und Apps wieder auf dem Telefon haben würde.

Das synchronisieren dauerte auch noch mal eine Weile, denn ich habe zwar nur sehr wenig Musik und sonstiges auf dem iPhone, aber zu Test-Zwecken der App war ja noch das Hörbuch von Charlotte Roche „Schoßgebete“ drauf und die neue Platte von Feist wollte auch synchronisiert werden. Die Zeit rinnt, dann, Endlich fertig, schnell anrufen, ja, ich komme etwas später, Rechner runter fahren und los!

– Leider war die Geschichte hier noch nicht ganz zu ende…

Nun bin ich ja App Entwickler – und auf eine App die ich veröffentliche, kommen ca. vier Apps, die ich nicht veröffentliche, sondern nur zu Testzwecken programmiert habe, oder wo ich glaube, dass es sich nicht lohnt, diese App zu veröffentlichen.

Das Treffen war mit einem langjährigen Freund, den ich ca. ein Jahr nicht mehr gesehen hatte. Wir plauderten über dies und jenes, irgendwann will ich ihm eine meiner Apps zeigen, hole das iPhone raus, wische vom ersten Bildschirm mit den Apps zum nächsten, zum dritten und … entsetzen !

Mich starrte die leere von meinem iPhone an. Der Erste Bildschirm noch voller Apps, der zweite leer bis auf eine App, der dritte noch zwei… Wo zum Teufel sind alle meine Apps ??? Wieso sind nur die gekauften Apps wieder aus dem Backup eingespielt worden???

Was ich nicht bedacht hatte, ist, dass alle meine selbst-entwickelten und lokal installierten Apps auch alle gelöscht sind. Und leider, leider, leider nicht im Apple Backup landen. Warum auch immer. Ich wusste es ja eigentlich, hatte es nur vergessen.

Was mich in dem Moment am meisten wurmte: Taschengeld, eine der Apps, die ich seit der Entwicklung immer mal wieder benötige war auch nicht mehr da. Schliesslich führe ich so Buch, welches Kind wann Taschengeld von mir bekommen hat. Und jetzt? Einfach Computer hochfahren, iPhone mit meiner Taschengeld App neu bespielen und …fertig? Oder einfach meine eigene App selber kaufen?

So komisch es klingt, damit ich beim nächsten mal meine eigene App auch im Backup wieder eingespielt bekomme, wähle ich, meine eigene App selber zu kaufen. Einen Moment lang überlege ich noch, ob ich die App mal eben einen Tag lang umsonst anbieten sollte um mir die 31 Cent, die Apple in Deutschland vom Entwickler-Verdienst abzieht (79-48=31) auch zu sparen, aber das ist zu viel Arbeit für meine Ungeduld, ich kaufe, lade runter…

Und bin Überrascht!

Alle meine Daten sind da! Wann welches meiner Kinder Taschengeld bekommen hat, alles da. Eigentlich ja kein Wunder, hatte ich es doch so programmiert, dass die Daten eine Neuinstallation einer Version überstehen würden. HATTE ICH NUR NICHT ERWARTET, DASS DIE DATEN IM BACKUP SIND, ABER NICHT DIE APP. Na gut, wunderbar, Apple ist gut, meine App ist gut und mein einer Sohn hat noch sein Taschengeld für diesem Monat zu bekommen.

…NA WENN DAS KEIN HAPPY END IST!

Hier geht‘s zum „Liken“

Hier ist jetzt der Like Button gelandet, für die, die uns mögen und das uns und der Welt auf Facebook zeigen wollen – neudeutsch „liken“ wollen.

Für alle anderen, sorry, wenn Ihr das hier lest weiß Facebook das schon.

Irgendwie finde ich das eine gute Lösung: Liken geht, aber Datenschutz ist trotzdem möglich. Gefällt Euch die Lösung? Dann zeigt es uns!

APT7: Objective-C Style Guide

Ich bin ja selber kein großer Freund von Regeln, wie man zu programmieren hat, auch Coding Conventions genannt. Insbesondere, weil ich in verschiedenen Programmiersprachen und über die vielen Jahre hinweg so viele verschiedene Coding Styles kennen gelernt habe.

Da ich meinen Source Code aber immer öfter an andere Leute übergebe, die ihn dann gut und leicht lesbar finden sollen, hier meine eigenen Coding conventions, an die ich mich versuchen werde zu halten:

– Classes start with upper case letter
– Variables start with lower case letter
– init methods (all methods that have an „init“ in their name) have return type id
– Class and Factory methods (all methods that have a „+“ before them) have return type id
– all method calls need to be checked for return value
– always have a dealloc function and release all properties in it
– initialize all variables
– if a Class has a factory method (e.g.: + (id)Array), then check if your are allowed to use init
– Always read the Overview Part of the Class you are using
– put the stars „*“ to the variable name
– generate a nice looking indenting for Variables, e.g. in Xcode use I to do correct indenting

Ich hoffe, jetzt machen wir alle tolle Programme.

(Segel)-Regattakalender

 

Wer Regatta segelt, der kennt das: Meist ist die Regatta-Saison gut geplant und jede Regatta im Vorfeld bekannt. Und dennoch liegen die Regatten immer mal wieder anders, eine Regatta wird abgesagt oder der Vorschoter hat doch keine Zeit. Dann muss man neu planen – oft ist man dann gerade am Wasser. Wenn man dann immer den Regattakalender dabei haben könnte!

Mit der kostenlosen Regattakalender App, kann man sich jederzeit die Regatten eines Reviers ansehen und sich so spontan entschließen, die eigene Saisonplanung zu ändern.

Derzeit unterstützte Reviere: Berlin (alle Reviere), Brandenburg und Bodensee.
In Berlin sind sogar die Links auf die Homepages der Vereine eingearbeitet – damit man schneller an die letzten Neuigkeiten herankommt!

Für Andere Reviere nehme ich gerne Hinweise und Regatta-Kalender-Links unter Thomas.patzelt@small-apps.com entgegen. Mal sehen, ob sich einer meldet – das wäre schön.

Für alle, die überlegen, sich doch noch spontan zu einer Regatta zu melden: Jetzt gibt es keine Ausreden mehr, jetzt kannst Du es!

Auf dass sich viele Segler (spontan) entschließen, zur Regatta zu melden und alle Regatten gut besucht werden!

Danke an alle fleißigen Regatta-Veranstalter! Danke auch an alle, die die Regattalisten zusammenstellen!!! Ohne Eure tolle Arbeit gäbe es keine Regatten, keine Regattalisten und auch diese App nicht. DANKE !

Also, Mast- und Schotbruch und immer eine Handbreit Wasser unterm Kiel!
Ahoi, Euer Thomas, Small Apps UG,
Mitglied im SC Ahoi Berlin, Revier Berlin Wannsee und Unterhavel.

p.s.: Für die Zukunft wünsche ich mir, dass wir die Formatierung verbessern und dass wir die Meldeadressen der Vereine nach und nach in die Datenbank aufnehmen können, dann könnte man als Segler mit ein paar mal tippen zu einer Regatta melden. Leider ist das viel Arbeit und wir verdienen ja nichts mit der App, so wird es noch ein bisschen dauern, habt bitte solange Geduld…

APT6: Backup failed, Error 11

Time Machine ist schon ein geniales Programm mit einer Tollen, intuitiven Oberfläche. Auf dem Foto sieht man sie.

Ich habe normalerweise sehr viel Freude an Time Machine, aber manchmal ärgert es mich. So geschehen im Oktober 2010, und so schon öfter mal geschehen, wenn es rumnörgelte – zum letzten Mal gestern. Doch der Reihe nach.

Der Grund, warum auf dem Foto oben nur Oktober 2010 als ältestes Backup steht und nicht etwa August 2009, wie es eigentlich davor war, lag daran, dass Time Machine überhaupt nicht damit klar kam, dass ich eine neue Festplatte im Rechner hatte – die alte Festplatte war schlicht voll geworden. Ich hätte mich erinnern müssen, dass Time Machine das nicht mag – entweder, weil mein neues Dateisystem diesmal Groß-Kleinschreibung unterschied, oder generell, weil Time Machine die Back-ups unter einer Platten-ID speichert. Ob es auch einen Weg um diese Probleme herum gibt, weiß ich nicht, ich hatte jedenfalls nicht danach gesucht und war daher in die Falle getappt.

Ein Umzug auf eine neue Festplatte (mein dritter Umzug) ist ja unter MAC OS X sehr einfach. Kaum war er erledigt, legte Time Machine los. Leider ohne, dass ich mitbekam, was ablief: Denn Time Machine wollte ein Full Back-up machen und die Back-up-Festplatte hatte nicht mehr genug freien Speicher. Daher löschte Time Machine erst mal alle alten Back-ups, in der Hoffnung, genug platz zu finden. Das tat es dann auch schließlich – als nur noch wenige Tage Back-up übrig waren.

Zwischendurch fragte es mich um Erlaubnis – und ich sagte dummerweise auch noch ja… Als ich merkte, was vor sich ging, da waren die alten Back-ups schon weg. Blöd gelaufen. Gut dass ich noch andere Back-ups an einer anderen Stelle mache. Also: Back-up komplett löschen (der eine Tag kostet auch nur Platz) und neu angefangen.

Seitdem lief es aber rund. Gestern stellte ich fest, dass ein anderer Rechner Probleme mit Back-up hatte – immer wieder brach das Back-up mit dem Fehler: Back-up failed with error 11 (oder so ähnlich) ab. Und das seit Tagen.

Time Machine empfahl die Überprüfung des Back-up-Laufwerks auf Fehler. Gute Idee, brachte aber nichts, Time Machine scheiterte wieder. Was tun?

Backup Fehler werden in der System-Konsole gespeichert. Also
Programme-> Dienstprogramme.-> Konsole.app
geladen. Dann Ablage-> Systemprotokoll öffnen ausgewählt und nach dem Fehler geguckt. Da wurde was von Problemen mit einer Datei unter /shared …. erzählt. Immer wieder. Also da mal hin und die Eigenschaften der Datei überprüft. Nichts besonderes. Außer: Da waren zwei Einträge in den Zugriffseigenschaften, die sahen komisch aus. „_spotlight: Special“ oder so. Ich erinnerte mich, dass ich den ganzen Dateibaum vor Wochen unter shared dahin kopiert hatte – von meinem Rechner aus.

Offensichtlich waren dabei komische Datei-Zugriffs-Rechte in den Eigenschaften entstanden und die jetzt vielleicht teil des Problems. Einfach mal alle komischen Eigenschaften im ganzen Dateibaum Löschen, brauchen tut sie eh keiner, es sind noch genügend gute Zugriffsrechte da. Back-up neu angestoßen. Problem gelöst.

Wie zum Teufel soll da einer drauf kommen, der nicht mindestens IT-Erfahrung oder gar ein Informatik-Studium hat.

Danke Apple, dass ich nie arbeitslos werde. 😉

Viel Spaß bei der Zeitreise! Gruß, Thomas

Das Team

 

 

Das Büro:
Es ist wunderbar. Mit toller Aussicht aus dem 7. Stock des Technologiezentrums in Teltow. Relativ leicht mit Öffentlichen zu erreichen.

Die Firma:
Small Apps ist gegründet worden, um kleine, mobile Applikationen zu veröffentlichen. UG steht übrigens für Unternehmergesellschaft, der offizielle Name für das, was der Volksmund Mini-GmbH nennt. Daher lautet der volle Firmenname auch Small Apps UG (haftungsbeschränkt).

Die Mission:
Wir erzeugen kleine und große Programme für iPhone, iPad und iPod oder für Android-Geräte. Für uns oder für Sie, auf eigene Rechnung oder in Ihrem Auftrag. Wir liefern und können von der Anforderungsanalyse (Requirements Engineering) bis zum fertigen Produkt im App Store alles.

Thomas:
Diplom Informatiker, Gründer. Programmierer, Projektleiter, CEO und Besitzer von Small Apps. Hat seit 2008 Erfahrung mit Apple und iPhone Programmierung – länger geht kaum. Mehrere Apps und geniale Lösungen gehen auf sein Konto. Und alle Applikationen auch mindestens einmal durch seine Hände – bisher war das auch immer besser so.

Nicolas:
Freiberuflicher Mitarbeiter. Mitarbeiter Nummer 1 – wer kann das schon von sich sagen? Hat jetzt auch schon einige Erfahrung in iPhone Programmierung – und zwei Applikation draußen.

Niels:
Freiberuflicher Mitarbeiter. Genau: Mitarbeiter Nummer 2. Hat fast genau so viel Erfahrung wie Nicolas, auch wenn er noch keine Applikation am Start hat.

Oliver:
Macht Praktikum bei uns und leistet gute Arbeit. Programmiert für Android und das schon ziemlich klasse. Erst heute habe ich wieder was von ihm gelernt – und er von mir. So soll es sein!

Leonard:
Arbeitet sich ein, hat aber noch sehr bescheidene Ziele.

???:
Und wann fängst Du bei uns an?

Gruß, Thomas