Compare commits

...

15 Commits

Author SHA1 Message Date
H-Lo
b7847b1212
Merge 4cf2fc613c into 427268c64f 2025-01-01 16:01:06 +02:00
Indrajit Raychaudhuri
427268c64f history-substring-search: Update history-substring-search module to current master 2024-12-26 22:32:57 -06:00
Indrajit Raychaudhuri
61d7dc9a72 completion: Update completion module to current master 2024-12-26 22:30:38 -06:00
Indrajit Raychaudhuri
2388b8f873 autosuggestions: Update autosuggestions module to 0.7.1 2024-12-26 22:27:46 -06:00
msdx321
9626ce2beb Add exception for VSCode env helper
Signed-off-by: msdx321 <msdx321@gmail.com>
2024-12-12 07:47:13 +05:30
H-Lo
4cf2fc613c
Removed Makefile from container, not needed after build 2019-10-27 16:06:05 -07:00
H-Lo
48de6d2bfb
Update container-README.md
markdown not rendering?
2019-10-27 16:00:49 -07:00
Hector
5e75f57345 again 2019-10-26 20:59:59 -07:00
Hector
544a7a9b55 turns out you cante embed gists on github REDMEs.. 2019-10-26 20:53:36 -07:00
Hector
2a992e2092 Updated container-README.md with better instructions, spelling 2019-10-26 20:30:52 -07:00
H-Lo
e4bb17142c
Update container-README.md 2019-10-25 13:41:01 -07:00
Hector
0b1e26065b Correcterd make clean, added tree to image, added container-README.md 2019-10-25 13:32:11 -07:00
Hector
0476408511 added a quick readme 2019-10-25 12:00:47 -07:00
Hector
280aa93bae Added missing utils to image, seems ready to kick the tires 2019-10-25 11:32:14 -07:00
Hector
7c15c748f5 clean image build 2019-10-25 06:30:56 -07:00
9 changed files with 327 additions and 4 deletions

1
.gitignore vendored
View File

@ -2,3 +2,4 @@
*.zwc.old *.zwc.old
modules/*/cache.zsh modules/*/cache.zsh
contrib contrib
.container

24
Dockerfile Normal file
View File

@ -0,0 +1,24 @@
FROM alpine as prezto-devel
LABEL maintainer="h@hlo.mx"
RUN apk --no-cache update && apk upgrade && \
apk add util-linux pciutils usbutils coreutils binutils\
findutils grep man man-pages mdocml-apropos less less-doc \
make grep zsh zsh-vcs zsh-zftp zsh-calendar zsh-doc git \
vim git-zsh-completion tmux tmux-zsh-completion tree \
docker-zsh-completion
RUN addgroup prezto && adduser -D prezto -G prezto -S /bin/zsh
WORKDIR /home/prezto
USER prezto
RUN cd /home/prezto && mkdir src
COPY . src
RUN cp src/Makefile .
RUN make .clone
RUN make src .homercs
RUN rm Makefile
# ENTRYPOINT ["/bin/zsh", "-"]
# CMD ["/bin/zsh","-l","-o","verbose","-o","xtrace","-o","sourcetrace"]
CMD ["/bin/zsh","-l"]

113
Makefile Executable file
View File

@ -0,0 +1,113 @@
#!/usr/bin/make shebang
# _ ____ _
# _ __ _ __ ___ ___| |_ ___ | _ \ ___ ___| | _____ _ __
# | '_ \| '__/ _ \_ / __/ _ \ _____| | | |/ _ \ / __| |/ / _ \ '__|
# | |_) | | | __// /| || (_) |_____| |_| | (_) | (__| < __/ |
# | .__/|_| \___/___|\__\___/ |____/ \___/ \___|_|\_\___|_|
# |_|
# h@h-lo.me 20191025 004745 -0700 PDT 1571989665 d(-_- )b...
# This makefile automates image building and container management
# for easy development of prezto and prezto-plugins without messing
# up your current configuration. Prezto is installed fresh on an
# alpine container, where you may add your edits
#
#######################################################################
# REPO and IMG define the TAG for our image. this is how it gets named
# when pushed to dockerhum. REPO should be your dockerhub username
# IMG would be nice if its related to the project.
REPO = hlecuanda
IMG = prezto-dev
TAG = $(REPO)/$(IMG)
# ALLCODE recirds all code files so we can have the docker image
# depend on all of them. if any file changes, the image gets rebuilt
ALLCODE != find . -type f | grep -vEe '^\./\.+|*.md'
RUNCOMS != ls runcoms
# The context is the current directory. this is important if you have
# a buildserver, v.gr on gitlab or google cloud. its still needed for
# local builds. so don't touch this, unless you know what you're doing
CONTEXT = .
# All reciipes on this makefile are zsh scripts, not bash or sh
# scripts, so we don't have to be context-switching
SHELL = zsh
# This removes the default build rules for gmake's built in suffixes
# when debugging the Makefile, output is a lot more readable, plus
# if you're not making C programs, it just makes sense to avoid
# mistery bugs
.SUFFIXES =
# We don't want to fail recipies on error for the targets if .IGNORE
.IGNORE: clean realclean ;
# These targets don't create files and are defined for convenience.
# note that other targets do create real files which are used to
# determine the state of the build
.PHONY: default run clean realclean ;
# an empty recipe, to avoid expensive operations if we "make" by
# mistake. it can be made to depend on another target and it will
# become the target of a "make" call with no arguments, vg.r:
# default: image; results in "make" and "make image" doing the same
default: ;
# a user callable target, depends on .container/image whiech records
# the timestamp of the last successfuly built image
image: .container/image ;
# we declare .container/image to depend on $(ALLCODE) which contains
# all files in the distribution. thus, if ANY file changes, it makes
# our image obsolete and will be re-made on next make command
.container/image: $(ALLCODE)
docker build -t $(TAG) $(CONTEXT)
[[ ! -d .container ]] && mkdir .container || :
touch $@
# NOTE: The following targets ( .homercs clone and .clone ) are
# run inside the container while building a container image. They are
# called from the Dockerfile when you "make image". .homercs creates
# the dotfiles on our home directory and depends on .clone, so .clone
# should be made before .homercs. We're spelling these out explicitly
# for clarity instead of using Makefile enchantments that would make
# this a 2 line recipe
.homercs: .clone
ln -s .zprezto/runcoms/zshenv /home/prezto/.zshenv
ln -s .zprezto/runcoms/zprofile /home/prezto/.zprofile
ln -s .zprezto/runcoms/zshrc /home/prezto/.zshrc
ln -s .zprezto/runcoms/zpreztorc /home/prezto/.zpreztorc
ln -s .zprezto/runcoms/zlogin /home/prezto/.zlogin
ln -s .zprezto/runcoms/zlogout /home/prezto/.zlogout
touch $@
# clones the prezto repository we have copied from the build context
# into the container, into a .zprezto directory, as the installation
# instructions recommend.
.clone:
git clone --recursive src .zprezto
touch $@
# This runs an interactive (-it) ephemeral (--rm) container named
# $(IMG) created from the image stored at $(TAG) it is made to depend
# on container/image so that it checks whether image is up to # date.
# Given that image depends on $(ALLCODE), calling "make run" will use
# the latest image, unless any code file hasa changed in which case,
# the image is rebuilt and then run.
run: .container/image
docker run -it --rm -h $(IMG) --name $(IMG) $(TAG)
# Removes the current container and image, so we can build a new one
# from scratch. If you want a real clean slate, then "make realclean"
clean:
docker container rm $(TAG)
docker image rm $(TAG)
rm -fv .container/*
# Deep cleaning, will remove dangling (intermediate build) images
# and containers for which a final image or container cannot be found
# (i.e has been deleted by clean or removed after usage for ephemeral
# containers. Run every once in a while.
realclean:
$(MAKE) clean
docker rmi $(TAG)
docker container prune
docker image prune
# vim: set ft=make sw=2 tw=7 fdm=manual noet :

94
container-README.md Normal file
View File

@ -0,0 +1,94 @@
# Prezto Docker Container
This branch contains a Dockerfile and a Makefile that hopefully may
prove helpful for prezto development.
The idea is to have a totally independent and isolated environemnet
in which to test changes to either prezto-core or any plugin that you
may be working on, **without disrupting your environment**, thus enabling
automated testing and even continuous integration.
This is a proof of concept, it may not be even a good idea to have
this on the main prezto repository. on the other hand, the container
image should depend on the code, so if the team finds this to be a
useful tool, there are choices to be made in that respect. My
intention is to introduce this as a helpful tool for development and
for new users to try prezto easely
Here is a screencast showing what the container can do so far
[![asciicast](https://asciinema.org/a/277054.svg)](https://asciinema.org/a/277054)
The container is a basic install of [alpine linux](https://alpinelinux.org) so the download
is reasonably small at around 200M, since debian based images can
weigh in around 1.5G.
On the container we have a few utilities and additional software that
prezto has core support for, (tmux, make, etc) and you can try it i
easily by running:
```bash
docker pull hlecuanda/prezto-dev:latest
```
once you have the image, create a container from it:
```bash
docker run -it --rm -h prezto hlecuanda/prezto-dev:latest
```
That will create an interactive (`--it`) ephemeral container (`--rm`)
whose hostname is prezto (`-h prezto`) based on the aforementioned
imag. you should be sitting at the plain sorin prompt in a brand new
prezto instance.
A development and testing workflow can be achieved by mounting a
project's directory on to the image's filesystem:
```bash
cd /path/to/project/root
docker run -it --rm -h prezto \
-v $(pwd):/home/prezto/.zprezto/modules/${:-$(pwd):t} \
hlecuanda/prezto-dev:latest
```
This will mount the current directory on the container's filesystem,
you can develop on your own machine and environnment, and test your
changes running on the container, your actual source will already be
in-place on prezto's directory hierarchy, as if it was just cloned
recursively (v.gr for modules with extenral dependencies)
Keep in mind that the containers created in this fashion are ephemeral,
so anything you write on the containers filesystem will be lost,
unless you remove the `--rm` option like so:
```bash
cd /path/to/project/root
docker run -it -h prezto --name prezto \
-v $(pwd):/home/prezto/.zprezto/modules/${:-$(pwd):t} \
hlecuanda/prezto-dev:latest
```
This will create a container named prezto, (`--name prezto`) with it's
hostname set to prezto also (`-h prezto`) that will retain changes
made to it's filesystem. When you detach, the container willi stop and
you can spinit up again using:
```bash
docker start -ai prezto
```
Containers started this way will remember the volume mounts they were
created with, so the project directory we previously mounted with
`-v` on the `docker run` command, will be ready on the image.
I have found epehermeral containers to be most useful since you get an
untainted, pristine environment for testing every time you spin up the
container.
Since the docker commands can be a bit verbose, the included Makefile
automates some of the frequent steps in the workflow, although it can
be replaced by [a shell function](https://gist.github.com/hlecuanda/78a6a39877c9753230a11c2d8832f4b6)
quite easily.
hope this turns out to be useful.

@ -1 +1 @@
Subproject commit c3d4e576c9c86eac62884bd47c01f6faed043fc5 Subproject commit e52ee8ca55bcc56a17c828767a3f98f22a68d4eb

@ -1 +1 @@
Subproject commit 978e79e12c44b5b1d3e1e2920c537002087b82c2 Subproject commit c160d09fddd28ceb3af5cf80e9253af80e450d96

@ -1 +1 @@
Subproject commit 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 Subproject commit 87ce96b1862928d84b1afe7c173316614b30e301

View File

@ -23,7 +23,7 @@ if ([[ "$TERM_PROGRAM" = 'iTerm.app' ]] && \
_tmux_iterm_integration='-CC' _tmux_iterm_integration='-CC'
fi fi
if [[ -z "$TMUX" && -z "$EMACS" && -z "$VIM" && -z "$INSIDE_EMACS" && "$TERM_PROGRAM" != "vscode" && "$TERMINAL_EMULATOR" != "JetBrains-JediTerm" ]] && ( \ if [[ -z "$TMUX" && -z "$EMACS" && -z "$VIM" && -z "$INSIDE_EMACS" && -z "$VSCODE_RESOLVING_ENVIRONMENT" && "$TERM_PROGRAM" != "vscode" && "$TERMINAL_EMULATOR" != "JetBrains-JediTerm" ]] && ( \
( [[ -n "$SSH_TTY" ]] && zstyle -t ':prezto:module:tmux:auto-start' remote ) || ( [[ -n "$SSH_TTY" ]] && zstyle -t ':prezto:module:tmux:auto-start' remote ) ||
( [[ -z "$SSH_TTY" ]] && zstyle -t ':prezto:module:tmux:auto-start' local ) \ ( [[ -z "$SSH_TTY" ]] && zstyle -t ':prezto:module:tmux:auto-start' local ) \
); then ); then

91
prezto-container.zsh Executable file
View File

@ -0,0 +1,91 @@
#!/usr/bin/env zsh
local opts withvals
zmodload zsh/zutil || { <<< 'Requires zparseopts'; false; return }
[ -z $commands[docker] ] && { <<< 'Requires Docker'; false; return }
zparseopts -D -E -M -a opts -A withvals - \
h=hlp -help=h \
i: -image=i \
N: -name=N \
n -dry-run=n \
p -persistant=p \
r -run=r \
-zdotdir: \
-zpreztodir:
if (( $#hlp == 1 )) ; then
<<-USAGE
${0}: create an ephemeral prezto container using docker
usage:
${0} [options] -- [addtl-args]
options:
-h, --help : print this message
-p, --persistant : make a persistant container
-N NAME, --name=NAME : set container name to NAME (default: prezto)
-n, --dry-run : see what command would be run without doing so
-r 'CMD' --run 'CMD' : run 'CMD' on the container (quote CMD)
-i IMG, --image=IMG : create container from image IMG (default hlecuanda/prezto-dev)
-zdotdir=PATH : use dotfiles from local PATH
-zpreztodir : override default prezto to local PATH
example:
${0} -n myruncoms -zdotdir=$HOME
creates an ephemeral container named myruncoms using
dotfiles found in ${HOME}
${0} -n illbeback -p
creates a persistant container named illbeback if such
container exists, then startit and attach to it
${0} -n ivebeenback -r 'apk add python'
spins up the a container named ivebeenback, and runs
the comand 'apk add python'. the container stops when
done.
USAGE
fi
local image="hlecuanda/prezto-dev"
local name="prezto"
local persistant="--rm"
local zdotdir=""
local zpreztodir=""
local dockercmd='docker run'
local dockerpull=""
for opt in ${(k)withvals}
case $opt in
-i)
image="$withvals[-i]" ;;
-n)
local dryrun="print --" ;;
-N)
name="$withvals[-n]" ;;
-p)
persistant="" ;;
-zdotdir)
zdotdir="-v ${(qq)withvals[-zdotdir]}:/home/prezto/zdotdir -e 'ZDOTDIR=/home/prezto/zdotdir " ;;
-zpreztodir)
zpreztodir="-v ${(qq)withvals[-zpreztodir]}:/home/prezto/zpreztodir -e 'ZPREZTODIR=/home/prezto/zpreztodir " ;;
esac
docker images \
| grep prezto-dev \
&>>! /dev/null || dockerpull="docker pull $image && "
dockercmd="$dryrun $dockerpull $dockercmd $persistant -h $name "
dockercmd="$dockercmd -name $name $zdotdir $zpreztodir $image"
cmd=$(echo $dockercmd | tr -s \ )
${(z)cmd}
# vim: set ft=zsh sw=2 tw=0 fdm=manual et :