diff options
| author | Mattias Andrée <maandree@kth.se> | 2024-02-10 07:05:52 +0100 | 
|---|---|---|
| committer | Mattias Andrée <maandree@kth.se> | 2024-02-10 07:05:52 +0100 | 
| commit | c90e3bf08b1c6f4426d0f72c76b1ac9a0a346efb (patch) | |
| tree | f9a0216e5e7d2a0a77d40a1840a1f6b3424869d2 /tools | |
| parent | Add alias for versions up to 99 of applications (diff) | |
| download | simple-icon-theme-c90e3bf08b1c6f4426d0f72c76b1ac9a0a346efb.tar.gz simple-icon-theme-c90e3bf08b1c6f4426d0f72c76b1ac9a0a346efb.tar.bz2 simple-icon-theme-c90e3bf08b1c6f4426d0f72c76b1ac9a0a346efb.tar.xz | |
Add tools
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
| -rwxr-xr-x | tools/addlink | 104 | ||||
| -rwxr-xr-x | tools/getlinks | 19 | ||||
| -rwxr-xr-x | tools/linkblink | 14 | ||||
| -rwxr-xr-x | tools/queryforest | 80 | ||||
| -rwxr-xr-x | tools/sortforest | 85 | 
5 files changed, 302 insertions, 0 deletions
| diff --git a/tools/addlink b/tools/addlink new file mode 100755 index 0000000..66e93da --- /dev/null +++ b/tools/addlink @@ -0,0 +1,104 @@ +#!/bin/sh +set -e + +target="$1" +link="$2" + +if ! test $# = 2; then +	printf 'usage: %s target link\n' "$0" >&2 +	exit 1 +fi + +if ! test -d scalable || ! test -r icons.mk; then +	printf 'could not find both scalable/ and icons.mk the current working directory\n' >&2 +	exit 1 +fi + +T="$target" +L="$link" +while test $(printf '%s\n' "$T" "$L" | grep / | wc -l) = 2; do +	Td="$(printf '%s\n' "$T" | cut -d / -f 1)" +	Ld="$(printf '%s\n' "$L" | cut -d / -f 1)" +	if test ! "$Td" = "$Ld"; then +		break +	fi +	T="$(printf '%s\n' "$T" | cut -d / -f 2-)" +	L="$(printf '%s\n' "$L" | cut -d / -f 2-)" +done +while printf '%s\n' "$L" | grep / > /dev/null; do +	T="$(printf '../%s\n' "$T")" +	L="$(printf '%s\n' "$L" | cut -d / -f 2-)" +done +expectedtarget="${T}.svg" + +if test -f "scalable/${link}.svg"; then +	if test ! -L "scalable/${link}.svg"; then +		currenttarget="not a symbolic link" +	elif test "$(readlink "scalable/${link}.svg")" = "$expectedtarget"; then +		currenttarget="links to $target" +	else +		currenttarget="symbolic link -> $target" +	fi +	printf '%s already exists (%s)\n' "scalable/${link}.svg" "$currenttarget" >&2 +	exit 1 +fi + +targetentry="$(grep '^[[:space:]]*'"$target"'\\$' < icons.mk)" +test -n "$targetentry" +test $(printf '%s\n' "$targetentry" | wc -l) = 1 + +if grep '^[[:space:]]*'"$link"'\\$' < icons.mk > /dev/null; then +	printf '%s is already listed in icons.mk, however its file does not exist\n' "$link" >&2 +	exit 1 +fi + +indent="$(sed -n 's:^\([[:space:]]*\)'"$target"'\\$:\1:p' < icons.mk)" +targetentrysed="$(printf '^%s$\n' "$targetentry" | sed 's:[/\\]:\\&:g')" + +newiconsfile="$(sed /"$targetentrysed"/q < icons.mk && \ +                printf '%s\t%s\\\n' "$indent" "$link" && \ +                sed 1,/"$targetentrysed"/d < icons.mk)" + +test $(printf '%s\n' "$newiconsfile" | diff icons.mk - | wc -l) = 2 + +( ! printf '%s\n' "$newiconsfile" | diff -U1 icons.mk - >&2 ) + +T="$target" +L="$link" +while test $(printf '%s\n' "$T" "$L" | grep / | wc -l) = 2; do +	Td="$(printf '%s\n' "$T" | cut -d / -f 1)" +	Ld="$(printf '%s\n' "$L" | cut -d / -f 1)" +	if test ! "$Td" = "$Ld"; then +		break +	fi +	T="$(printf '%s\n' "$T" | cut -d / -f 2-)" +	L="$(printf '%s\n' "$L" | cut -d / -f 2-)" +done +while printf '%s\n' "$L" | grep / > /dev/null; do +	T="$(printf '../%s\n' "$T")" +	L="$(printf '%s\n' "$L" | cut -d / -f 2-)" +done + +target="$expectedtarget" +link="scalable/${link}.svg" +printf 'ln -s %s %s\n' "$target" "$link" >&2 + +if ! cp icons.mk icons.mk~; then +	printf 'failed to create backup of icons.mk\n' >&2 +	exit 1 +fi +if ! ln -s "$target" "$link"; then +	printf 'failed to create symbolic link %s -> %s\n' "$link" "$target" >&2 +	rm -f icons.mk~ >&2 +	exit 1 +fi +if ! printf '%s\n' "$newiconsfile" > icons.mk; then +	printf 'failed to insert entry into icons.mk\n' >&2 +	if ! unlink "$link" >&2; then +		printf '\x1b[31mfailed to remove created symbolic link (%s)\x1b[m\n' "$link" >&2 +	fi +	if ! mv icons.mk~ icons.mk >&2; then +		printf '\x1b[1;31mfailed to restore icons.mk using icons.mk~\x1b[m\n' >&2 +	fi +	exit 1 +fi diff --git a/tools/getlinks b/tools/getlinks new file mode 100755 index 0000000..b1a376a --- /dev/null +++ b/tools/getlinks @@ -0,0 +1,19 @@ +#!/bin/sh + +if test $# = 0; then +	dir=. +else +	dir="$1" +	shift 1 +fi + +dirlen="${#dir}" +find "$dir" | xtest -L "$@" | colrm 1 $dirlen | sed 's/^\/*//' | while read f; do +	L="$(printf '%s\n' "$f" | rev | cut -d . -f 2- | rev)" +	T="$(dirname -- "$L")/$(readlink -- "$dir/$f" | rev | cut -d . -f 2- | rev)" +	T="$(printf '%s\n' "$T" | sed 's:/\(./\)*:/:g')" +	while printf '%s\n' "$T" | grep '/../' > /dev/null; do +		T="$(printf '%s\n' "$T" | sed 's:[^/]*/\.\./::')" +	done +	printf '%s\n\t%s\n' "$T" "$L" +done diff --git a/tools/linkblink b/tools/linkblink new file mode 100755 index 0000000..fe0d842 --- /dev/null +++ b/tools/linkblink @@ -0,0 +1,14 @@ +#!/bin/sh + +if test $# = 0; then +	printf 'usage: blink-on-icon ...' >&2 +	exit 1 +fi + +for n; do +	of="${n}.svg" +	nf="${n}-blink_off.svg" +	ot="$(readlink -- "${of}")" +	nt="$(printf '%s\n' "$ot" | sed 's/\.svg$/-blink_off&/')" +	ln -s "$nt" "$nf" +done diff --git a/tools/queryforest b/tools/queryforest new file mode 100755 index 0000000..8dc979c --- /dev/null +++ b/tools/queryforest @@ -0,0 +1,80 @@ +#!/usr/bin/env python3 +import sys, os + +args = sys.argv[1:] + +if len(args) == 0: +	print('usage: %s (icon | file | directory) ... < icon-forest' % sys.argv[0], file = sys.stderr) +	exit(1) + +forest = {} +selected = {} + +try: +	while True: +		line = input() +		if not line.strip(): +			continue +		if not line.startswith('\t'): +			tree = [] +		icon = line.strip() +		tree.append(line) +		if icon in forest: +			print('duplicate entry of %s found' % icon, file = sys.stderr) +		forest[icon] = (tree, len(tree) - 1) +except EOFError: +	pass + +basenames = {} +for icon in forest: +	iconbasename = icon.split('/')[-1] +	icons = basenames.get(iconbasename, []) +	icons.append(icon) +	basenames[iconbasename] = icons + +def select(icon): +	if icon in forest: +		(tree, line) = forest[icon] +		lines = selected.get(tree[0], {}) +		lines[line] = None +		selected[tree[0]] = lines +	elif icon.split('/')[-1] in basenames: +		icondir = '/'.join(icon.split('/')[:-1]) +		for alticon in basenames[icon.split('/')[-1]]: +			(tree, line) = forest[alticon] +			lines = selected.get(tree[0], {}) +			if line not in lines: +				lines[line] = [icondir] +			elif lines[line] is None: +				continue +			else: +				lines[line].append(icondir) +			selected[tree[0]] = lines + +def visit(d): +	for f in os.listdir(d): +		f = d + '/' + f +		if os.path.isfile(f): +			icon = '/'.join('.'.join(f.split('.')[:-1]).split('/')[-2:]) +			select(icon) +		elif os.path.isdir(f): +			visit(f) + +for icon in args: +	if os.path.isfile(icon) and '/' in icon and icon.endswith('.svg'): +		icon = '/'.join(icon[:-4].split('/')[-2:]) +	elif os.path.isdir(icon): +		visit(icon) +		continue +	select(icon) + +for tree in sorted(selected): +	lines = selected[tree] +	(tree, _) = forest[tree] +	for i, line in enumerate(tree): +		if i not in lines: +			print(line) +		elif lines[i] is None: +			print('\033[1;31m%s\033[m' % line) +		else: +			print('\033[1;33m%s\033[;33m (%s)\033[m' % (line, ', '.join(sorted(lines[i])))) diff --git a/tools/sortforest b/tools/sortforest new file mode 100755 index 0000000..bbb2faa --- /dev/null +++ b/tools/sortforest @@ -0,0 +1,85 @@ +#!/usr/bin/env python3 +import sys + +if len(sys.argv) > 1: +	print('usage: %s < icon-forest' % sys.argv[0], file = sys.stderr) +	exit(1) + +standalone = set() +pairs = [] +stack = [] +try: +    while True: +        line = input() +        if not line.strip(): +            continue +        indent = 0 +        while line.startswith('\t'): +            indent += 1 +            line = line[1:] +        assert not line.startswith(' ') +        assert not line.endswith(' ') +        assert '\t' not in line +        assert indent <= len(stack) +        stack = stack[:indent] +        stack.append(line) +        if indent == 0: +            standalone.add(line) +        else: +            pairs.append((stack[indent - 1], line)) +except EOFError: +    pass + +tree = {} +retree = {} +for parent, child in pairs: +    if parent == child: +        continue +    if child in retree: +        if retree[child] == parent: +            continue +        print('%s appears in the tree twice' % child, file = sys.stderr) +        if parent in retree: +            exit(1) +        print('reversing with parent %s\n' % parent, file = sys.stderr) +        (parent, child) = (child, parent) +    if parent in tree: +        tree[parent].append(child) +    else: +        tree[parent] = [child] +    retree[child] = parent + +forest = {} +printed = {} +def printtree(this_tree, node, root, indent = ''): +    if node in forest: +        subtree = forest[node] +        del forest[node] +        this_tree.extend([(indent + subnode) for subnode in subtree]) +        return +    if node in printed: +        if indent: +            this_tree.append(indent + node) +        return +    this_tree.append(indent + node) +    printed[node] = root +    indent = indent + '\t' +    if node in tree: +        for child in sorted(tree[node]): +            if child != root: +                printtree(this_tree, child, root, indent) +defered = [] +for root in sorted(standalone): +    if root in tree: +        mytree = [] +        printtree(mytree, root, root) +        forest[root] = mytree +    else: +        defered.append(root) + +for tree in sorted(forest): +    for line in forest[tree]: +        print(line) +for stub in sorted(defered): +    if stub not in printed: +        print(stub) | 
