295 lines
5.3 KiB
Plaintext
295 lines
5.3 KiB
Plaintext
|
use re
|
|||
|
use str
|
|||
|
|
|||
|
var cmd = $e:qpdf~
|
|||
|
|
|||
|
fn -is-pdf {|f|
|
|||
|
str:has-suffix $f .pdf
|
|||
|
}
|
|||
|
|
|||
|
fn -is-number {|arg|
|
|||
|
re:match '^\d+$' $arg
|
|||
|
}
|
|||
|
|
|||
|
fn -is-rotate {|arg|
|
|||
|
re:match '^(\+|-)(\d+):.*' $arg
|
|||
|
}
|
|||
|
|
|||
|
fn -is-seq {|arg|
|
|||
|
re:match '^\d+(,\d+)*$' $arg
|
|||
|
}
|
|||
|
|
|||
|
fn -must-pdf {|f|
|
|||
|
if (not (-is-pdf $f)) {
|
|||
|
fail $f' n’est pas un fichier PDF'
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn -must-not-exist {|f|
|
|||
|
var exist = ?(stat $f 2>&- > /dev/null)
|
|||
|
if (bool $exist) {
|
|||
|
fail $f' existe déjà'
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn -must-exist {|f|
|
|||
|
var exist = ?(stat $f 2>&- > /dev/null)
|
|||
|
if (not (bool $exist)) {
|
|||
|
fail $f' n’existe pas'
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn -make-tmp {
|
|||
|
mktemp -q /tmp/qpdf_XXXXXXXXXX.pdf
|
|||
|
}
|
|||
|
|
|||
|
fn -make-seq {|seq|
|
|||
|
if (not (-is-seq $seq)) {
|
|||
|
fail $seq': pas une séquence'
|
|||
|
}
|
|||
|
set @seq = (order (str:split , $seq))
|
|||
|
var b = 1
|
|||
|
each {|ei|
|
|||
|
var e = (- $ei 1)
|
|||
|
if (== $b $e) {
|
|||
|
put $b
|
|||
|
set b = $ei
|
|||
|
} elif (< $b $e) {
|
|||
|
put $b'-'$e
|
|||
|
set b = $ei
|
|||
|
}
|
|||
|
} $seq
|
|||
|
put $b'-z'
|
|||
|
}
|
|||
|
|
|||
|
fn -out {|in suffix|
|
|||
|
var out = (str:trim-suffix $in .pdf)
|
|||
|
str:join '' [ $out .pdf ]
|
|||
|
}
|
|||
|
|
|||
|
fn -parse-selection {|in selection|
|
|||
|
if (-is-rotate $selection) {
|
|||
|
var out = (-make-tmp)
|
|||
|
var i = (str:index $selection :)
|
|||
|
var r sel = $selection[..$i] $selection[(+ $i 1)..]
|
|||
|
if (eq sel '') {
|
|||
|
set @sel = $in
|
|||
|
} else {
|
|||
|
set @sel = $in $sel
|
|||
|
}
|
|||
|
$cmd --empty --pages $@sel -- $out
|
|||
|
$cmd $out --replace-input --rotate=$r
|
|||
|
put $out
|
|||
|
} else {
|
|||
|
put $in $selection
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn -parse-all {|args|
|
|||
|
var tmpfiles = []
|
|||
|
var selection = []
|
|||
|
var in = $nil
|
|||
|
var miss = $nil
|
|||
|
try {
|
|||
|
each {|e|
|
|||
|
if (-is-pdf $e) {
|
|||
|
-must-exist $e
|
|||
|
if (not-eq $miss $nil) {
|
|||
|
set @selection = $@selection $miss
|
|||
|
set miss = $e
|
|||
|
}
|
|||
|
set in = $e
|
|||
|
} else {
|
|||
|
if (eq $in $nil) {
|
|||
|
fail 'Le pagerange doit être déclaré après un fichier d’entrée'
|
|||
|
}
|
|||
|
var @s = (-parse-selection $in $e)
|
|||
|
if (== (count $s) 1) {
|
|||
|
set @tmpfiles = $@tmpfiles $@s
|
|||
|
}
|
|||
|
set @selection = $@selection $@s
|
|||
|
}
|
|||
|
} $args
|
|||
|
} finally {
|
|||
|
put $selection $tmpfiles
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn -merge {|&collate=$nil selection out|
|
|||
|
if (< (count $selection) 1) {
|
|||
|
fail 'Aucune sélection'
|
|||
|
}
|
|||
|
var @args = --empty --pages $@selection -- $out
|
|||
|
if (not-eq $collate $nil) {
|
|||
|
if (-is-number $collate) {
|
|||
|
set @args = $collate $@args
|
|||
|
}
|
|||
|
set @args = --collate $@args
|
|||
|
}
|
|||
|
$cmd $@args
|
|||
|
}
|
|||
|
|
|||
|
fn merge {|@args|
|
|||
|
var l = (- (count $args) 1)
|
|||
|
if (< $l 1) {
|
|||
|
fail "la commande doit contenir au moins 2 paramètres"
|
|||
|
}
|
|||
|
var out = $args[$l]
|
|||
|
-must-pdf $out
|
|||
|
-must-not-exist $out
|
|||
|
|
|||
|
var sel tmp = [] []
|
|||
|
try {
|
|||
|
set sel tmp = (-parse-all $args[..$l])
|
|||
|
-merge $sel $out
|
|||
|
} finally {
|
|||
|
if (> (count $tmp) 0) {
|
|||
|
rm -f $@tmp
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn split {|@args|
|
|||
|
var l = (- (count $args) 1)
|
|||
|
if (< $l 1) {
|
|||
|
fail "la commande doit contenir au moins 2 paramètres"
|
|||
|
}
|
|||
|
var out = $args[$l]
|
|||
|
-must-pdf $out
|
|||
|
-must-not-exist $out
|
|||
|
set args = $args[..$l]
|
|||
|
|
|||
|
var size = $nil
|
|||
|
if (-is-number $args[0]) {
|
|||
|
set size @args = @args
|
|||
|
}
|
|||
|
|
|||
|
var sel tmp = [] []
|
|||
|
try {
|
|||
|
set sel tmp = (-parse-all $args[..$l])
|
|||
|
var t = (-make-tmp)
|
|||
|
-merge $sel $t
|
|||
|
set @tmp = $@tmp $t
|
|||
|
var @ac = --split-pages
|
|||
|
if (not-eq $size $nil) {
|
|||
|
set @ac = $@ac $size
|
|||
|
}
|
|||
|
set @ac = $@ac $t $out/%d.pdf
|
|||
|
mkdir $out
|
|||
|
$cmd $@ac
|
|||
|
} finally {
|
|||
|
if (> (count $tmp) 0) {
|
|||
|
rm -f $@tmp
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn split-at {|@args|
|
|||
|
var l = (- (count $args) 1)
|
|||
|
if (< $l 2) {
|
|||
|
fail "la commande doit contenir au moins 3 paramètres"
|
|||
|
}
|
|||
|
var out = $args[$l]
|
|||
|
-must-pdf $out
|
|||
|
-must-not-exist $out
|
|||
|
var @seq = (-make-seq $args[0])
|
|||
|
set args = $args[1..$l]
|
|||
|
|
|||
|
var sel tmp = [] []
|
|||
|
try {
|
|||
|
set sel tmp = (-parse-all $args[..$l])
|
|||
|
var t = (-make-tmp)
|
|||
|
-merge $sel $t
|
|||
|
set @tmp = $@tmp $t
|
|||
|
var i = 1
|
|||
|
each {|s|
|
|||
|
$cmd --empty --pages $t $s -- $out/$i.pdf
|
|||
|
set i = (+ $i 1)
|
|||
|
} $seq
|
|||
|
} finally {
|
|||
|
if (> (count $tmp) 0) {
|
|||
|
rm -f $@tmp
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn zip {|@args|
|
|||
|
var l = (- (count $args) 1)
|
|||
|
if (< $l 1) {
|
|||
|
fail "la commande doit contenir au moins 2 paramètres"
|
|||
|
}
|
|||
|
var out = $args[$l]
|
|||
|
var col = $true
|
|||
|
-must-pdf $out
|
|||
|
-must-not-exist $out
|
|||
|
set args = $args[..$l]
|
|||
|
|
|||
|
if (-is-number $args[0]) {
|
|||
|
set col @args = $@args
|
|||
|
}
|
|||
|
|
|||
|
var sel tmp = [] []
|
|||
|
try {
|
|||
|
set sel tmp = (-parse-all $args)
|
|||
|
-merge &collate=$col $sel $out
|
|||
|
} finally {
|
|||
|
if (> (count $tmp) 0) {
|
|||
|
rm -f $@tmp
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn unzip {|@args|
|
|||
|
echo '<en construction…>'
|
|||
|
}
|
|||
|
|
|||
|
fn decrypt {|@args|
|
|||
|
var l = (count $args)
|
|||
|
if (or (< $l 1) (> $l 3)) {
|
|||
|
fail "decrypt doit contenir entre 1 et 3 paramètres"
|
|||
|
}
|
|||
|
var in = $args[0]
|
|||
|
-must-pdf $in
|
|||
|
-must-exist $in
|
|||
|
var out = (-out $in _decrypted.pdf)
|
|||
|
var p = $nil
|
|||
|
if (> $l 1) {
|
|||
|
set p = $args[1]
|
|||
|
if (== $l 3) {
|
|||
|
set out = $args[2]
|
|||
|
-must-pdf $out
|
|||
|
}
|
|||
|
}
|
|||
|
-must-not-exist $out
|
|||
|
if (eq $p $nil) {
|
|||
|
$cmd $in $out --decrypt
|
|||
|
} else {
|
|||
|
$cmd $in $out --decrypt $p
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fn help {|@args|
|
|||
|
cat $E:HOME/.config/elvish/aliases/qpdf.help
|
|||
|
}
|
|||
|
|
|||
|
fn info {|@args|
|
|||
|
echo '<en construction…>'
|
|||
|
}
|
|||
|
|
|||
|
edit:add-var epdf~ {|action @args|
|
|||
|
var actions = [
|
|||
|
&merge=$merge~
|
|||
|
&split=$split~
|
|||
|
&split-at=$split-at~
|
|||
|
&zip=$zip~
|
|||
|
&unzip=$unzip~
|
|||
|
&decrypt=$decrypt~
|
|||
|
&help=$help~
|
|||
|
&info=$info~
|
|||
|
]
|
|||
|
if (not (has-key $actions $action)) {
|
|||
|
fail $action': action inconnue'
|
|||
|
}
|
|||
|
$actions[$action] $@args
|
|||
|
}
|