As far as I know (and read everywhere) an application's documents directory should be somewhere in /var/mobile/Library/
on the iPhone but if I'm logging the gotten directory it is /var/mobile/Documents
.
I get the directory as follows:
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
is this a problem if I'm creating a file named Settings.xml
in here or is something wrong with my app/etc.?
Information: I've a jailbroken iPhone 4 with iOS 4.2.1 and my app gets installed via Cydia or SSH.
Update
Yeah, but that directory is not really related to my application. For example I am creating a document settings.xml and what if another application uses the same NSDocumentDirectory and the same file name? And yes, I know. Cydia apps got installed into /Applications but there should be a document directory for my app too and not even /var/mobile/Documents. If you take a look at http://thebigboss.org/hosting-repository/submit-your-app/compile-for-cydia-submission the directory should be /var/mobile/Library/ but as I described before, I never get this directory.
All files created by your application will be limited to the app sandbox (e.g. /var/stash/Applications/AppName. When you look for the file, settings.xml, you can get the filePath name using the code example from above.
Storing the file outside your sandbox would not be recommended.
Using the constant
NSDocumentDirectory
will in fact get you /var/mobile/Documents when running a jailbreak app. It would be bad policy to dump your app's documents directly in there, even if you think they're named uniquely.If you look at the contents of the /var/mobile/Library/ folder, you'll see that many apps have their data stored there, including jailbreak apps. It's not clear to me whether there's a handy constant like
NSDocumentDirectory
that you can use to get that. But, you can always hardcode your source to look for files in@"/var/mobile/Library/APPNAME"
. It's unlikely that this folder will change (and if it does, it's probably going to break other apps, and is certainly an easy fix to make).If you look at the document you link to, it does specify:
... so you need to create that subdirectory yourself. It won't be there if you don't.
In my experience, writing jailbreak apps simply involves some of these slightly stinky coding practices (hardcoding paths and creating them ourselves) ... it might just be something we have to deal with.
Update: make sure to see Saurik's comment below.
Some Cydia binaries are installed into
/private/var/lib/
(like apt-get, openssh, etc). Others are installed into/Applications/
(like Cydia.app, games, etc).I am suffering with this issue too... I haven't find out what is happening yet, so I've accepted to work at /var/mobile/Documents. However, I've had to create that directory manually in my device (via ssh or mobile terminal) and set its permissions to 666 [chmod -r 777 /var/mobile/Documents] to let my app save and load files there.
See you!
Use your bundle ID as a name, for example com.companyname.appname.Settings.xml. They are rarely the same in different apps. Also you may use UUIDs to name your file and store the UUID that's in the name in the application bundle, but it has its pros and cons: Pro: File never gets overwritten by another app Con: It will be tricky to do such thing.
What you do is on app start, you check if the file you want in the docs dir exists, and if it doesn't, you copy it there from your read-only application bundle. Each successive time you launch the app, it's there. And, if for some stupid reason apple ever changes it, you don't have to adjust your code, since it's versatile enough to adapt to the change. It'll copy over the original data into the new location (which isn't optimal, but it's better than assuming it's in a static location, which would cause all sorts of confusion amongst your users, or worse: a crash).