Skip to content

Commit

Permalink
Add file associations support documentation (#5054)
Browse files Browse the repository at this point in the history
Docs for file associations support
(#4957) which
fixes #773.

---------

Co-authored-by: Aleksey Zamulla <[email protected]>
  • Loading branch information
zhelenskiy and zamulla authored Jul 2, 2024
1 parent c7b6403 commit 810745f
Showing 1 changed file with 57 additions and 0 deletions.
57 changes: 57 additions & 0 deletions tutorials/Native_distributions_and_local_execution/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -511,6 +511,63 @@ compose.desktop {
}
```

## File associations

File associations can be added using the `fileAssociation()` function.
These associations can optionally include custom icons.
Similar to the [app icon](#app-icon), these custom icons also must be provided in OS-specific formats: `.icns` for macOS, `.ico` for Windows and `.png` for Linux.

It is possible to specify both OS-specific and OS-agnostic file associations.
For OS-agnostic associations you can specify icon files for all three operating systems in-place,
while for OS-specific there is a shorthand with a single `iconFile` parameter.

```kotlin
compose.desktop {
application {
mainClass = "MainKt"

nativeDistributions {
targetFormats(TargetFormat.Dmg, TargetFormat.Msi, TargetFormat.Deb)

packageName = "file-associations-demo"
packageVersion = "1.0.0"

// macOS-specific associations for .kott and .ko files.
macOS {
fileAssociation(
mimeType = "text/kotlin",
extension = "kott",
description = "Kotlin Source File",
iconFile = project.file("Kotlin_icon_big.icns"),
)
fileAssociation(
mimeType = "text/kotlin",
extension = "ko",
description = "Kotlin Source File",
)
}

// OS-agnostic file association for .kot files, with icons for all three operating systems.
fileAssociation(
mimeType = "text/kotlin",
extension = "kot",
description = "Kotlin Source File",
macOSIconFile = project.file("Kotlin_icon_big.icns"),
windowsIconFile = project.file("Kotlin_icon_big.ico"),
linuxIconFile = project.file("Kotlin_icon_big.png"),
)

// OS-agnostic file association for .kottt files, without icons.
fileAssociation(
mimeType = "text/kotlin",
extension = "kottt",
description = "Kotlin Source File",
)
}
}
}
```

## Customizing Info.plist on macOS

We aim to support important platform-specific customization use-cases via declarative DSL.
Expand Down

0 comments on commit 810745f

Please sign in to comment.