Annotation of scripts/pgallery/src/libpgallery.sh, revision 1.3

1.1       as          1: #!/bin/sh
                      2: #
                      3: # THE BEER-WARE LICENSE 2012
                      4: # <as@paefchen.net> wrote this file. As long as you retain this notice you
                      5: # can do whatever you want with this stuff. If we meet some day, and you think
                      6: # this stuff is worth it, you can buy me a beer in return Aron Schlesinger
                      7: #
1.3     ! as          8: # $Paefchen: scripts/pgallery/src/libpgallery.sh,v 1.2 2012/08/31 14:26:58 as Exp $
1.1       as          9: #
                     10: 
                     11: BIN_CONVERT="/usr/local/bin/convert"
                     12: BIN_EXIFAUTOTRAN="/usr/local/bin/exifautotran"
                     13: BIN_IMGINFO="/usr/local/bin/imginfo"
                     14: BIN_SENDMAIL="/usr/sbin/sendmail"
                     15: BIN_EXIFTRAN="/usr/local/bin/exiftran"
                     16: BIN_EXIF="/usr/local/bin/exif"
                     17: 
                     18: ARGFILE=".htpgallery"
                     19: VERSION="pgallery-1.3"
                     20: 
                     21: #
                     22: # get_my_path()
                     23: #
                     24: get_my_path()
                     25: {
                     26:        current=$(pwd)
                     27:        cd $(dirname $0)
                     28:        echo $(pwd)/$(basename $0)
                     29:        cd "$current"
                     30: }
                     31: 
                     32: #
                     33: # html_header()
                     34: #
                     35: html_header()
                     36: {
                     37:        cat <<HTML
                     38: <?xml version="1.0" encoding="utf-8"?>
                     39: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
                     40:        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
                     41: <html xmlns="http://www.w3.org/1999/xhtml">
                     42: <head>
                     43:        <title>$ARG_TITLE</title>
                     44:        <meta http-equiv="content-type" content="text/html; charset=utf-8" />
                     45:        <style type="text/css">
                     46:        <!--
                     47: body {
                     48:        background-color: #464646;
                     49:        background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFgAAABYB\
                     50: AMAAACDuy0HAAAAG1BMVEX+/v4BAQH///8KCgoDAwN/f3/19fWAgID8/PzhDwT2AAAACXRSTlMFBQUFBQU\
                     51: FBQWHDtP9AAALwklEQVR4Xg3KOWOyWhAA0Bn2ci57eXEvQY1JCZp8sQTjVoJLTAkaE0swbj/7ve4UB37FL\
                     52: W4q86Lwwlh86J/ASAkpWaj+Krbb31HzH0Kjc2tIl7SADaWbpZBPE5dds6jJNyNdjAyKWqdroIixWRQIY6E\
                     53: /kOY7hIciL/ZfrAO3XP/06AuUJ3mSd/z95OB9vIal0DPlaZWHP7RE6DIXjmKqKkuGr+xNZylOnj1GSlUKv\
                     54: nxZDBOIzTfMe0fJgJ7c/GIIOdUuKxYyBFUOzvY6AC5AXx8R+o5O4S0j0wqBND3ErIYm/XHFbQjtH1MXD5d\
                     55: Ubp19OFdjkDlys+HSwrBgHRvL9wVN/pi8ViOIwcv/D1GRW6UuDvJLLQA5lCI17iUdsKYpOuYfMATGnpn/Z\
                     56: s3W6gov51G+/Vs9Ay//we5kh8uwvEPum6o5HkDMDb3ZWunwtq+UzENU8NphDdbvNtKM3knx5gi6UMSQl+e\
                     57: Gs+27mraDtxeWdH+T62Us/GylEtr7Ct8jlbeXKvAf5onx8D2uVt1J/GblV+XQyKUInOUG44fqjcszK266y\
                     58: HWAAYG9ekhvy4l4Maa44jYVyV2RFEuS54e2HcswtmNdqR/+V4P0O9e4XnpWgxVSQkNXpYMCxJ4Vel0lmi5\
                     59: 6jnYIIJAQMndF+zTEiyuj92r3ijJT1O0alPQnLWJvJLR7Xx7Xg9fm9QOqFu8o29m3QQqFwZN4bki/RoprN\
                     60: tMKKtEET9iMsJyKpkiguAorn2yzkv0wG3M1EEVDJP5VN7muLjYCglzdGQ7boYGgRmorzhRDq83gglgylC+\
                     61: hBLEyy6ZQWNwCmmqt6PvExAqGEA9V2XIT4/fS+I2cx1n5td85kOCjHfPWTg72FJ/+vKOyggt+rytFbEDJW\
                     62: L+mPwpgw6HtFLIHmq4o2m1nZ9saKwiKEOTVZtWlnqHODPu949VfKD+zzpfynd/ZZU5IWZ0dgnqRHC4uOBp\
                     63: BsT8N7YbFJzADiW2eo/T979OKFxY8zk/+HR/NNEkzgSBsmA35Sayz1m/ubxgmYQOmffyRh9gdx42mUVX51\
                     64: 2oqWkfxAzyuSCxx1cywx3jIXuXJEEbssymo0xMy7SskJW9C5IPYroPwQunt7f5FEPPXJLWRbGHcL4Q3sx3\
                     65: TLAN6W672r/I5CKkL6zSwwk0AI8+iBCSv1Y7QQP5RSoLE227uy8vn22Y6dhLBgEsRh18cTGjIv3y+60Kmt\
                     66: 3YAZQX8qf3bJDUc/5pdjti+KwAZ9GzzQzd23d1JBAnSvWkWB8YfsIGlspHitNiMPYPFfR+OecRuPyxgfoP\
                     67: 9/HkR3cR27IohiaDXCk/3VNP6lIxP9TBnsMeAAUZloq6P8KURLBsNFuiA3LsN/d9qpCeKKIBgSzsN5k+rd\
                     68: h3uh0VbvMuOIomJD1fBOiCqIsvklS5bOQhMaahJC+Rc+6lz+Uvxmq05Py+LoGIQlLKvlcaHsFG9Ui66H/q\
                     69: dHz67sPRGho+ruC92QgN5JEMmLsZREEiJu78FJbyzT8FsdK90XoEcezn2R5iLUzZhczJmf1yNY3gJNJUQv\
                     70: bpTznTAbnV5J8iL4q2OWuhJEndWVTyEr8M5VGTWtvOmUo1DsnOsqXE5ZzKE8K4/8cl8+c1XArp1RUKz+iK\
                     71: P96j2FcUmA+v0HnEr0iUdSrRK5duAj1FQamvpiaXR2JddD6g8n4SyFx/fjT4LkC+ghJckj1e1wP+DrHrpI\
                     72: iMaPH5F1rcaRvwZWfEn6fx+/C7PdXABGLNKjr1USZ5XyHjsafXMEoXtguAfjykMioMMHISXVAc9yQY5o5Q\
                     73: g8MM0nhWCA2HoiEgBc1EH+warLjxH3Ln68M/ciFqI1bG0mBOxiNreOuShEf/9pIzhm1Bh2cbYVxn2IYQ7e\
                     74: ljYpab/5EdPF2PSmcy+62j6e2HBPNbe+8JVMuRQBrWdL9uBh4bYbQaQJ07FyfcpCuvSuxUyYjP6avvw9gT\
                     75: cAj0uTVohSwOHDDaHTs8nyachMBcWoVDWp3/lWgqeCLMneAUhSuhD2RJpufLOSi7emxOVhYsOGomV2JCEK\
                     76: jWu7kuqwueyFEmDgVhR0l4oHn8W87UZuxb8id54SxHWiSnPKnMyAhzdhi2wN/AoH3OYwLajuybB8h/QeJJ\
                     77: iX1gIt+dfij+gr0CJRXQ2Y04Q6q8xHzfWm9FIgchiW0+X86tIotIGzRG1gENaKokQkLn+FXZ2x3KUcp7d/\
                     78: NUsmOmFCG/i03YB8pi0eiNS4LUIfA06AKvfQmP/VAXS1AP2kzJ+9LAaTafvFyO7bz8U9OCpld2q1eHGts+\
                     79: ZFrt04AmIlubOPP7Xayfi/r0tiX2aaPT9Dz4+TVPBoXsjHDzWfrmawOsZfmBT/k2+c6sz/hvD5wjrjT7Xg\
                     80: RlnEzPuZermi1jqfUrE3q7VdFfJu5oT9Ad+VUh1fIwIFhBy8TmMuhIeX2XpmogmvS1C3ZuwiyR87ZSrj0J\
                     81: v1DpEAYkbcL3RpjZXmZpPV4mXH8z8Nh8CS+R+PpcTnkhyr5UJaSiz0wjK22Ewl+zS+pTug0PQ0CSnJQ5Lf\
                     82: dR77vVZufgjkQ/ydf4V5zpEaNq+JZmrQK6WdZBacmMHL9RmLnPUs0/MYwYFzoyrXYQMTHGAUJOfumR5r79\
                     83: MZO28DIEXQVT5wGw99TY1T0GOCC/BzWv8READwICd0LjUNKnE6ORVa0lOnqhoO0v33lwWcwF0ynTgTpFxy\
                     84: +0OKdphNDWJlH8ubKoG6WJXtKxAwbsilpBJB+GBwimvTsCrv1R7LSX9ExkAw44ZEcxU3L50OHnKAyKZNe1\
                     85: fih+hVqItRGCDf7shuvme+lTWteX5oYuc58NrCaqjYIrIV0PFyQeh2ZzZEqNS60LuhnP5wweMkkaU93pDA\
                     86: /RWPNeGpPCBgiUeDvV0L1NfdRP/Hn5i7rUK7kftlIWeIUIYbtzzFl9nlIeaNfoX+x/qyWzIABLTZDbeq/h\
                     87: DZpxg2gkh+ICfSU8OUpJ8yWY17uQ5EGa+GGWFmnrBd9vX3KOteYkJaMpPwJ4TjzDjbhkOMKmWKClzVJ2g8\
                     88: 1YGFl/c0xPIKncgJGdUKvZoUUJu0gYaIAh6E0xNeQ15qpJXzNITgf4W+w/oUaKOM54EMUi1j5yvOCsEe8J\
                     89: YpwVGj53lNiPMY9Rltgd4icp82fvN69zkSBUI40nJSRTeHz7h1IX42Cr0klWjxjO05MSX1IaTeDmTRGEeK\
                     90: vAvtaaBaLQnjftGJz+4cjFyy6/iCjLGF2/gW+jQhEUxbEBPyQzXi+Bb4kc9wK4jIwNLWbwQAOtYKRLaipD\
                     91: H+X4TPPOG8DCNY4IC9yBk1qcibjhUgRnDcf35pl9d5otbvQjOIXlEu5dVtm5LRaK5KWcD/PX6LaGd25CuN\
                     92: HG/vgeIB1kcpCme+J8idlcjfBALAJSggznsGHGOAJgdGduMnZg+bAaeGASGV9bh/X2wPsVTmBLxmTTQsBG\
                     93: FkEOkZJTsGAm+HrtMDbWwvTXOutX1u7BxIq9Xib6DkFMbUitNdrYsULkahsAhBEh9FjdzL9BNARxTSr7T3\
                     94: u1rE+IWUmCIpwTZHZCu5l9THCuCcOhZqfekuQxjQ7EoyGUJAwCv/q1JOuJeCc/3lknb76zAquO/DAQhK/6\
                     95: 2cP8X2s3+IBLIhvL8RHopoHpIArJysYTTmMMeubPXh8W760AvMVH67jqgg06+/ne5MZ631z6yROhloh3dP\
                     96: QirZoEpr80wgt/cEbhbAQTmRLtGh8lxCwDBBb5OeJ4aEq25XBNMT2rzWedW2zIzj+CCDKlnlyJBzT81qBW\
                     97: p69h7vlb3TmEV+DNm2rqj1iT7BQuwVVsuPkwq1e5P8tgNjVbIlMzwXeM11kZqjx3KKFOJzc3CAyFVhi8fx\
                     98: VZ5FvhdAM5mM6kS6OgKu16MFglq3/b/QVIwdw7HUCyeW04JPjC5dO+GC9OfqfB4VX+wwuift+ths2Ss3i6\
                     99: nkOE+JFyD+wKFL+WMX6nwwDva0S1/O8Mlnida69Ph96fuFvCoRMvXnCfsLPPmC/hA5RnMNE4fDK0pVOQ4B\
                    100: HLaErzv/wD99ABmjNZk0AAAAABJRU5ErkJggg==");
                    101:        margin: 10px auto;
                    102:        font-family: Geneva,Arial,sans-serif;
                    103:        font-size: 12px;
                    104:        text-shadow: 1px 1px 1px #000;
                    105:        color: #808080;
                    106: }
                    107: div.tn {
                    108:        float: left;
                    109:        width: ${ARG_TNSIZE}px;
                    110:        vertical-align:text-top;
                    111:        text-align: center;
                    112:        margin: 4px;
                    113: }
                    114: div.t {
                    115:        text-overflow: ellipsis;
                    116:        overflow: hidden;
                    117:        white-space: nowrap;
                    118:        margin-bottom: 1px;
                    119:        background: rgb(38,38,38); /* Old browsers */
                    120:        background: -moz-linear-gradient(top, rgba(38,38,38,1) 0%, rgba(53,53,53,1) 50%, rgba(48,48,48,1) 51%, rgba(73,73,73,1) 100%); /* FF3.6+ */
                    121:        background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(38,38,38,1)), color-stop(50%,rgba(53,53,53,1)), color-stop(51%,rgba(48,48,48,1)), color-stop(100%,rgba(73,73,73,1))); /* Chrome,Safari4+ */
                    122:        background: -webkit-linear-gradient(top, rgba(38,38,38,1) 0%,rgba(53,53,53,1) 50%,rgba(48,48,48,1) 51%,rgba(73,73,73,1) 100%); /* Chrome10+,Safari5.1+ */
                    123:        background: -o-linear-gradient(top, rgba(38,38,38,1) 0%,rgba(53,53,53,1) 50%,rgba(48,48,48,1) 51%,rgba(73,73,73,1) 100%); /* Opera 11.10+ */
                    124:        background: -ms-linear-gradient(top, rgba(38,38,38,1) 0%,rgba(53,53,53,1) 50%,rgba(48,48,48,1) 51%,rgba(73,73,73,1) 100%); /* IE10+ */
                    125:        background: linear-gradient(to bottom, rgba(38,38,38,1) 0%,rgba(53,53,53,1) 50%,rgba(48,48,48,1) 51%,rgba(73,73,73,1) 100%); /* W3C */
                    126:        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#262626', endColorstr='#494949',GradientType=0 ); /* IE6-9 */
                    127: }
1.2       as        128: div.tn div.t {
                    129:        width: $(($ARG_TNSIZE - 8))px;
                    130:        height: 20px;
                    131:        padding: 0 4px;
                    132:        line-height: 18px;
                    133: }
                    134: body > div.t {
                    135:        font-weight: bold;
                    136:        position: relative;
                    137:        bottom: 10px;
                    138:        padding: 6px;
                    139:        border-width: 0 0 1px 0;
                    140:        border-color: gray;
                    141:        border-style: solid;
1.3     ! as        142:        box-shadow: 1px 1px 2px #000000;
        !           143:        margin-bottom: -6px;
        !           144: }
        !           145: body > div.t div.center {
        !           146:        position: absolute;
        !           147:        text-align: center;
        !           148:        top: 0px;
        !           149:        padding: 6px;
        !           150:        width: 100%;
1.2       as        151: }
1.1       as        152: div.tn a {
                    153:        position: relative;
                    154:        display: inline-block;
                    155:        height: ${ARG_TNSIZE}px;
                    156: }
                    157: div.tn, div.big {
                    158:        background-color: black;
                    159:        border-width: 1px;
                    160:        border-style: solid;
                    161:        border-color: gray;
                    162:        box-shadow: 1px 1px 2px #000;
                    163:        padding: 1px;
                    164:        border-radius: 3px;
                    165: }
                    166: div.tn:hover {
                    167:        background-color: #222;
                    168: }
                    169: div.big {
                    170:        display: inline-block;
                    171:        width: ${ARG_BIGSIZE}px;
                    172: }
                    173: div.over {
                    174:        width: ${ARG_BIGSIZE}px;
                    175:        position: absolute;
                    176:        top: 30px;
                    177:        padding: 1px;
                    178: }
                    179: div.over a.left, div.over a.right {
                    180:        display: block;
                    181:        /* shell fuck of: missing CTLARI (shouldn't happen) - WTF?! */
                    182:        width: $(($ARG_BIGSIZE / 2))px;
                    183:        position: relative;
                    184:        top: 1px;
                    185:        left: 1px;
                    186:        background-repeat: no-repeat;
                    187: }
                    188: div.over a.left:hover {
                    189:        background-position: 5% center;
                    190:        background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAAwC\
                    191: AYAAADtoXHnAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAh9JREFUeNrE2L1Lw0A\
                    192: UAHATSivSZii0ldpBnMU6SgYJpQUJDlk7dLV+LTqIiIv4B7kLolBKQRA6GLqUDMEhqKAlhUIR4125SHo0b\
                    193: XJ51x68pDSX+3G5I/dyguM4S/MuMfeHIAiQ7Yo+//+OocAYPm+jWEXxg8JC8erCgvt4AXrqgkkUJRRZ6jq\
                    194: G71EMRcAeil6wWq2uGYZx1ul0jjRNy5Jey6PauKcRJ5NIhklCoaE4QODNYDCwHVJ6vd5HIpE4xNdQxKOiM\
                    195: 0G3FIvFc4Imo6CBQV3XXwioje5jREOBkiQdE3SLFWUFFXJfaJQVLP2DIWdvFDA+9pYKiMKBAVFYMAAKD85\
                    196: A+YBTUH6gD8oXnIDyB31QviCFzgekUPxYVe4ghW7ixhRFueQKUmgZN9hut1s0aNv2V6FQOAUBqRvT+IAaX\
                    197: 6crWZb1hsqQJFfPkPnpJz6YpmnQlXK5XD6TycRIcrUDib7jQ71ev+v3+9/eSqlUKt1qtU4IvIFid2x9jDC\
                    198: muJE9PG6qql7jcaTHttvt6gh2J1MZYva6ees+d9jnjcQXnoDyh31WGb7wlPWUHzwjc+ADB8iR4OGA2SAsH\
                    199: CLvhYNDZvgwMMO3THSY8auNBS6xfrVFhZUoaGjYk+qA7DkEgmu12i1Bs1C7K1NhvLviecTLEOhEuFKpXDW\
                    200: bzcdGo/Egy/KFZzKJPHbMVsiEyVPXTRRPeMdMWMQuqLi0gPInwACOBcZx3lRFMwAAAABJRU5ErkJggg==");
                    201: }
                    202: div.over a.right:hover {
                    203:        background-position: 95% center;
                    204:        background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB0AAAAwC\
                    205: AYAAADtoXHnAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAiJJREFUeNrE2D1Lw0A\
                    206: YAOAmlNbBdii0FVM6OEu7SgcJpRUJDlk7dE21uuggIi7iD/IX+AGlFAXBDqVLyVCCBBW0JFhwMN7JHRxnY\
                    207: 5PcnX3hhSM58nB3+Xhzkud5sf8OiWjLPn2+eGF4gHEChLkOcgUdt0E+isAlhCVAbiGQjGeQ1yBdHjAeKZ7\
                    208: SCgR1Xc8Nh8M90zQPG42GAo7lQFZBLhOzwSXgKI1kMrk7mUxePBTT6dQB8Dk8B1IHmUbTLrOMFI8WjsIol\
                    209: 8tHHhW8YRKV0QWNwWDwIBKm0RK8aDqdbouEaRReQBUNkygJV0XCNBojnldh8CxUOOyHCoX/QoXB81AhcBC\
                    210: UOxwU5QqHQbnBYVFWODLKDEdFo8IanGYWNBSsquoJgkus6C+4UCgcOI7zRsP9fv8OoTWM8qh57mHlaFnWp\
                    211: 23bFn1SUZQiambm1bphYgMWddlsNp7P51fpk+Px2ETNV1YUf383Qa5BsNfr7adSqQzZyXXd91ardUmUs8x\
                    212: rWYNrBcD2aDQa0GsJ11fTtDO0ntssd28UcAfXzSxvpLBg5DcSKyhH/cowgVG+p8xg2MqBCximRuIGBq0Gu\
                    213: YJB6l7u4LwKXwjo9y8jFPT7a6uKBGehqmiQRhO45BAJ0ijcQTGazeaFSJBGl/DUkrsrvMFZa/pzE1UqleN\
                    214: Op3PV7XZv6vX6KU+QRMkdM3gzFal+TyBvQX7w3DGTFrELKscWEN8CDADBm8pgcciwqgAAAABJRU5ErkJgg\
                    215: g=="); 
                    216: }
                    217: div.big a {
                    218:        position: relative;
                    219:        display: inline-block;
                    220:        width: ${ARG_BIGSIZE}px;
                    221: }
                    222: div.box {
                    223:        text-align: center;
                    224:        width: ${ARG_BIGSIZE}px;
                    225:        margin: auto;
                    226: }
                    227: div.box div.d {
                    228:        width: ${ARG_BIGSIZE}px;
                    229:        padding: 5px;
                    230:        text-align: center;
                    231: }
                    232: div.box div.i {
                    233:        width: ${ARG_BIGSIZE}px;
                    234:        font-size: 90%;
                    235:        height: 25px;
                    236:        line-height: 25px;
                    237:        position: relative;
                    238: }
                    239: body > div.c {
                    240:        text-align: center;
                    241:        font-size: 90%;
                    242:        height: 25px;
                    243:        line-height: 25px;
                    244:        position: relative;
                    245:        margin: 4px;
                    246: }
                    247: a img {
                    248:        border-width: 0;
                    249: }
                    250: a {
                    251: }
                    252: div.nav {
                    253:        width: ${ARG_BIGSIZE}px;
                    254:        height: 20px;
                    255: }
1.3     ! as        256: a {
1.1       as        257:        color: #FFF;
                    258:        text-decoration: none;
                    259: }
1.3     ! as        260: a:hover {
1.1       as        261:        text-decoration: underline;
                    262: }
                    263: div.nav div.top {
                    264:        position: absolute;
                    265:        text-align: center;
                    266:        width: $(($ARG_BIGSIZE - 100))px;
                    267:        margin: 0 50px;
                    268: }
                    269: .left {
                    270:        float: left;
                    271: }
                    272: .right {
                    273:        float: right;
                    274: }
                    275: .clear {
                    276:        clear: both;
                    277: }
                    278:                -->
                    279:                </style>
                    280:        </head>
                    281: <body>
                    282: HTML
                    283: }
                    284: 
                    285: #
                    286: # html_footer()
                    287: #
                    288: html_footer()
                    289: {
                    290:        cat <<HTML
                    291: </body></html>
                    292: HTML
                    293: }
                    294: 
                    295: #
                    296: # html_tn()
                    297: #
                    298: html_tn()
                    299: {
                    300:        tn=$1
                    301:        link=$2
                    302:        title="$3"
                    303: 
                    304:        info=$($BIN_IMGINFO -f $tn)
                    305:        width=$(echo $info | awk '{print $3}')
                    306:        height=$(echo $info | awk '{print $4}')
                    307:        top=$(($(($ARG_TNSIZE - $height)) / 2))
                    308: 
                    309:        test "$title" != "" && title="<div class='t'>$title</div>"
                    310: 
                    311:        cat <<HTML
                    312: <div class="tn">
                    313:        $title
                    314:        <a href="$link" style="top:${top}px">
                    315:                <img alt="$tn" width="$width" height="$height" src="$tn" />
                    316:        </a>
                    317: </div>
                    318: HTML
                    319: }
                    320: 
                    321: #
                    322: # html_img()
                    323: #
                    324: html_img()
                    325: {
                    326:        orig=$1
                    327:        num=$2
                    328:        all=$3
                    329:        img=$4
                    330:        link=$5
                    331:        linkb=$6
                    332:        linkn=$7
                    333: 
                    334:        info=$($BIN_IMGINFO -f $img)
                    335:        width=$(echo $info | awk '{print $3}')
                    336:        height=$(echo $info | awk '{print $4}')
                    337: 
                    338:        desc=$(get_exif_desc $orig)
                    339:        if [ "$desc" != "" ]
                    340:        then
                    341:                desc="<div class='d'>$desc</div>"
                    342:        fi
                    343: 
                    344:        if [ "$linkb" != "" ]
                    345:        then
                    346:                hlinkb="<a href='$linkb'>prev</a>"
                    347:                olinkb="<a class='left' style='height:${height}px' href='$linkb'></a>"
                    348:        fi
                    349: 
                    350:        if [ "$linkn" != "" ]
                    351:        then
                    352:                hlinkn="<a href="$linkn">next</a>"
                    353:                olinkn="<a class='right' style='height:${height}px' href='$linkn'></a>"
                    354:        fi
                    355: 
                    356:        cat <<HTML
                    357: <div class="box">
                    358:        <div class="nav">
                    359:                <div class="top">
                    360:                        <a href="$link">index</a>&nbsp;&nbsp;&nbsp;|&nbsp;&nbsp;&nbsp;<a href="$orig">original</a>&nbsp;&nbsp;&nbsp;|&nbsp;&nbsp;&nbsp;$num/$all
                    361:                </div>
                    362:                <div class="left">$hlinkb</div>
                    363:                <div class="right">$hlinkn</div>
                    364:        </div>
                    365:        <div class="big">
                    366:                <img alt="$img" width="$width" height="$height" src="$img" />
                    367:        </div>
                    368:        $desc
                    369:        <div class="i">
                    370:                <div class="left">$(get_exif_info $orig)</div>
                    371:                <div class="right">$ARG_TITLE $ARG_COPYRIGHT</div>
                    372:        </div>
                    373:        <div class="over" style='height:${height}px'>
                    374:                $olinkb
                    375:                $olinkn
                    376:        </div>
                    377: </div>
                    378: HTML
                    379: }
                    380: 
                    381: #
1.2       as        382: # html_title()
                    383: #
                    384: html_title()
                    385: {
                    386:        left="$1"
1.3     ! as        387:        center="$2"
        !           388:        right="$3"
1.2       as        389:        cat <<HTML
                    390: <div class="t">
                    391:        <div class="left">$left</div>
                    392:        <div class="right">$right</div>
1.3     ! as        393:        <div class="center">$center</div>
1.2       as        394:        <div class="clear"></div>
                    395: </div>
                    396: HTML
                    397: }
                    398: 
                    399: #
1.1       as        400: # err
                    401: #
                    402: err()
                    403: {
                    404:        echo "$1" >&2
                    405:        exit 1
                    406: }
                    407: 
                    408: #
                    409: # mysendmail()
                    410: #
                    411: mysendmail()
                    412: {
                    413:        subject=$1
                    414:        (
                    415:                cat <<MAIL
                    416: From: $ARG_MAILFROM
                    417: To: $ARG_MAILTO
                    418: Subject: $subject
                    419: Content-Type: text/plain; charset=iso-8859-1
                    420: X-Mailer: $VERSION
                    421: 
                    422: $(cat)
                    423: MAIL
                    424:        ) | $BIN_SENDMAIL -t
                    425: }
                    426: 
                    427: #
                    428: # get_exif_desc()
                    429: #
                    430: get_exif_desc()
                    431: {
                    432:        img=$1
                    433:        $BIN_EXIF --ifd=0 --tag=0x010e -m $img 2> /dev/null | while read line
                    434:        do
                    435:                echo "$line<br />"
                    436:        done
                    437: }
                    438: 
                    439: #
                    440: # get_exif_ts()
                    441: #
                    442: get_exif_ts()
                    443: {
                    444:        img=$1
                    445:        date=$($BIN_EXIF --ifd=EXIF --tag=0x9003 -m $img 2> /dev/null)
                    446:        if [ "$date" = "" ]
                    447:        then
                    448:                echo "-1"
                    449:                return 1
                    450:        fi
                    451:        date -j -f "%Y:%m:%d %T" "$date" "+%s"
                    452: }
                    453: 
                    454: #
                    455: # get_exif_date()
                    456: #
                    457: get_exif_date()
                    458: {
                    459:        img=$1
                    460:        ts=$(get_exif_ts $img) && date -r $ts "+%d.%m.%Y %H:%M" || echo ""
                    461: }
                    462: 
                    463: #
                    464: # get_exif_value()
                    465: #
                    466: get_exif_value()
                    467: {
                    468:        img=$1
                    469:        hex=$2
                    470:        $BIN_EXIFTRAN -d $img | grep $hex | sed -E 's/^.{45}//'
                    471: }
                    472: 
                    473: #
                    474: # get_exif_info()
                    475: #
                    476: get_exif_info()
                    477: {
                    478:        img=$1
                    479: 
                    480:        exifinfo=
                    481:        created=$(get_exif_date $img) && exifinfo="$created / "
                    482: 
                    483:        for exif in $ARG_EXIF
                    484:        do
                    485:                if echo $exif | grep -q -E '0x[[:alnum:]]{4}'
                    486:                then
                    487:                        exifinfo="$exifinfo$(get_exif_value $img $exif) "
                    488:                else
                    489:                        exifinfo="$exifinfo$exif "
                    490:                fi
                    491:        done
                    492:        echo $exifinfo | sed -E -e 's/ mm /mm /' -e 's/ se(c|k)./s/' -e 's/ ISO / ISO/' -e 's/ ISO(\/| )/ \1/'
                    493: }
                    494: 
                    495: #
                    496: # is_in_list()
                    497: #
                    498: is_in_list()
                    499: {
                    500:        list=$1
                    501:        value=$2
                    502:        for entry in $list
                    503:        do
                    504:                test "$entry" = "$value" && return 0
                    505:        done
                    506:        return 1
                    507: }