summaryrefslogtreecommitdiff
path: root/docs/libraries/apps.md
blob: 6853996eaedabac09920e3e584a0670092e837af (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# Apps

Library and CLI tool for querying and launching
applications that have a corresponding `.desktop` file.

## Installation

1. install dependencies

:::code-group

```sh [<i class="devicon-archlinux-plain"></i> Arch]
sudo pacman -Syu meson vala json-glib gobject-introspection
```

```sh [<i class="devicon-fedora-plain"></i> Fedora]
sudo dnf install meson gcc valac json-glib-devel gobject-introspection-devel
```

```sh [<i class="devicon-ubuntu-plain"></i> Ubuntu]
sudo apt install meson valac libjson-glib-dev gobject-introspection
```

:::

2. clone repo

```sh
git clone https://github.com/aylur/astal.git
cd astal/lib/apps
```

3. install

```sh
meson setup build
meson install -C build
```

:::tip
Most distros recommend manual installs in `/usr/local`,
which is what `meson` defaults to. If you want to install to `/usr`
instead which most package managers do, set the `prefix` option:

```sh
meson setup --prefix /usr build
```

:::

## Usage

You can browse the [Apps reference](https://aylur.github.io/libastal/apps).

### CLI

```sh
astal-apps --help
```

### Library

:::code-group

```js [<i class="devicon-javascript-plain"></i> JavaScript]
import Apps from "gi://AstalApps";

const apps = new Apps.Apps({
  includeEntry: true,
  includeExecutable: true,
});

print(apps.fuzzy_query("spotify")
    .map(app => app.name)
    .join("\n"))

```

```py [<i class="devicon-python-plain"></i> Python]
import gi

gi.require_version("AstalApps", "0.1")

from gi.repository import AstalApps

apps = AstalApps.Apps(include_entry = True, include_executable = True )

match = apps.fuzzy_query("obsidian")
print("\n".join(app.get_name() for app in match))
```

```lua [<i class="devicon-lua-plain"></i> Lua]
local lgi = require("lgi")

local AstalApps = lgi.require("AstalApps", "0.1")

local apps = AstalApps.Apps({
	include_entry = true,
	include_executable = true,
})

local match = apps:fuzzy_query("lutris")

for _, app in ipairs(match) do
	print(app.name)
end
```

```vala [<i class="devicon-vala-plain"></i> Vala]
// Not yet documented, contributions are appreciated
```

:::

:::info
The fuzzy query uses [Levenshtein distance](https://en.wikipedia.org/wiki/Levenshtein_distance). I am not a mathematician, but if you know how to reimplement
the logic of [fzf](https://github.com/junegunn/fzf) to make it better feel free to open PRs.
:::