Merge branch 'main' into ai-refactoring

This commit is contained in:
Nathan Sobo 2023-08-29 10:17:01 -06:00
commit 84b9c22170
4 changed files with 149 additions and 58 deletions

4
Cargo.lock generated
View file

@ -4275,9 +4275,9 @@ dependencies = [
[[package]] [[package]]
name = "memchr" name = "memchr"
version = "2.5.0" version = "2.6.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "2dffe52ecf27772e601905b7522cb4ef790d2cc203488bbd0e2fe85fcb74566d" checksum = "76fc44e2588d5b436dbc3c6cf62aef290f90dab6235744a93dfe1cc18f451e2c"
[[package]] [[package]]
name = "memfd" name = "memfd"

View file

@ -8,7 +8,7 @@ use alacritty_terminal::{
event::{Event as AlacTermEvent, EventListener, Notify, WindowSize}, event::{Event as AlacTermEvent, EventListener, Notify, WindowSize},
event_loop::{EventLoop, Msg, Notifier}, event_loop::{EventLoop, Msg, Notifier},
grid::{Dimensions, Scroll as AlacScroll}, grid::{Dimensions, Scroll as AlacScroll},
index::{Column, Direction as AlacDirection, Line, Point}, index::{Boundary, Column, Direction as AlacDirection, Line, Point},
selection::{Selection, SelectionRange, SelectionType}, selection::{Selection, SelectionRange, SelectionType},
sync::FairMutex, sync::FairMutex,
term::{ term::{
@ -724,14 +724,13 @@ impl Terminal {
self.last_content.size, self.last_content.size,
term.grid().display_offset(), term.grid().display_offset(),
) )
.grid_clamp(term, alacritty_terminal::index::Boundary::Grid); .grid_clamp(term, Boundary::Grid);
let link = term.grid().index(point).hyperlink(); let link = term.grid().index(point).hyperlink();
let found_word = if link.is_some() { let found_word = if link.is_some() {
let mut min_index = point; let mut min_index = point;
loop { loop {
let new_min_index = let new_min_index = min_index.sub(term, Boundary::Cursor, 1);
min_index.sub(term, alacritty_terminal::index::Boundary::Cursor, 1);
if new_min_index == min_index { if new_min_index == min_index {
break; break;
} else if term.grid().index(new_min_index).hyperlink() != link { } else if term.grid().index(new_min_index).hyperlink() != link {
@ -743,8 +742,7 @@ impl Terminal {
let mut max_index = point; let mut max_index = point;
loop { loop {
let new_max_index = let new_max_index = max_index.add(term, Boundary::Cursor, 1);
max_index.add(term, alacritty_terminal::index::Boundary::Cursor, 1);
if new_max_index == max_index { if new_max_index == max_index {
break; break;
} else if term.grid().index(new_max_index).hyperlink() != link { } else if term.grid().index(new_max_index).hyperlink() != link {
@ -761,11 +759,34 @@ impl Terminal {
} else if let Some(word_match) = regex_match_at(term, point, &WORD_REGEX) { } else if let Some(word_match) = regex_match_at(term, point, &WORD_REGEX) {
let maybe_url_or_path = let maybe_url_or_path =
term.bounds_to_string(*word_match.start(), *word_match.end()); term.bounds_to_string(*word_match.start(), *word_match.end());
let original_match = word_match.clone();
let (sanitized_match, sanitized_word) =
if maybe_url_or_path.starts_with('[') && maybe_url_or_path.ends_with(']') {
(
Match::new(
word_match.start().add(term, Boundary::Cursor, 1),
word_match.end().sub(term, Boundary::Cursor, 1),
),
maybe_url_or_path[1..maybe_url_or_path.len() - 1].to_owned(),
)
} else {
(word_match, maybe_url_or_path)
};
let is_url = match regex_match_at(term, point, &URL_REGEX) { let is_url = match regex_match_at(term, point, &URL_REGEX) {
Some(url_match) => url_match == word_match, Some(url_match) => {
// `]` is a valid symbol in the `file://` URL, so the regex match will include it
// consider that when ensuring that the URL match is the same as the original word
if sanitized_match != original_match {
url_match.start() == sanitized_match.start()
&& url_match.end() == original_match.end()
} else {
url_match == sanitized_match
}
}
None => false, None => false,
}; };
Some((maybe_url_or_path, is_url, word_match)) Some((sanitized_word, is_url, sanitized_match))
} else { } else {
None None
}; };

View file

@ -31,7 +31,7 @@ use std::{
env, env,
ffi::OsStr, ffi::OsStr,
fs::OpenOptions, fs::OpenOptions,
io::Write as _, io::{IsTerminal, Write as _},
os::unix::prelude::OsStrExt, os::unix::prelude::OsStrExt,
panic, panic,
path::{Path, PathBuf}, path::{Path, PathBuf},
@ -635,8 +635,7 @@ async fn load_login_shell_environment() -> Result<()> {
} }
fn stdout_is_a_pty() -> bool { fn stdout_is_a_pty() -> bool {
std::env::var(FORCE_CLI_MODE_ENV_VAR_NAME).ok().is_none() std::env::var(FORCE_CLI_MODE_ENV_VAR_NAME).ok().is_none() && std::io::stdout().is_terminal()
&& unsafe { libc::isatty(libc::STDOUT_FILENO as i32) != 0 }
} }
fn collect_path_args() -> Vec<PathBuf> { fn collect_path_args() -> Vec<PathBuf> {

View file

@ -5,11 +5,29 @@ set -e
build_flag="--release" build_flag="--release"
target_dir="release" target_dir="release"
open_result=false open_result=false
local_only=false
overwrite_local_app=false
bundle_name=""
# Function for displaying help info
help_info() {
echo "
Usage: ${0##*/} [options] [bundle_name]
Build the application bundle.
Options:
-d Compile in debug mode and print the app bundle's path.
-l Compile for local architecture only and copy bundle to /Applications.
-o Open the resulting DMG or the app itself in local mode.
-f Overwrite the local app bundle if it exists.
-h Display this help and exit.
"
}
# If -o option is specified, the folder of the resulting dmg will be opened in finder # If -o option is specified, the folder of the resulting dmg will be opened in finder
# If -d is specified, Zed will be compiled in debug mode and the application's path printed # If -d is specified, Zed will be compiled in debug mode and the application's path printed
# If -od or -do is specified Zed will be bundled in debug and the application will be run. # If -od or -do is specified Zed will be bundled in debug and the application will be run.
while getopts 'od' flag while getopts 'dlfoh' flag
do do
case "${flag}" in case "${flag}" in
o) open_result=true;; o) open_result=true;;
@ -17,9 +35,21 @@ do
build_flag=""; build_flag="";
target_dir="debug" target_dir="debug"
;; ;;
l) local_only=true;;
f) overwrite_local_app=true;;
h)
help_info
exit 0
;;
esac esac
done done
shift $((OPTIND-1))
if [ "$1" ]; then
bundle_name=$1
fi
export ZED_BUNDLE=true export ZED_BUNDLE=true
export MACOSX_DEPLOYMENT_TARGET=10.15.7 export MACOSX_DEPLOYMENT_TARGET=10.15.7
@ -33,14 +63,24 @@ rustup target add wasm32-wasi
# Deal with versions of macOS that don't include libstdc++ headers # Deal with versions of macOS that don't include libstdc++ headers
export CXXFLAGS="-stdlib=libc++" export CXXFLAGS="-stdlib=libc++"
echo "Compiling zed binary for aarch64-apple-darwin" version_info=$(rustc --version --verbose)
cargo build ${build_flag} --package zed --target aarch64-apple-darwin host_line=$(echo "$version_info" | grep host)
echo "Compiling zed binary for x86_64-apple-darwin" local_target_triple=${host_line#*: }
cargo build ${build_flag} --package zed --target x86_64-apple-darwin
echo "Compiling cli binary for aarch64-apple-darwin" if [ "$local_only" = true ]; then
cargo build ${build_flag} --package cli --target aarch64-apple-darwin echo "Building for local target only."
echo "Compiling cli binary for x86_64-apple-darwin" cargo build ${build_flag} --package zed
cargo build ${build_flag} --package cli --target x86_64-apple-darwin cargo build ${build_flag} --package cli
else
echo "Compiling zed binary for aarch64-apple-darwin"
cargo build ${build_flag} --package zed --target aarch64-apple-darwin
echo "Compiling zed binary for x86_64-apple-darwin"
cargo build ${build_flag} --package zed --target x86_64-apple-darwin
echo "Compiling cli binary for aarch64-apple-darwin"
cargo build ${build_flag} --package cli --target aarch64-apple-darwin
echo "Compiling cli binary for x86_64-apple-darwin"
cargo build ${build_flag} --package cli --target x86_64-apple-darwin
fi
echo "Creating application bundle" echo "Creating application bundle"
pushd crates/zed pushd crates/zed
@ -50,27 +90,34 @@ sed \
-i .backup \ -i .backup \
"s/package.metadata.bundle-${channel}/package.metadata.bundle/" \ "s/package.metadata.bundle-${channel}/package.metadata.bundle/" \
Cargo.toml Cargo.toml
app_path=$(cargo bundle ${build_flag} --target x86_64-apple-darwin --select-workspace-root | xargs)
if [ "$local_only" = true ]; then
app_path=$(cargo bundle ${build_flag} --select-workspace-root | xargs)
else
app_path=$(cargo bundle ${build_flag} --target x86_64-apple-darwin --select-workspace-root | xargs)
fi
mv Cargo.toml.backup Cargo.toml mv Cargo.toml.backup Cargo.toml
popd popd
echo "Bundled ${app_path}" echo "Bundled ${app_path}"
echo "Creating fat binaries" if [ "$local_only" = false ]; then
lipo \ echo "Creating fat binaries"
-create \ lipo \
target/{x86_64-apple-darwin,aarch64-apple-darwin}/${target_dir}/Zed \ -create \
-output \ target/{x86_64-apple-darwin,aarch64-apple-darwin}/${target_dir}/Zed \
"${app_path}/Contents/MacOS/zed" -output \
lipo \ "${app_path}/Contents/MacOS/zed"
-create \ lipo \
target/{x86_64-apple-darwin,aarch64-apple-darwin}/${target_dir}/cli \ -create \
-output \ target/{x86_64-apple-darwin,aarch64-apple-darwin}/${target_dir}/cli \
"${app_path}/Contents/MacOS/cli" -output \
"${app_path}/Contents/MacOS/cli"
fi
echo "Copying WebRTC.framework into the frameworks folder" echo "Copying WebRTC.framework into the frameworks folder"
mkdir "${app_path}/Contents/Frameworks" mkdir "${app_path}/Contents/Frameworks"
cp -R target/x86_64-apple-darwin/${target_dir}/WebRTC.framework "${app_path}/Contents/Frameworks/" cp -R target/${local_target_triple}/${target_dir}/WebRTC.framework "${app_path}/Contents/Frameworks/"
if [[ -n $MACOS_CERTIFICATE && -n $MACOS_CERTIFICATE_PASSWORD && -n $APPLE_NOTARIZATION_USERNAME && -n $APPLE_NOTARIZATION_PASSWORD ]]; then if [[ -n $MACOS_CERTIFICATE && -n $MACOS_CERTIFICATE_PASSWORD && -n $APPLE_NOTARIZATION_USERNAME && -n $APPLE_NOTARIZATION_PASSWORD ]]; then
echo "Signing bundle with Apple-issued certificate" echo "Signing bundle with Apple-issued certificate"
@ -99,31 +146,55 @@ if [ "$target_dir" = "debug" ]; then
exit 0 exit 0
fi fi
dmg_target_directory="target/${target_dir}" if [ "$local_only" = true ]; then
dmg_source_directory="${dmg_target_directory}/dmg" # If bundle_name is not set or empty, use the basename of $app_path
dmg_file_path="${dmg_target_directory}/Zed.dmg" if [ -z "$bundle_name" ]; then
bundle_name=$(basename "$app_path")
else
# If bundle_name doesn't end in .app, append it
if [[ "$bundle_name" != *.app ]]; then
bundle_name="$bundle_name.app"
fi
fi
echo "Creating DMG" if [ "$overwrite_local_app" = true ]; then
rm -rf ${dmg_source_directory} rm -rf "/Applications/$bundle_name"
mkdir -p ${dmg_source_directory} fi
mv "${app_path}" "${dmg_source_directory}" mv "$app_path" "/Applications/$bundle_name"
ln -s /Applications ${dmg_source_directory} if [ "$open_result" = true ]; then
hdiutil create -volname Zed -srcfolder "${dmg_source_directory}" -ov -format UDZO "${dmg_file_path}" open "/Applications/$bundle_name"
# If someone runs this bundle script locally, a symlink will be placed in `dmg_source_directory`. else
# This symlink causes CPU issues with Zed if the Zed codebase is the project being worked on, so we simply remove it for now. echo "Installed application bundle:"
rm ${dmg_source_directory}/Applications echo "/Applications/$bundle_name"
fi
else
echo "Creating DMG"
dmg_target_directory="target/${target_dir}"
dmg_source_directory="${dmg_target_directory}/dmg"
dmg_file_path="${dmg_target_directory}/Zed.dmg"
echo "Adding license agreement to DMG" rm -rf ${dmg_source_directory}
npm install --global dmg-license minimist mkdir -p ${dmg_source_directory}
dmg-license script/eula/eula.json "${dmg_file_path}" mv "${app_path}" "${dmg_source_directory}"
if [[ -n $MACOS_CERTIFICATE && -n $MACOS_CERTIFICATE_PASSWORD && -n $APPLE_NOTARIZATION_USERNAME && -n $APPLE_NOTARIZATION_PASSWORD ]]; then ln -s /Applications ${dmg_source_directory}
echo "Notarizing DMG with Apple" hdiutil create -volname Zed -srcfolder "${dmg_source_directory}" -ov -format UDZO "${dmg_file_path}"
npm install -g notarize-cli # If someone runs this bundle script locally, a symlink will be placed in `dmg_source_directory`.
npx notarize-cli --file "${dmg_file_path}" --bundle-id dev.zed.Zed --username "$APPLE_NOTARIZATION_USERNAME" --password "$APPLE_NOTARIZATION_PASSWORD" # This symlink causes CPU issues with Zed if the Zed codebase is the project being worked on, so we simply remove it for now.
fi rm ${dmg_source_directory}/Applications
if [ "$open_result" = true ]; then echo "Adding license agreement to DMG"
open $dmg_target_directory npm install --global dmg-license minimist
dmg-license script/eula/eula.json "${dmg_file_path}"
if [[ -n $MACOS_CERTIFICATE && -n $MACOS_CERTIFICATE_PASSWORD && -n $APPLE_NOTARIZATION_USERNAME && -n $APPLE_NOTARIZATION_PASSWORD ]]; then
echo "Notarizing DMG with Apple"
npm install -g notarize-cli
npx notarize-cli --file "${dmg_file_path}" --bundle-id dev.zed.Zed --username "$APPLE_NOTARIZATION_USERNAME" --password "$APPLE_NOTARIZATION_PASSWORD"
fi
if [ "$open_result" = true ]; then
open $dmg_target_directory
fi
fi fi