Update readme and version (#64)

* Update README and increment version

* Add comfortable-swipe version badge

* Have macro guard warning for version

* Improve README and install script

* Expound bug reports statement
This commit is contained in:
Rico Tiongson 2019-03-15 10:40:54 +08:00 committed by GitHub
parent 810a20f1ed
commit 4852993663
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 117 additions and 82 deletions

View File

@ -1,4 +1,5 @@
# Comfortable Swipe (Ubuntu) # Comfortable Swipe (Ubuntu)
[![comfortable-swipe version](https://img.shields.io/github/release/Hikari9/comfortable-swipe.svg?label=comfortable-swipe&color=orange)](https://github.com/Hikari9/comfortable-swipe/releases)
[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0) [![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
Comfortable, seamless, and fast 3-finger (and 4-finger) touchpad swipe gestures for Ubuntu 14.04 LTS and beyond. May work for other Linux distros that support `libinput`. Comfortable, seamless, and fast 3-finger (and 4-finger) touchpad swipe gestures for Ubuntu 14.04 LTS and beyond. May work for other Linux distros that support `libinput`.
@ -15,7 +16,7 @@ Comfortable, seamless, and fast 3-finger (and 4-finger) touchpad swipe gestures
```bash ```bash
git clone https://github.com/Hikari9/comfortable-swipe.git --depth 1 git clone https://github.com/Hikari9/comfortable-swipe.git --depth 1
cd comfortable-swipe-ubuntu cd comfortable-swipe
``` ```
3. Install 3. Install
@ -24,7 +25,7 @@ Comfortable, seamless, and fast 3-finger (and 4-finger) touchpad swipe gestures
bash install bash install
``` ```
4. You may delete the downloaded `comfortable-swipe-ubuntu` folder after installation. 4. You may delete the downloaded `comfortable-swipe` folder after installation.
## How to Run ## How to Run
@ -49,7 +50,7 @@ Comfortable, seamless, and fast 3-finger (and 4-finger) touchpad swipe gestures
## Configurations ## Configurations
Comfortable swipe makes use of keyboard shortcuts for configurations. Edit by running Comfortable swipe makes use of keyboard shortcuts for configurations. Edit by running
``` ```
nano $(comfortable-swipe config) gedit $(comfortable-swipe config)
``` ```
Make sure to run after making changes: Make sure to run after making changes:
@ -126,4 +127,18 @@ Download the `uninstall` script then run `bash uninstall`
## Bug Reports ## Bug Reports
Create an issue [here](https://github.com/Hikari9/comfortable-swipe-ubuntu/issues/new) to report a bug. Search in [Issues](https://github.com/Hikari9/comfortable-swipe/issues?utf8=%E2%9C%93&q=is%3Aissue) if the problem has already been solved.
Otherwise, [create a new issue](https://github.com/Hikari9/comfortable-swipe/issues/new) to report your bug.
Please include the output of the following:
1. `lsb_release -a`
2. `g++ --version`
3. `ls -l /dev/input/event*`
3. `xinput list | grep touchpad -i`
4. `lsmod | grep hid`
5. `comfortable-swipe status`
6. `comfortable-swipe start` (if you can run it)
7. `comfortable-swipe debug` (try swiping if you can see `GESTURE_SWIPE_XXX`)
8. `cat $(comfortable-swipe config)`

1
VERSION Normal file
View File

@ -0,0 +1 @@
v1.0.3

View File

@ -1,2 +1,7 @@
#!/bin/sh #!/bin/sh
g++ $(dirname $0)/comfortable-swipe.cpp -std=c++11 -O2 -lxdo -Wno-unused-result -o $1 dir="$(dirname $0)"
g++ "$dir/comfortable-swipe.cpp" \
-o "$1" \
-std=c++11 \
-O2 -lxdo -Wno-unused-result \
-DCOMFORTABLE_SWIPE_VERSION="\"$(cat $dir/VERSION | tr -d '[:space:]')\""

149
install
View File

@ -1,82 +1,93 @@
#!/bin/bash #!/bin/bash
# prefer running as root
DIR=$(dirname $0)
PROGRAM=/usr/local/bin/comfortable-swipe
COMPILE=$DIR/comfortable-swipe.compile.sh
CONF_PATH=/usr/local/share/comfortable-swipe/comfortable-swipe.conf
DCONF_PATH=$DIR/defaults.conf
OLD_CONF_PATH=${XDG_CONFIG_HOME:-$HOME/.config}/comfortable-swipe.conf
if [ -x "$(command -v $PROGRAM)" ]; then function install {
# stop any running comfortable-swipe if it exists # prefer running as root
$PROGRAM stop local dir="$(dirname $0)"
fi local program=comfortable-swipe
local program_exe=/usr/local/bin/$program
local compile_command="$dir/$program.compile.sh"
local conf_path=/usr/local/share/$program/$program.conf
local dconf_path="$dir/defaults.conf"
local old_conf_path="${XDG_CONFIG_HOME:-$HOME/.config}/$program.conf"
#copy config file if [ -x "$(command -v $program_exe)" ]; then
abort () { # stop any running $program if it exists
exec echo "Installation aborted" $program_exe stop
}
sudo mkdir -p $(dirname $CONF_PATH) || abort
# check if "-y" or "--yes" is passed as an argument
YES=false
while test $# -gt 0
do
case "$1" in
-y) YES=true
;;
--yes) YES=true
;;
esac
shift
done
sudo chown $USER $(dirname $CONF_PATH)
if [ ! -f $CONF_PATH ]; then
if [ ! -f $OLD_CONF_PATH ]; then
# old config file not found, create from scratch
cat $DCONF_PATH > $CONF_PATH || abort
else
# old config file found, move to the new path
cat $OLD_CONF_PATH > $CONF_PATH || abort
echo "Configuration copied from $OLD_CONF_PATH to $CONF_PATH"
fi fi
else
# config file found, ask user if overwrite #copy config file
echo "Old conf file found in $CONF_PATH" abort () {
if [ $YES == false ]; then exec echo "Installation aborted"
read -r -p "Keep the old conf file? (default: yes) [Y/n] " response }
response=${response,,} # tolower sudo mkdir -p "$(dirname $conf_path)" || abort
if [[ "$response" =~ ^(no|n)$ ]]; then
read -r -p "Conf file will be overwritten. Are you sure? [Y/n] " response # check if "-y" or "--yes" is passed as an argument
response=${response,,} YES=false
if [[ "$response" =~ ^(yes|y)$ ]]; then while test $# -gt 0
cat $DCONF_PATH > $CONF_PATH || abort do
else case "$1" in
abort -y) YES=true
;;
--yes) YES=true
;;
esac
shift
done
sudo chown $USER "$(dirname $conf_path)"
if [ ! -f "$conf_path" ]; then
if [ ! -f "$old_conf_path" ]; then
# old config file not found, create from scratch
cat "$dconf_path" > "$conf_path" || abort
else
# old config file found, move to the new path
cat "$old_conf_path" > "$conf_path" || abort
echo "Configuration copied from $old_conf_path to $conf_path"
fi
else
# config file found, ask user if overwrite
echo "Old conf file found in $conf_path"
if [ "$YES" == false ]; then
read -r -p "Keep the old conf file? (default: yes) [Y/n] " response
response="${response,,}" # tolower
if [[ "$response" =~ ^(no|n)$ ]]; then
read -r -p "Conf file will be overwritten. Are you sure? [Y/n] " response
response="${response,,}"
if [[ "$response" =~ ^(yes|y)$ ]]; then
cat "$dconf_path" > "$conf_path" || abort
else
abort
fi
fi fi
fi fi
fi fi
fi
echo "Installing..." echo "Installing to $program_exe ..."
# remove existing comfortable-swipe # remove existing $program
if [ -x "$(command -v $PROGRAM)" ]; then if [ -x "$(command -v $program_exe)" ]; then
sudo rm -f $(which comfortable-swipe) sudo rm -f "$(which $program)"
fi fi
# compile library # compile library
sudo $COMPILE $PROGRAM || abort sudo "$compile_command" "$program_exe" || abort
# add permissions to input group (defer) # add permissions to input group (defer)
# GROUP=$(ls -l /dev/input/event* | awk '{print $4}' | head --line=1) || abort # GROUP=$(ls -l /dev/input/event* | awk '{print $4}' | head --line=1) || abort
# toggle autostart twice to refresh any changes # turn on autostart by default
$PROGRAM autostart > /dev/null || abort local autostart_status="$($program_exe autostart)"
$PROGRAM autostart > /dev/null || abort if [[ "$autostart_status" == *off* ]]; then
autostart_status="$($program_exe autostart)"
fi
echo "Successfully installed comfortable-swipe." echo "Successfully installed $program $(cat $dir/VERSION | tr -d '[:space:]')"
echo "Configuration file is located at $CONF_PATH" echo ""
echo "" echo "$autostart_status"
echo "Try running 'comfortable-swipe start' to test." echo "Edit configuration file: gedit \$($program config)"
echo ""
echo "Try running: $program start"
}
install
unset -f install

View File

@ -28,6 +28,11 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#define __COMFORTABLE_SWIPE__CONFIG__ "/usr/local/share/comfortable-swipe/comfortable-swipe.conf" #define __COMFORTABLE_SWIPE__CONFIG__ "/usr/local/share/comfortable-swipe/comfortable-swipe.conf"
#endif /* __COMFORTABLE_SWIPE__CONFIG__ */ #endif /* __COMFORTABLE_SWIPE__CONFIG__ */
#ifndef COMFORTABLE_SWIPE_VERSION
#warning COMFORTABLE_SWIPE_VERSION is not defined
#define COMFORTABLE_SWIPE_VERSION "v(UNKNOWN)"
#endif /* COMFORTABLE_SWIPE_VERSION */
#include <map> // std::map #include <map> // std::map
#include <string> // std::string #include <string> // std::string

View File

@ -30,7 +30,7 @@ namespace comfortable_swipe::service
void help() void help()
{ {
using comfortable_swipe::util::conf_filename; using comfortable_swipe::util::conf_filename;
std::puts("comfortable-swipe [start|stop|restart|autostart|buffer|help|config|debug|status]"); std::puts("comfortable-swipe " COMFORTABLE_SWIPE_VERSION " [start|stop|restart|autostart|buffer|help|config|debug|status]");
std::puts(""); std::puts("");
std::puts("start - starts 3/4-finger gesture service"); std::puts("start - starts 3/4-finger gesture service");
std::puts("stop - stops 3/4-finger gesture service"); std::puts("stop - stops 3/4-finger gesture service");

View File

@ -50,19 +50,13 @@ namespace comfortable_swipe::service
auto autostart_f = comfortable_swipe::util::autostart_filename(); auto autostart_f = comfortable_swipe::util::autostart_filename();
bool autostart_on = access(autostart_f, F_OK) != -1; bool autostart_on = access(autostart_f, F_OK) != -1;
// print status std::puts(comfortable_swipe::util::conf_filename());
std::printf("program is %s\n", running ? "ON" : "OFF");
std::printf("autostart is %s\n", autostart_on ? "ON" : "OFF");
std::printf("config file at %s\n", comfortable_swipe::util::conf_filename());
// check status of configuration file // check status of configuration file
try try
{ {
auto config = comfortable_swipe::util::read_config_file(comfortable_swipe::util::conf_filename()); auto config = comfortable_swipe::util::read_config_file(comfortable_swipe::util::conf_filename());
// print keys and values of config file
std::printf("\nConfigurations:\n");
// print threshold // print threshold
if (config.count("threshold") > 0) if (config.count("threshold") > 0)
{ {
@ -91,6 +85,10 @@ namespace comfortable_swipe::service
{ {
std::printf("config error: %s\n", e.what()); std::printf("config error: %s\n", e.what());
} }
// print status
std::printf("autostart is %s\n", autostart_on ? "ON" : "OFF");
std::printf("comfortable-swipe program is %s\n", running ? "RUNNING" : "STOPPED");
} }
} }