dotfiles | ||
install | ||
packs | ||
tools | ||
uninstall | ||
upgrade | ||
.dockerignore | ||
.editorconfig | ||
.gitignore | ||
Dockerfile | ||
gen-makefile | ||
LICENSE | ||
Makefile | ||
README.md |
My Ubuntu environment
make
-ready bunch of scripts for easily installation of different software.
Requirements
- Ubuntu >= 20.04 (not tested with version < 20)
bash
,zsh
or other POSIX-compatible shellmake
(optional but recommended)wget
(necessary for some scripts)git
(necessary for some scripts)
If some dependecies are missed for some of these scripts it is enougth to run ./install/apt
in most cases.
Usage
Clone this repo (recommended)
# if git is installed
git clone git@git.axenov.dev:anthony/my-env.git --depth=1
# if git is not installed
wget -qO - https://git.axenov.dev/anthony/my-env/archive/master.tar.gz | tar -zxf -
# switch to repo dir
cd my-env
# generate fresh ./Makefile and get full list of `make` goals
./gen-makefile
# get full list of `make` goals
make
Selective straightforward installation
# from remote file
wget -qO - https://git.axenov.dev/anthony/my-env/raw/branch/master/install/apt | bash
# from locally cloned repo
./install/apt
How to add my script?
- Create a new shell script in
./install
,./upgrade
or./uninstall
directory.
At the beggining of a file you must write these two lines:#!/bin/bash ##makedesc: Your description for Makefile
- Make this script executable, e.g.:
sudo chmod a+x ./install/myscript
- Test your script
- Run
make self
to generate new./Makefile
How to create packs?
You can create new file inside ./packs
dir.
Syntax is same as classic makefile with one important and necessary addition -- a comment started with ##
:
# Pack description
mypack1: goal1 goal2 goalX ...
...
# Pack description
mypackX: goalA goalB
@cp file1 file2
...
...
where:
mypack*
is the pack namegoal*
are script names in./install
Testing in docker (not recommended)
Note that this is almost useless way to test since you'll meet errors in many cases because dockerized OS is not fully-functional and will never be.
You can use docker to test something really simple, e.g. to check general script steps or install cli tools.
In other cases you need virtualized Ubuntu instead of dockerized one, so I strongly recommend you to use VirtualBox or your host machine.
# switch to repo dir
cd my-env
# build and run container
docker build -t myenv . && docker run -it myenv
# or oneliner
docker run -it $(docker build -q .)
Now you can play around with scripts.
TODO
- build: flameshot
- build: rustdesk
- JB mono (2)
- update scripts (when possible)
- uninstall scripts (when possible)