Auto Launch

Auto launch any application or executable at startup. Supports Windows, Mac (via AppleScript or Launch Agent), and Linux.

As for how does it work, see here for details.

If you find any bugs, welcome to PR or issue.

Usage

The parameters of AutoLaunch::new are different on each platform. See the function definition or the demo below for details.

Linux

On Linux, it supports hidden parameter which means that hidden the app on launch.

```rust use auto_launch::AutoLaunch;

fn main() { let appname = "the-app"; let apppath = "/path/to/the-app"; let auto = AutoLaunch::new(appname, apppath, false);

// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();

// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();

} ```

Macos

Macos supports two ways to achieve auto launch (via AppleScript or Launch Agent). When the use_launch_agent is true, it will achieve by Launch Agent, otherwise by AppleScript. On Macos, it supports hidden parameter which means that hidden the app on launch.

Note:

```rust use auto_launch::AutoLaunch;

fn main() { let appname = "the-app"; let apppath = "/path/to/the-app.app"; let auto = AutoLaunch::new(appname, apppath, false, false);

// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();

// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();

} ```

Windows

On Windows, it will add a registry entry under \HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\Run.

```rust use auto_launch::AutoLaunch;

fn main() { let appname = "the-app"; let apppath = "C:\path\to\the-app.exe"; let auto = AutoLaunch::new(appname, apppath);

// enable the auto launch
auto.enable().is_ok();
auto.is_enabled().unwrap();

// disable the auto launch
auto.disable().is_ok();
auto.is_enabled().unwrap();

} ```

License

MIT License. See the License file for details.

Acknowledgement

The project is based on node-auto-launch.