aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile18
-rw-r--r--man/unixize.1173
-rw-r--r--src/c_opts.c8
-rw-r--r--src/c_unixize.c7
4 files changed, 176 insertions, 30 deletions
diff --git a/Makefile b/Makefile
index 21950b4..737127c 100644
--- a/Makefile
+++ b/Makefile
@@ -11,7 +11,7 @@
# ========================
#
# unixize: Makefile
-# 2020-11-02 21:43
+# Fri Nov 27 22:53:29 CET 2020
# Joe
#
# GNU Makefile
@@ -19,18 +19,18 @@
.DEFAULT_GOAL := all
SHELL := /bin/sh
-DESTDIR =
-SRCS_DIR = src/
-OBJS_DIR = obj/
-MAN_DIR = man/
+DESTDIR :=
+SRCS_DIR := src/
+OBJS_DIR := obj/
+MAN_DIR := man/
-CC := cc
-CFLAGS = -std=c89
+CC ?= cc
+CFLAGS += -std=c89
CFLAGS += -Wall
CFLAGS += -Wextra
CFLAGS += -Werror
CFLAGS += -pedantic
-CFLAGS += -march=ivybridge -O2 -pipe
+CFLAGS += -march=native -O2 -pipe
MKDIR := mkdir -p
RM := rm -f
@@ -38,7 +38,7 @@ INSTALL := install
GZIP := gzip
GUNZIP := gunzip
-SRCS_NAME = c_lfiles
+SRCS_NAME := c_lfiles
SRCS_NAME += c_opts
SRCS_NAME += c_subst
SRCS_NAME += c_unixize
diff --git a/man/unixize.1 b/man/unixize.1
index 6f5923c..a6ca6d6 100644
--- a/man/unixize.1
+++ b/man/unixize.1
@@ -38,8 +38,7 @@
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
.\"
.\" unixize: man/unixize.1
-.\" 2020-11-14 20:57
-.\" date
+.\" Fri Nov 27 22:55:32 CET 2020
.\" Joe
.\"
.\" Manpage for unixize.
@@ -55,15 +54,15 @@
.Text \\$3\(lq\fB\\$1\f[]\(rq\\$2
..
.de file_example
-.P
+.PP
.RS
\`\\$1\' \-\> \`\\$2\'
.RE
-.P
+.PP
..
.
.
-.TH unixize 1 "15 November 2020" "unixize 1.0"
+.TH unixize 1 "27 November 2020" "unixize 1.0"
.
.
.SH NAME
@@ -82,7 +81,7 @@
.
.
.SH DESCRIPTION
-.P
+.PP
The
.B unixize
utility renames all file in a given
@@ -92,7 +91,7 @@ to a predefined style. Here is a description of the
behaviour without options. This behavious can be changed using options, see
\(lqOPTIONS\(rq below. By default:
.
-.P
+.PP
.
All upper-case characters will be set to lower-case.
.
@@ -101,39 +100,185 @@ All upper-case characters will be set to lower-case.
Spaces will be substitued by a
.BR separator ,
by default underscores
-.squoted_text _ ) (
+.squoted_text _ ). (
.
.file_example "a file with spaces.org" "a_file_with_spaces.org"
.
Multiple spaces will be condensed into only one
-.BR sparator .
+.BR separator .
.
.file_example "lots of spaces.gif" "lots_of_spaces.gif"
.
+By default the
+.BR "opposite separator"
+is hyphen
+.squoted_text - ). (
+All
+.BR "opposite separator"
+will be changed to the chosen
+.BR separator ,
+underscores
+.squoted_text _ ) (
+by default.
+.
+.file_example "2004-with-the-lights-out" "2004_with_the_lights_out"
+.
All unicode characters will be deleted
except for latin extended ascii characters, which will be replaced by the most
relevant ascii character (or double characters).
.
-.file_example "\(Eu\-Hliðskjálf-\(de\(dd.jpg" "hlidhskjalf.jpg"
+.file_example "\(EuHliðskjálf\(de\(dd.jpg" "hlidhskjalf.jpg"
.
Two special patterns are always substitued, regardless of options.
-.P
-The first one is
+.PP
+The first sequence is
.dquoted_text C\+\+ ,
which will always be changed to
.dquoted_text cxx
whether the letter
.squoted_text C
is upper-case or lower-case.
-.P
.
.file_example "learn_c++_programming.pdf" "learn_cxx_programming.pdf"
.
-The second one is removes the first dot
+The second one is the special case where the filename begins with a number,
+followed directly by a dot
+.squoted_text . ) (
+and another dot
.squoted_text . ) (
+can be found later in the filename (for example the file's extension). In this
+case, the first dot is removed.
+.
+.file_example "07. Negative Creep.flac" "07_negative_creep.flac"
+.
+If another dot
+.squoted_text . ) (
+can't be found, nothing is changed.
+.
+.file_example "255.sql" "255.sql"
+.
+In the case where the renamed version of a file is already present in the
+.I directory
+(for example if \(lqREADME\(rq is being unixized but another \(lqreadme\(rq
+already exists), or if the renamed version is empty of text, the renaming of
+this file will be skipped.
.SH OPTIONS
+.TP
+.B \-a
+Include directory entries whose names begin with a dot
+.squoted_text . ). (
+.TP
+.BI \-e\c ext
+Unixize certain file extensions.
+.I ext
+can be either
+.IR 0 ,
+.I 1
+or
+.IR 2 .
+Some file extensions are often prefered over other ones to specify the same file
+type in UNIX-like operating systems. With
+.I ext
+set to
+.IR 1 ,
+.dquoted_text .asm
+extensions will be changed to
+.dquoted_text .S ,
+.dquoted_text .cpp
+extensions will be changed to
+.dquoted_text .cc ,
+.dquoted_text .hpp
+extensions will be changed to
+.dquoted_text .hh
+and
+.dquoted_text .txt
+files will see their extension removed. When
+.I ext
+is set to
+.IR 2 ,
+all the previous rules are applied as well except that
+.dquoted_text .cpp
+extensions will be changed to
+.dquoted_text .cxx
+and
+.dquoted_text .hpp
+extensions will be changed to
+.dquoted_text .hxx .
+Default:
+.IR 0 .
+.TP
+.B \-h
+Output a brief help message.
+.TP
+.B \-i
+Prompt user before running
+.B unixize
+on the specified directory. If the
+.B \-R
+option is being used, the user will be prompted for each subdirectory the
+program is entering.
+.TP
+.B \-k
+Keep the opposite separator occurences in the filename. If the
+.B \-n
+option is not being used, all existing hyphens
+.squoted_text - ) (
+will be preserved. Otherwise, all existing underscores
+.squoted_text _ ) (
+will be kept.
+.RS 12
+\`screen 2020-10-21.mkv\' \-\> \`screen_2020-10-21.mkv\'
+.RE
+.TP
+.B \-n
+Use hyphens
+.squoted_text - ) (
+instead of underscores
+.squoted_text _ ) (
+as a
+.B separator
+and sets underscores as the
+.BR "opposite separator" .
+.RS 12
+\`04 School.mp3' \-\> \`04-school.mp3\'
+.RE
+.RS 12
+\`11-27_958x1078_scrot.png\' \-\> \`11-27-958x1078-scrot.png\'
+.RE
+.TP
+.B \-p
+Pretend only.
+.B unixize
+will run normally but will not actually rename any file. This
+option is intended to be used with the
+.B \-v
+and/or
+.B \-r
+options.
+.TP
+.B \-R
+Recursive mode. The program will enter and repeat into every subdirectories.
+.TP
+.B \-r
+Reverse verbose mode. Files that are not being renamed will be displayed to
+stdout.
+.TP
+.B \-v
+Verbose mode. File that are being renamed will be displayed to to stdout as well
+as their new version.
+.
+.SH BUG REPORT
+Please note that
+.B unixize
+was tested only on FreeBSD at the moment. Linux and macOS tests are coming soon.
+You can report bug at
+.I rbousset@42lyon.fr
+or on GitHub at
+.IR github.com/JozanLeClerc/unixize.git .
+.
.SH SEE ALSO
.IR ascii (7),
.IR ls (1),
+.IR tree (1),
.IR rename (2)
.\" vim: set filetype=groff:
diff --git a/src/c_opts.c b/src/c_opts.c
index 996643e..1664523 100644
--- a/src/c_opts.c
+++ b/src/c_opts.c
@@ -160,7 +160,7 @@ c_get_opts
}
else if (opt == 'h') {
c_dump_usage();
- exit(0);
+ exit(EXIT_SUCCESS);
}
else if (opt == 'i') {
opts->confirm = TRUE;
@@ -190,7 +190,7 @@ c_get_opts
C_C_OPT_FMT,
optarg
);
- exit(1);
+ exit(EXIT_FAILURE);
}
else {
opts->cxx = optarg[0] - 48;
@@ -198,7 +198,7 @@ c_get_opts
}
else if (opt == '?') {
c_dump_usage();
- exit(1);
+ exit(EXIT_FAILURE);
}
}
if (
@@ -206,7 +206,7 @@ c_get_opts
argv[optind] == NULL
) {
c_dump_usage();
- exit(1);
+ exit(EXIT_FAILURE);
}
if (
argv[0][0] != C_RECURSIVE_CHAR &&
diff --git a/src/c_unixize.c b/src/c_unixize.c
index f6b7b87..b3fb265 100644
--- a/src/c_unixize.c
+++ b/src/c_unixize.c
@@ -52,6 +52,7 @@
#include <locale.h>
#include <stdio.h>
#include <stddef.h>
+#include <stdlib.h>
#include <string.h>
#include <unistd.h>
@@ -80,7 +81,7 @@ main
static char path[MAXPATHLEN] = "";
if (c_get_opts(&opts, argc, argv) == FALSE) {
- return (0);
+ return (EXIT_SUCCESS);
}
if (
argv[0][0] != 'r'
@@ -91,7 +92,7 @@ main
}
og_files = c_lfiles_gather(path);
if (og_files == NULL) {
- return (0);
+ return (EXIT_SUCCESS);
}
new_files = c_subst_filenames(
og_files,
@@ -101,7 +102,7 @@ main
);
if (new_files == NULL) {
c_lfiles_clear(&og_files);
- return (1);
+ return (EXIT_FAILURE);
}
og_files_head = og_files;
new_files_head = new_files;