Esto es factible, pero probablemente no sea tan sencillo como podría pensar. Tendrá que familiarizarse con los identificadores de tipo uniforme. Mire la página Identificador de tipo uniforme de Wikipedia
.
OS X almacena información sobre asociaciones de archivos preferidos en un archivo de preferencias con el nombre com.apple.LaunchServices.plist
. Antes de que intente buscar y modificar ese archivo, le sugiero que se familiarice con la jerarquía de dominios de OS X para los valores predeterminados (a.k.a. "configuración"). Puede encontrar un artículo decente sobre esto aquí . (Descargo de responsabilidad: parece que están vendiendo algo en ese sitio. No sé qué es y no tengo ninguna asociación con ellos, la explicación es buena.)
Ahora que sabe todo acerca de los valores predeterminados y las IU (no del tipo médico), ahora podemos hablar sobre la configuración de asociaciones de archivos desde una línea de comandos / comandos.
Primero, deberá conocer la forma correcta de identificar los archivos para los que desea hacer una asociación.
¿Recuerdas cuando dije que las UTI eran importantes? Hay varias formas de identificar un archivo. Depende de si el tipo ha sido declarado formalmente en su sistema o no. Por ejemplo, los editores de texto decentes como TextMate o TextWrangler agregarán bastantes declaraciones de tipo a la jerarquía de tipos cuando las use en su sistema. Sin embargo, si no tiene esas aplicaciones, es posible que no tenga dichos tipos declarados.
OK, basta de hablar. Ejemplos:
Obtenga la UTI para un archivo:
$ mdls myFile.xml
...
kMDItemContentType = "public.xml"
kMDItemContentTypeTree = (
"public.xml",
"public.text",
"public.data",
"public.item",
"public.content"
)
...
Ok, genial. Un tipo de contenido explícito que podemos usar. Escribe eso en alguna parte.
$ mdls myFile.myExtn
...
kMDItemContentType = "dyn.ah62d4rv4ge8048pftb4g6"
kMDItemContentTypeTree = (
"public.data",
"public.item"
)
...
Uy. OS X no conoce los archivos ".myExtn". Entonces, creó una UTI dinámica que no podemos usar para nada. Y los tipos principales son demasiado genéricos para ser útiles.
Ahora que sabemos cuáles son nuestros archivos, veamos el archivo LaunchServices.plist y veamos qué podemos hacer:
$defaults read com.apple.LaunchServices
{
...
LSHandlers = (
{
LSHandlerContentType = "public.html";
LSHandlerRoleAll = "com.apple.safari";
LSHandlerRoleViewer = "com.google.chrome";
},
...
{
LSHandlerContentTag = myExtn;
LSHandlerContentTagClass = "public.filename-extension";
LSHandlerRoleAll = "com.macromates.textmate";
},
...
);
...
}
Entonces, cuando tienes un tipo de contenido "bueno" para usar, la primera construcción es mejor. De lo contrario la otra construcción. Tenga en cuenta que hay otras construcciones en ese archivo, pero no son relevantes para lo que pidió. Solo debes saber que están ahí cuando miras a través de la salida.
Como puede ver, deberá encontrar la UTI para la aplicación que desea usar. Las UTI para Safar y TextMate están en mi ejemplo anterior, pero para encontrar de manera genérica la UTI para una aplicación:
$ cd /Applications/MyApp.app/Contents
$ less Info.plist
...
<key>CFBundleIdentifier</key>
<string>com.apple.Safari</string>
...
NOTA: No tengo ninguna idea de lo que constituye la diferencia entre LSHandlerRoleAll y LSHandlerRoleViewer. No puedo encontrar documentación sobre eso en ninguna parte. Lo que hago veo es que el 99% del tiempo LSHandlerRoleAll es el único conjunto (es decir, no hay ningún LSHandlerRoleViewer) y que está configurado a la UTI para la aplicación que desea asociar. escribe con.
Después de llevarte tan lejos, voy a dejar CÓMO establecer los valores que deseas como un ejercicio para el lector. Jugar con estas cosas puede ser algo peligroso. Es completamente posible que arruines un archivo y no tengas ninguna de tus asociaciones de archivos funcionando. Luego tienes que tirar el archivo y comenzar de nuevo.
Algunos consejos:
- Lee sobre
defaults write
y su sintaxis
- Echa un vistazo a
PlistBuddy
. man PlistBuddy
y /usr/libexec/PlistBuddy -h
- Omita todas estas tonterías y use RCDefaultApp