diff options
author | johalun <johalun0@gmail.com> | 2017-01-12 13:16:09 -0800 |
---|---|---|
committer | Joe Wilm <jwilm@users.noreply.github.com> | 2017-01-18 22:28:16 -0800 |
commit | 398e31fa3789f0574a6ff679742dfb7639984e12 (patch) | |
tree | 534eac678766a748c6b3543da8ba448c3018ea24 | |
parent | a2cd4b647c1058c3012348774481ade30dddd601 (diff) | |
download | alacritty-398e31fa3789f0574a6ff679742dfb7639984e12.tar.gz alacritty-398e31fa3789f0574a6ff679742dfb7639984e12.zip |
Make it run on FreeBSD
-rw-r--r-- | README.md | 14 | ||||
-rw-r--r-- | copypasta/src/lib.rs | 5 | ||||
-rw-r--r-- | src/config.rs | 3 | ||||
-rw-r--r-- | src/tty.rs | 6 |
4 files changed, 18 insertions, 10 deletions
@@ -50,9 +50,9 @@ will walk you through how to build from source on both macOS and Ubuntu. ```sh rustup override set nightly ``` - + If you run into problems, you can try a known-good version of the compiler by running - + ```sh rustup override set $(<rustc-version) ``` @@ -107,6 +107,16 @@ On [Void Linux](https://voidlinux.eu), install following packages before compili xbps-install cmake freetype-devel freetype expat-devel fontconfig xclip ``` +##### FreeBSD + +On FreeBSD, you need a few extra libraries to build Alacritty. Here's a `pkg` +command that should install all of them. If something is still found to be +missing, please open an issue. + +```sh +pkg install cmake freetype2 fontconfig xclip +``` + ##### Other If you build Alacritty on another Linux distribution, we would love some help diff --git a/copypasta/src/lib.rs b/copypasta/src/lib.rs index b498e2e9..828c23bd 100644 --- a/copypasta/src/lib.rs +++ b/copypasta/src/lib.rs @@ -40,13 +40,12 @@ pub trait Store : Load { where S: Into<String>; } -#[cfg(target_os = "linux")] +#[cfg(any(target_os = "linux", target_os = "freebsd"))] mod x11; -#[cfg(target_os = "linux")] +#[cfg(any(target_os = "linux", target_os = "freebsd"))] pub use x11::{Clipboard, Error}; #[cfg(target_os = "macos")] mod macos; #[cfg(target_os = "macos")] pub use macos::{Clipboard, Error}; - diff --git a/src/config.rs b/src/config.rs index 2665c3b3..e9173f6c 100644 --- a/src/config.rs +++ b/src/config.rs @@ -1100,7 +1100,7 @@ impl Default for Font { } } -#[cfg(target_os = "linux")] +#[cfg(any(target_os = "linux",target_os = "freebsd"))] impl Default for Font { fn default() -> Font { Font { @@ -1546,4 +1546,3 @@ impl Key { } } } - @@ -20,7 +20,7 @@ use std::fs::File; use std::os::unix::io::FromRawFd; use std::ptr; -use libc::{self, winsize, c_int, pid_t, WNOHANG, WIFEXITED, WEXITSTATUS, SIGCHLD}; +use libc::{self, winsize, c_int, pid_t, WNOHANG, WIFEXITED, WEXITSTATUS, SIGCHLD, TIOCSCTTY}; use term::SizeInfo; use display::OnResize; @@ -112,7 +112,7 @@ fn openpty(rows: u8, cols: u8) -> (c_int, c_int) { (master, slave) } -#[cfg(target_os = "macos")] +#[cfg(any(target_os = "macos",target_os = "freebsd"))] fn openpty(rows: u8, cols: u8) -> (c_int, c_int) { let mut master: c_int = 0; let mut slave: c_int = 0; @@ -138,7 +138,7 @@ fn openpty(rows: u8, cols: u8) -> (c_int, c_int) { /// Really only needed on BSD, but should be fine elsewhere fn set_controlling_terminal(fd: c_int) { let res = unsafe { - libc::ioctl(fd, libc::TIOCSCTTY as _, 0) + libc::ioctl(fd, TIOCSCTTY as _, 0) }; if res < 0 { |