summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDylan Araps <dylan.araps@gmail.com>2018-04-26 19:15:06 +1000
committerDylan Araps <dylan.araps@gmail.com>2018-04-26 19:15:06 +1000
commit9ae8c5e08945e52a115034aedba63c222e959d0b (patch)
tree07c1a3bc52e8e161bbf0115710e84a90240061cf
parentd240c6e50b62c227cbc6b7bdd60b0183953b9fe8 (diff)
parentf2278e6c543e0b90000ba3493f7a6f0f773fdc24 (diff)
Merge branch 'master' of github.com:dylanaraps/pywal
-rw-r--r--pywal/__main__.py7
-rw-r--r--pywal/colors.py5
-rw-r--r--pywal/image.py44
-rw-r--r--pywal/templates/colors-wal-st.h1
4 files changed, 49 insertions, 8 deletions
diff --git a/pywal/__main__.py b/pywal/__main__.py
index f448607..a8e2a87 100644
--- a/pywal/__main__.py
+++ b/pywal/__main__.py
@@ -48,6 +48,11 @@ def get_args():
Use 'wal --theme' to list builtin themes.",
const="list_themes", nargs="?")
+ arg.add_argument("--iterative", action="store_true",
+ help="When pywal is given a directory as input and this "
+ "flag is used: Go through the images in order "
+ "instead of shuffled.")
+
arg.add_argument("-c", action="store_true",
help="Delete all cached colorschemes.")
@@ -141,7 +146,7 @@ def parse_args(parser):
shutil.rmtree(scheme_dir, ignore_errors=True)
if args.i:
- image_file = image.get(args.i)
+ image_file = image.get(args.i, iterative=args.iterative)
colors_plain = colors.get(image_file, args.l, args.backend)
if args.theme:
diff --git a/pywal/colors.py b/pywal/colors.py
index fa606e7..26e2c60 100644
--- a/pywal/colors.py
+++ b/pywal/colors.py
@@ -113,7 +113,12 @@ def get(img, light=False, backend="wal", cache_dir=CACHE_DIR):
cache_file = os.path.join(*cache_name)
if os.path.isfile(cache_file):
+ # Disable logging in theme.file().
+ logger = logging.getLogger()
+ logger.disabled = True
colors = theme.file(cache_file)
+ logger.disabled = False
+
util.Color.alpha_num = colors["alpha"]
logging.info("Found cached colorscheme.")
diff --git a/pywal/image.py b/pywal/image.py
index 1b982ce..d23e82b 100644
--- a/pywal/image.py
+++ b/pywal/image.py
@@ -4,6 +4,7 @@ Get the image file.
import logging
import os
import random
+import re
import sys
from .settings import CACHE_DIR
@@ -11,15 +12,20 @@ from . import util
from . import wallpaper
-def get_random_image(img_dir):
- """Pick a random image file from a directory."""
+def get_image_dir(img_dir):
+ """Get all images in a directory."""
current_wall = wallpaper.get()
current_wall = os.path.basename(current_wall)
file_types = (".png", ".jpg", ".jpeg", ".jpe", ".gif")
- images = [img for img in os.scandir(img_dir)
- if img.name.lower().endswith(file_types)]
+ return [img.name for img in os.scandir(img_dir)
+ if img.name.lower().endswith(file_types)], current_wall
+
+
+def get_random_image(img_dir):
+ """Pick a random image file from a directory."""
+ images, current_wall = get_image_dir(img_dir)
if len(images) > 2 and current_wall in images:
images.remove(current_wall)
@@ -29,17 +35,41 @@ def get_random_image(img_dir):
sys.exit(1)
random.shuffle(images)
+ return os.path.join(img_dir, images[0])
+
- return os.path.join(img_dir, images[0].name)
+def get_next_image(img_dir):
+ """Get the next image in a dir."""
+ images, current_wall = get_image_dir(img_dir)
+ images.sort(key=lambda img: [int(x) if x.isdigit() else x
+ for x in re.split('([0-9]+)', img)])
+ try:
+ next_index = images.index(current_wall) + 1
-def get(img, cache_dir=CACHE_DIR):
+ except ValueError:
+ next_index = 0
+
+ try:
+ image = images[next_index]
+
+ except IndexError:
+ image = images[0]
+
+ return os.path.join(img_dir, image)
+
+
+def get(img, cache_dir=CACHE_DIR, iterative=False):
"""Validate image input."""
if os.path.isfile(img):
wal_img = img
elif os.path.isdir(img):
- wal_img = get_random_image(img)
+ if iterative:
+ wal_img = get_next_image(img)
+
+ else:
+ wal_img = get_random_image(img)
else:
logging.error("No valid image file found.")
diff --git a/pywal/templates/colors-wal-st.h b/pywal/templates/colors-wal-st.h
index acb2863..fcf8538 100644
--- a/pywal/templates/colors-wal-st.h
+++ b/pywal/templates/colors-wal-st.h
@@ -31,3 +31,4 @@ const char *colorname[] = {{
unsigned int defaultbg = 0;
unsigned int defaultfg = 257;
unsigned int defaultcs = 258;
+ unsigned int defaultrcs= 258;