
Should cut down on the number of CI cycles if you're forgetful like I am! Release Notes: - N/A
5.3 KiB
Extracting an extension to dedicated repo
These are some notes of how to extract an extension from the main zed repository and generate a new repository which preserves the history as best as possible. In the this example we will be extracting the ruby
extension, substitute as appropriate.
Pre-requisites
Install git-filter-repo:
brew install git-filter-repo
Process
We are going to use a $LANGNAME
variable for all these steps. Make sure it is set correctly.
Note
If you get
zsh: command not found: #
errors, run:setopt interactive_comments && echo "setopt interactive_comments" >> ~/.zshrc
- Create a clean clone the zed repository, delete tags and delete branches.
LANGNAME=your_language_name_here
rm -rf $LANGNAME
git clone --single-branch --no-tags git@github.com:zed-industries/zed.git $LANGNAME
cd $LANGNAME
- Create an expressions.txt file somewhere (e.g.
~/projects/$LANGNAME.txt
)
This file takes the form of patern==>replacement
, where the replacement is optional.
Note whitespace matters so ruby: ==>
is removing the ruby:
prefix from a commit messages and adding a space after ==>
means the replacement begins with a space. Regex capture groups are numbered \1
, \2
, etc.
See: Git Filter Repo Docs for more.
# Create regex mapping for rewriting commit messages (edit as appropriate)
mkdir -p ~/projects
echo "${LANGNAME}: ==>
extension: ==>
chore: ==>
zed_extension_api: ==>
"'regex:(?<![\[a-zA-Z0-9])(#[0-9]{3,5})==>zed-industries/zed\1' \
> ~/projects/${LANGNAME}.txt
# This removes the LICENSE symlink
git filter-repo --invert-paths --path extensions/$LANGNAME/LICENSE-APACHE
# This does the work
git filter-repo \
--use-mailmap \
--subdirectory-filter extensions/$LANGNAME/ \
--path LICENSE-APACHE \
--replace-message ~/projects/${LANGNAME}.txt
- Review the commits.
This is your last chance to make any modifications. If you don't fix it now, it'll be wrong forever.
For example, a previous commit message was php/ruby: bump version to 0.0.5
which was replaced with php/bump version to 0.0.5
so I added a new line to expressions.txt with php/==>
and next run it became bump version to 0.0.5
.
- [Optional] Generate tags
You can always add tags later, but it's a nice touch.
Show you all commits that mention a version number:
git log --grep="(\d+\.\d+\.\d+)" --perl-regexp --oneline --reverse
Then just:
git tag v0.0.2 abcd1234
git tag v0.0.3 deadbeef
Usually the initial extraction didn't mention a version number so you can just do that one manually.
-
[Optional] Add a README.md and commit.
-
Push to the new repo
Create a new empty repo on github under the zed-extensions organization.
git remote add origin git@github.com:zed-extensions/$LANGNAME
git push origin main --tags
git branch --set-upstream-to=origin/main main
- Setup the new repository:
- Go to the repository settings:
- Disable Wikis
- Uncheck "Allow Merge Commits"
- Check "Allow Squash Merging"
- Default commit message: "Pull request title and description"
- Publish a new version of the extension.
OLD_VERSION=$(grep '^version = ' extension.toml | cut -d'"' -f2)
NEW_VERSION=$(echo "$OLD_VERSION" | awk -F. '{$NF = $NF + 1;} 1' OFS=.)
echo $OLD_VERSION $NEW_VERSION
perl -i -pe "s/$OLD_VERSION/$NEW_VERSION/" extension.toml
perl -i -pe "s#https://github.com/zed-industries/zed#https://github.com/zed-extensions/${LANGNAME}#g" extension.toml
# if there's rust code, update this too.
test -f Cargo.toml && perl -i -pe "s/$OLD_VERSION/$NEW_VERSION/" Cargo.toml
# remove workspace Cargo.toml lines
test -f Cargo.toml && perl -ni -e 'print unless /^.*(workspace\s*=\s*true|\[lints\])\s*$/' Cargo.toml
test -f Cargo.toml && cargo check
# add a .gitignore
echo "target/
grammars/
*.wasm" > .gitignore
# commit and push
git add -u
git checkout -b "bump_${NEW_VERSION}"
git commit -m "Bump to v${NEW_VERSION}"
git push
gh pr create --title "Bump to v${NEW_VERSION}" --web
# merge PR in web interface
git checkout main
git pull
git tag v${NEW_VERSION}
git push origin v${NEW_VERSION}
- In zed repository, remove the old extension and push a PR.
rm -rf extensions/$LANGNAME
sed -i '' "/extensions\/$LANGNAME/d" Cargo.toml
cargo check
git checkout -b remove_$LANGNAME
git add extensions/$LANGNAME
git add Cargo.toml Cargo.lock extensions/$LANGNAME
git commit -m "Migrate to $LANGNAME extension to zed-extensions/$LANGNAME"
git push
gh pr create --web
- Update extensions repository:
cd ../extensions
git checkout main
git pull
git submodule init
git submodule update
git status
git checkout -b ${LANGNAME}_v${NEW_VERSION}
git submodule add https://github.com/zed-extensions/${LANGNAME}.git extensions/${LANGNAME}
pnpm sort-extensions
# edit extensions.toml:
# - bump version
# - change `submodule` from `extensions/zed` to new path
# - remove `path` line all together
git add extensions.toml .gitmodules extensions/${LANGNAME}
git diff --cached
git commit -m "Bump ${LANGNAME} to v${NEW_VERSION}"
git push
Create PR and reference the Zed PR with removal from tree.