Compare commits
163 Commits
v2017-05-2
...
v2017-11-0
Author | SHA1 | Date | |
---|---|---|---|
|
7c03ae2f80 | ||
|
affae48547 | ||
|
11ab1ae731 | ||
|
6b324152ac | ||
|
edaa0a3443 | ||
|
133f81db8e | ||
|
634f72213b | ||
|
94049d2338 | ||
|
46356c3b98 | ||
|
53d3cf8a74 | ||
|
46ffb01181 | ||
|
fe937d7e4a | ||
|
2cc48104b1 | ||
|
7e7942149e | ||
|
35a217c20b | ||
|
ac0697f1c4 | ||
|
44ee05bcaf | ||
|
2e3c0b861b | ||
|
f34858d644 | ||
|
c18a193973 | ||
|
8cce1275a8 | ||
|
fa08a2dbe8 | ||
|
09e637e6c4 | ||
|
5cb449afcc | ||
|
b0f2b62767 | ||
|
48a51a6f6a | ||
|
c552ffe699 | ||
|
f4850a6010 | ||
|
0bddb123e1 | ||
|
66139ce781 | ||
|
921b75bb2e | ||
|
1e705b4914 | ||
|
cf8756ced7 | ||
|
c6a579a0bf | ||
|
494993d4c2 | ||
|
a472a09597 | ||
|
05460bde51 | ||
|
0c32e03f3a | ||
|
1ac02df52a | ||
|
24b8c5ac35 | ||
|
9fceb27952 | ||
|
1e9629051f | ||
|
b5e95143ca | ||
|
0a2e1ca63a | ||
|
21a019612c | ||
|
80ba7cfaa6 | ||
|
132a00f9e7 | ||
|
d73ae6a382 | ||
|
f427a05c89 | ||
|
3555a692dc | ||
|
11bf8d4de2 | ||
|
4ccf83b953 | ||
|
f6be6aa37e | ||
|
04432d0323 | ||
|
ea323d4b01 | ||
|
082f9a1175 | ||
|
04776428c8 | ||
|
b1f7f5cad4 | ||
|
6d41096dd5 | ||
|
77c31a7c5c | ||
|
0c9086d70d | ||
|
2b6dfac5b0 | ||
|
ba21f8b88d | ||
|
b483acdb6d | ||
|
d91fb336b9 | ||
|
97f62ae600 | ||
|
98d2459b79 | ||
|
719e3a73f5 | ||
|
439f1933da | ||
|
0f52cde91a | ||
|
8a14c6e5fb | ||
|
8c04a58949 | ||
|
6e93313528 | ||
|
b7bc7218b8 | ||
|
7ec21fb6d2 | ||
|
1e2b2dd18f | ||
|
9d4e18e6ef | ||
|
61681c8dd3 | ||
|
71e68b5e2e | ||
|
872eec2aa7 | ||
|
863f70054d | ||
|
16c8d68e39 | ||
|
08593bb221 | ||
|
516a78d397 | ||
|
89ea7a28bd | ||
|
763e9c594f | ||
|
fd7528a6bd | ||
|
efd9e55b66 | ||
|
da94557324 | ||
|
f5887473f3 | ||
|
17ea63f7b9 | ||
|
d7db07bcab | ||
|
e92a1cf713 | ||
|
96903f018c | ||
|
fcc95ce518 | ||
|
8c349b8282 | ||
|
93627e0da2 | ||
|
593bb63e23 | ||
|
3a58b6ae82 | ||
|
11848054a3 | ||
|
c0e9a05e1d | ||
|
7cbdd6a074 | ||
|
fa1cda441e | ||
|
7d07c3818a | ||
|
3374812782 | ||
|
9c871d760a | ||
|
22fa09470b | ||
|
9bae51d6a4 | ||
|
b598ed1040 | ||
|
23148d4721 | ||
|
df422912d6 | ||
|
e5f6f5cf2d | ||
|
96c382943b | ||
|
ef6e5d07dc | ||
|
bf260c2ee2 | ||
|
7f1a765dd8 | ||
|
6c85518288 | ||
|
63abcd36d0 | ||
|
905b75547b | ||
|
7aa124c3d1 | ||
|
50185eb04e | ||
|
975766188f | ||
|
fd1d596f50 | ||
|
18a80c10f1 | ||
|
c6f7593d65 | ||
|
e6962b3ca4 | ||
|
0ba25be082 | ||
|
e4611d8b6b | ||
|
d609a9b943 | ||
|
d132e86f1d | ||
|
e1e1060904 | ||
|
8b5fa8aa6a | ||
|
7bd05a8163 | ||
|
126fb1d284 | ||
|
9799316c19 | ||
|
6e4ed74841 | ||
|
0a6204264c | ||
|
c835746c24 | ||
|
86e53b92c8 | ||
|
41423e0917 | ||
|
9a0875b692 | ||
|
0473e85448 | ||
|
b57349a3ec | ||
|
9f3b56305c | ||
|
5593b86ab7 | ||
|
3544828fb1 | ||
|
c8691285cc | ||
|
e4a660967b | ||
|
86138a55e1 | ||
|
4c14af3209 | ||
|
8d18077af5 | ||
|
8871868eda | ||
|
e1fb86ec94 | ||
|
7fe503d324 | ||
|
513631c80b | ||
|
22ff2368ad | ||
|
c81827d98f | ||
|
19d249a09b | ||
|
04abe26b53 | ||
|
ab3a8b25cf | ||
|
40e8f8c73c | ||
|
129540fbfc | ||
|
8578f01e1c |
7
css/bootstrap.min.css
vendored
242
css/css.css
@@ -1,9 +1,127 @@
|
|||||||
|
html, body {
|
||||||
|
line-height: 1.5;
|
||||||
|
font-size: 16px;
|
||||||
|
color: #888888;
|
||||||
|
background-color: #060606;
|
||||||
|
margin: 0;
|
||||||
|
word-break: break-word;
|
||||||
|
}
|
||||||
|
|
||||||
|
.grid {
|
||||||
|
display: grid;
|
||||||
|
align-content: center;
|
||||||
|
grid-template-areas:
|
||||||
|
"header"
|
||||||
|
"sidebar"
|
||||||
|
"content"
|
||||||
|
"footer";
|
||||||
|
}
|
||||||
|
|
||||||
|
.header {
|
||||||
|
grid-area: header;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.content {
|
||||||
|
grid-area: content;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
grid-area: sidebar;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer {
|
||||||
|
grid-area: footer;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (max-width: 999px) {
|
||||||
|
.grid {
|
||||||
|
grid-template-columns: 1fr;
|
||||||
|
grid-template-areas:
|
||||||
|
"header"
|
||||||
|
"sidebar"
|
||||||
|
"content"
|
||||||
|
"footer";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (min-width: 1000px) {
|
||||||
|
.grid {
|
||||||
|
grid-gap: 1rem;
|
||||||
|
grid-template-columns: 25% auto;
|
||||||
|
grid-template-areas:
|
||||||
|
"header header"
|
||||||
|
"sidebar content"
|
||||||
|
"footer footer";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media only screen and (min-width: 1500px) {
|
||||||
|
.grid {
|
||||||
|
max-width: 70%;
|
||||||
|
margin: 0 auto;
|
||||||
|
grid-template-areas:
|
||||||
|
"header header"
|
||||||
|
"sidebar content"
|
||||||
|
"footer footer";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #91cf91;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover {
|
||||||
|
color: #5cb85c;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:visited {
|
||||||
|
color: #449d44;
|
||||||
|
}
|
||||||
|
|
||||||
|
.license img {
|
||||||
|
max-width: 10em;
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
|
||||||
h1, h2, h3, h4, h5, h6 {
|
h1, h2, h3, h4, h5, h6 {
|
||||||
font-family: 'Montserrat', sans-serif;
|
font-family: 'Montserrat', sans-serif;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
letter-spacing: 0.1em;
|
||||||
|
font-size: 7vw;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
font-size: 1.5em;
|
||||||
|
margin: 5px 8px 8px 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.heading {
|
||||||
|
font-size: 2em;
|
||||||
|
margin: 6px 0px 12px 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3 {
|
||||||
|
font-size: 1.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.intro-lead {
|
||||||
|
font-family: 'Montserrat', sans-serif;
|
||||||
|
font-size: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
code {
|
code {
|
||||||
|
padding: 2px 4px;
|
||||||
|
color: #c7254e;
|
||||||
|
background-color: #f9f2f4;
|
||||||
|
border-radius: 4px;
|
||||||
word-break: break-all;
|
word-break: break-all;
|
||||||
|
word-wrap: break-word;
|
||||||
|
white-space: normal;
|
||||||
|
display: inline-block;
|
||||||
}
|
}
|
||||||
|
|
||||||
dd {
|
dd {
|
||||||
@@ -12,6 +130,10 @@ dd {
|
|||||||
|
|
||||||
dt {
|
dt {
|
||||||
font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
|
font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
|
||||||
|
word-break: break-all;
|
||||||
|
word-wrap: break-word;
|
||||||
|
white-space: normal;
|
||||||
|
display: inline-block;
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
@@ -22,13 +144,17 @@ img {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.sample-image {
|
.sample-image {
|
||||||
|
margin: 0 auto;
|
||||||
margin-bottom: 18px;
|
margin-bottom: 18px;
|
||||||
|
max-width: 500px;
|
||||||
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
h1 {
|
.sample-image-small {
|
||||||
letter-spacing: 8px;
|
margin: 0 auto;
|
||||||
font-size: 86px;
|
margin-bottom: 18px;
|
||||||
line-height: 120px;
|
max-width: 250px;
|
||||||
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
div {
|
div {
|
||||||
@@ -36,46 +162,67 @@ div {
|
|||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn {
|
.sidebar a {
|
||||||
margin: 8px;
|
text-decoration: none;
|
||||||
display: inline-block;
|
|
||||||
vertical-align: middle;
|
|
||||||
-webkit-transform: translateZ(0);
|
|
||||||
transform: translateZ(0);
|
|
||||||
box-shadow: 0 0 1px rgba(0, 0, 0, 0);
|
|
||||||
-webkit-backface-visibility: hidden;
|
|
||||||
backface-visibility: hidden;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
position: relative;
|
|
||||||
padding-left: 2.5em;
|
|
||||||
-webkit-transition-duration: 0.3s;
|
|
||||||
transition-duration: 0.3s;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn:before {
|
.recipe, .contents-list {
|
||||||
|
color: white;
|
||||||
|
background-color: #383838;
|
||||||
|
padding: 14px;
|
||||||
|
font-family: "Montserrat";
|
||||||
|
letter-spacing: 0.05em;
|
||||||
|
border: 1px solid black;
|
||||||
|
cursor: pointer;
|
||||||
|
position: relative;
|
||||||
|
padding-left: 2.8em;
|
||||||
|
transition: all .5s ease-out;
|
||||||
|
}
|
||||||
|
|
||||||
|
.contents-list {
|
||||||
|
font-size: 0.9em;
|
||||||
|
}
|
||||||
|
|
||||||
|
nav .heading {
|
||||||
|
word-break: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe {
|
||||||
|
display: block;
|
||||||
|
width: 90%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe:hover, .contents-list:hover {
|
||||||
|
background-color: #449d44;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe:before {
|
||||||
content: "💫";
|
content: "💫";
|
||||||
|
}
|
||||||
|
|
||||||
|
.contents-list:before {
|
||||||
|
content: "📼";
|
||||||
|
}
|
||||||
|
|
||||||
|
.recipe:before, .contents-list:before {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 1em;
|
left: 1em;
|
||||||
padding: 0 1px;
|
padding-right: 1em;
|
||||||
-webkit-transform: translateZ(0);
|
|
||||||
transform: translateZ(0);
|
|
||||||
-webkit-transition-duration: 0.3s;
|
|
||||||
transition-duration: 0.3s;
|
|
||||||
-webkit-transition-property: transform;
|
|
||||||
transition-property: transform;
|
|
||||||
-webkit-transition-timing-function: ease-out;
|
|
||||||
transition-timing-function: ease-out;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.btn:hover:before, .btn:focus:before, .btn:active:before {
|
.recipe:hover:before, .recipe:focus:before, .recipe:active:before {
|
||||||
-webkit-transform: scale(1.3) translateZ(0);
|
transform: scale(1.5) translateX(0.1em);
|
||||||
transform: scale(1.3) translateZ(0);
|
transition: 0.5s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.contents-list:hover:before, .contents-list:focus:before, .contents-list:active:before {
|
||||||
|
transform: scale(1.8) translateX(0.3em);
|
||||||
|
transition: 0.5s;
|
||||||
}
|
}
|
||||||
|
|
||||||
.codeblock {
|
.codeblock {
|
||||||
font-family: monospace
|
font-family: monospace
|
||||||
padding: 2px 4px;
|
padding: 2px 4px;
|
||||||
font-size: 90%;
|
|
||||||
color: #c7254e;
|
color: #c7254e;
|
||||||
background-color: #f9f2f4;
|
background-color: #f9f2f4;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
@@ -89,14 +236,29 @@ div {
|
|||||||
font-size: 90%;
|
font-size: 90%;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (min-width: 576px) {
|
.well {
|
||||||
img {
|
padding: 1em;
|
||||||
max-width: 60%;
|
margin-bottom: 0.5em;
|
||||||
}
|
background-color: #151515;
|
||||||
|
border: 1px solid #030303;
|
||||||
|
border-radius: 8px;
|
||||||
|
box-shadow: inset 0 1px 1px rgba(0,0,0,0.05);
|
||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (min-width: 992px) {
|
.hiding {
|
||||||
img {
|
opacity: 0;
|
||||||
width: 100%;
|
height: 0;
|
||||||
}
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
input {
|
||||||
|
position: absolute;
|
||||||
|
left: -999em
|
||||||
|
}
|
||||||
|
|
||||||
|
input[type=checkbox]:checked + div {
|
||||||
|
opacity: 1;
|
||||||
|
height: auto;
|
||||||
|
overflow: hidden;
|
||||||
|
transition: opacity .5s linear, height .5s linear;
|
||||||
}
|
}
|
||||||
|
BIN
img/brng.gif
Before Width: | Height: | Size: 7.6 MiB |
BIN
img/cc.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
img/crop_example_aftercrop1.png
Normal file
After Width: | Height: | Size: 245 KiB |
BIN
img/crop_example_aftercrop2.png
Normal file
After Width: | Height: | Size: 167 KiB |
BIN
img/crop_example_aftercrop3.png
Normal file
After Width: | Height: | Size: 146 KiB |
BIN
img/crop_example_orig.png
Normal file
After Width: | Height: | Size: 436 KiB |
BIN
img/eia608_captions.gif
Normal file
After Width: | Height: | Size: 2.1 MiB |
BIN
img/outside_broadcast_range.gif
Normal file
After Width: | Height: | Size: 2.9 MiB |
BIN
img/vhs.ico
Normal file
After Width: | Height: | Size: 15 KiB |
4371
index.html
6
js/bootstrap.min.js
vendored
32
js/js.js
@@ -1,28 +1,20 @@
|
|||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
|
|
||||||
$(function () {
|
// open recipe window if a hash is found in URL
|
||||||
$('[data-toggle="tooltip"]').tooltip()
|
|
||||||
});
|
|
||||||
|
|
||||||
// open modal window if a hash is found in URL
|
|
||||||
if(window.location.hash) {
|
if(window.location.hash) {
|
||||||
$(window.location.hash).modal('show');
|
id = window.location.hash
|
||||||
// add direct link to modal window
|
document.getElementById(id.substring(1)).checked = true;
|
||||||
$(".link").empty();
|
$('html, body').animate({ scrollTop: $(id).offset().top}, 1000);
|
||||||
$(".link").append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>");
|
$(id).closest('div').find('.link').empty();
|
||||||
|
$(id).closest('div').find('.link').append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>");
|
||||||
}
|
}
|
||||||
|
|
||||||
// add hash to URL when modal is opened
|
// add hash URL when recipe is opened
|
||||||
$('span[data-toggle="modal"]').on("click", function(){
|
$('label[class="recipe"]').on("click", function(){
|
||||||
window.location.hash = $(this).attr("data-target");
|
id = $(this).attr("for");
|
||||||
// add direct link to modal window
|
window.location.hash = ('#' + id)
|
||||||
$(".link").empty();
|
$('#' + id).closest('div').find('.link').empty();
|
||||||
$(".link").append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>");
|
$('#' + id).closest('div').find('.link').append("<small>Link to this command: <a href="+window.location.href+">"+window.location.href+"</a></small>");
|
||||||
});
|
|
||||||
|
|
||||||
// remove hash from URL when modal is closed
|
|
||||||
$(document).on('hide.bs.modal', function (e) {
|
|
||||||
history.pushState("", document.title, window.location.pathname);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
17
readme.md
@@ -32,7 +32,7 @@ To contribute to this project directly (and more quickly), clone this repository
|
|||||||
|
|
||||||
#### Make a request
|
#### Make a request
|
||||||
|
|
||||||
If you are having trouble with coding it yourself or with github, feel free to [submit an issue](https://github.com/amiaopensource/ffmprovisr/issues) with the kind of command you would like to see added to the site.
|
If you are having trouble with coding it yourself or with GitHub, feel free to [submit an issue](https://github.com/amiaopensource/ffmprovisr/issues) with the kind of command you would like to see added to the site.
|
||||||
|
|
||||||
#### General help
|
#### General help
|
||||||
|
|
||||||
@@ -49,7 +49,7 @@ You can read our contributor code of conduct [here](https://github.com/amiaopens
|
|||||||
## Contributors
|
## Contributors
|
||||||
* Gathered using [octohatrack](https://github.com/LABHR/octohatrack)
|
* Gathered using [octohatrack](https://github.com/LABHR/octohatrack)
|
||||||
|
|
||||||
GitHub Contributors:
|
*GitHub Contributors*:
|
||||||
ablwr (Ashley)
|
ablwr (Ashley)
|
||||||
dericed (Dave Rice)
|
dericed (Dave Rice)
|
||||||
edsu (Ed Summers)
|
edsu (Ed Summers)
|
||||||
@@ -58,33 +58,38 @@ kfrn (Katherine Frances Nagels)
|
|||||||
kgrons (Kathryn Gronsbell)
|
kgrons (Kathryn Gronsbell)
|
||||||
kieranjol (Kieran O'Leary)
|
kieranjol (Kieran O'Leary)
|
||||||
llogan (Lou)
|
llogan (Lou)
|
||||||
|
pjotrek-b (Peter B.)
|
||||||
privatezero (Andrew Weaver)
|
privatezero (Andrew Weaver)
|
||||||
retokromer (Reto Kromer)
|
retokromer (Reto Kromer)
|
||||||
rfraimow
|
rfraimow
|
||||||
|
|
||||||
All Contributors:
|
*All Contributors*:
|
||||||
ablwr (Ashley)
|
ablwr (Ashley)
|
||||||
audiovisualopen
|
audiovisualopen
|
||||||
brainwane (Sumana Harihareswara)
|
brainwane (Sumana Harihareswara)
|
||||||
|
bturkus
|
||||||
dericed (Dave Rice)
|
dericed (Dave Rice)
|
||||||
edsu (Ed Summers)
|
edsu (Ed Summers)
|
||||||
Fizz24
|
Fizz24
|
||||||
jamessam (Jim)
|
jamessam (Jim Sam)
|
||||||
jfarbowitz (Jonathan Farbowitz)
|
jfarbowitz (Jonathan Farbowitz)
|
||||||
jronallo (Jason Ronallo)
|
jronallo (Jason Ronallo)
|
||||||
|
kellyhaydon (metacynic)
|
||||||
kfrn (Katherine Frances Nagels)
|
kfrn (Katherine Frances Nagels)
|
||||||
kgrons (Kathryn Gronsbell)
|
kgrons (Kathryn Gronsbell)
|
||||||
kieranjol (Kieran O'Leary)
|
kieranjol (Kieran O'Leary)
|
||||||
llogan (Lou)
|
llogan (Lou)
|
||||||
mulvya
|
mulvya
|
||||||
|
pjotrek-b (Peter B.)
|
||||||
privatezero (Andrew Weaver)
|
privatezero (Andrew Weaver)
|
||||||
retokromer (Reto Kromer)
|
retokromer (Reto Kromer)
|
||||||
rfraimow
|
rfraimow
|
||||||
|
richardpl (Paul B Mahol)
|
||||||
todrobbins (Tod Robbins)
|
todrobbins (Tod Robbins)
|
||||||
|
|
||||||
Repo: amiaopensource/ffmprovisr
|
Repo: amiaopensource/ffmprovisr
|
||||||
GitHub Contributors: 11
|
GitHub Contributors: 12
|
||||||
All Contributors: 18
|
All Contributors: 22
|
||||||
|
|
||||||
## AVHack Team
|
## AVHack Team
|
||||||
|
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
SCRIPT=$(basename "${0}")
|
SCRIPT=$(basename "${0}")
|
||||||
VERSION='2017-04-17'
|
VERSION='2017-07-08'
|
||||||
AUTHOR='ffmprovisr'
|
AUTHOR='ffmprovisr'
|
||||||
RED='\033[1;31m'
|
RED='\033[1;31m'
|
||||||
BLUE='\033[1;34m'
|
BLUE='\033[1;34m'
|
||||||
NC='\033[0m'
|
NC='\033[0m'
|
||||||
|
|
||||||
if [[ ${OSTYPE} = "cygwin" ]] || [ ! $(which diff) ]; then
|
if [[ "${OSTYPE}" = "cygwin" ]] || [ ! $(which diff) ]; then
|
||||||
echo -e "${RED}Error: 'diff' is not installed by default. Please install 'diffutils' from Cygwin.${NC}"
|
echo -e "${RED}Error: 'diff' is not installed by default. Please install 'diffutils' from Cygwin.${NC}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
_output_prompt(){
|
_output_prompt(){
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Usage: ${SCRIPT} -h | -i <av_file> -m <md5_file>
|
Usage: ${SCRIPT} -i <av_file> -m <md5_file> | -h
|
||||||
EOF
|
EOF
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
@@ -21,13 +21,11 @@ EOF
|
|||||||
_output_help(){
|
_output_help(){
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Syntax:
|
Syntax:
|
||||||
${SCRIPT}
|
|
||||||
Prompts a short help message.
|
|
||||||
${SCRIPT} -h
|
|
||||||
This help.
|
|
||||||
${SCRIPT} -i <av_file> -m <md5_file>
|
${SCRIPT} -i <av_file> -m <md5_file>
|
||||||
Pass to the script the audio-visual file and the corresponding MD5
|
Pass to the script the audio-visual file and the corresponding MD5
|
||||||
file to check.
|
file to check.
|
||||||
|
${SCRIPT} -h
|
||||||
|
This help.
|
||||||
Dependency:
|
Dependency:
|
||||||
ffmpeg
|
ffmpeg
|
||||||
About:
|
About:
|
||||||
@@ -40,11 +38,11 @@ EOF
|
|||||||
unset input_file
|
unset input_file
|
||||||
unset input_hash
|
unset input_hash
|
||||||
|
|
||||||
while getopts ":hi:m:" opt; do
|
while getopts ":i:m:h" opt; do
|
||||||
case "${opt}" in
|
case "${opt}" in
|
||||||
|
i) input_file=${OPTARG} ;;
|
||||||
|
m) input_hash=${OPTARG} ;;
|
||||||
h) _output_help ;;
|
h) _output_help ;;
|
||||||
i) input_file=$OPTARG ;;
|
|
||||||
m) input_hash=$OPTARG ;;
|
|
||||||
:) echo -e "${RED}Error: option -${OPTARG} requires an argument${NC}" ; _output_prompt ;;
|
:) echo -e "${RED}Error: option -${OPTARG} requires an argument${NC}" ; _output_prompt ;;
|
||||||
*) echo -e "${RED}Error: bad option -${OPTARG}${NC}" ; _output_prompt ;;
|
*) echo -e "${RED}Error: bad option -${OPTARG}${NC}" ; _output_prompt ;;
|
||||||
esac
|
esac
|
||||||
@@ -59,12 +57,12 @@ else
|
|||||||
md5_tmp="${HOME}/$(basename "${input_hash}").tmp"
|
md5_tmp="${HOME}/$(basename "${input_hash}").tmp"
|
||||||
fi
|
fi
|
||||||
# Find audio frame size for hash calculation
|
# Find audio frame size for hash calculation
|
||||||
|
unset sample_rate
|
||||||
sample_rate=$(grep -v '^#' "${input_hash}" | head -n 1 | tr -d ' ' | cut -d',' -f4)
|
sample_rate=$(grep -v '^#' "${input_hash}" | head -n 1 | tr -d ' ' | cut -d',' -f4)
|
||||||
ffmpeg -i "${input_file}" -loglevel 0 -af "asetnsamples=n='$sample_rate'" -f framemd5 -vn "${md5_tmp}"
|
ffmpeg -i "${input_file}" -loglevel 0 -af "asetnsamples=n='$sample_rate'" -f framemd5 -vn "${md5_tmp}"
|
||||||
[[ ! -f ${md5_tmp} ]] && { echo -e "${RED}Error: '${input_file}' is not a valid audio-visual file.${NC}" ; _output_prompt ; }
|
[[ ! -f ${md5_tmp} ]] && { echo -e "${RED}Error: '${input_file}' is not a valid audio-visual file.${NC}" ; _output_prompt ; }
|
||||||
unset old_file
|
unset old_file
|
||||||
unset tmp_file
|
unset tmp_file
|
||||||
unset sample_rate
|
|
||||||
old_file=$(grep -v '^#' "${input_hash}")
|
old_file=$(grep -v '^#' "${input_hash}")
|
||||||
tmp_file=$(grep -v '^#' "${md5_tmp}")
|
tmp_file=$(grep -v '^#' "${md5_tmp}")
|
||||||
if [[ "${old_file}" = "${tmp_file}" ]]; then
|
if [[ "${old_file}" = "${tmp_file}" ]]; then
|
||||||
|
@@ -1,19 +1,19 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
SCRIPT=$(basename "${0}")
|
SCRIPT=$(basename "${0}")
|
||||||
VERSION='2017-04-17'
|
VERSION='2017-07-08'
|
||||||
AUTHOR='ffmprovisr'
|
AUTHOR='ffmprovisr'
|
||||||
RED='\033[1;31m'
|
RED='\033[1;31m'
|
||||||
BLUE='\033[1;34m'
|
BLUE='\033[1;34m'
|
||||||
NC='\033[0m'
|
NC='\033[0m'
|
||||||
|
|
||||||
if [[ ${OSTYPE} = "cygwin" ]] || [ ! $(which diff) ]; then
|
if [[ "${OSTYPE}" = "cygwin" ]] || [ ! $(which diff) ]; then
|
||||||
echo -e "${RED}Error: 'diff' is not installed by default. Please install 'diffutils' from Cygwin.${NC}"
|
echo -e "${RED}Error: 'diff' is not installed by default. Please install 'diffutils' from Cygwin.${NC}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
_output_prompt(){
|
_output_prompt(){
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Usage: ${SCRIPT} -h | -i <av_file> -m <md5_file>
|
Usage: ${SCRIPT} -i <av_file> -m <md5_file> | -h
|
||||||
EOF
|
EOF
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
@@ -21,13 +21,11 @@ EOF
|
|||||||
_output_help(){
|
_output_help(){
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Syntax:
|
Syntax:
|
||||||
${SCRIPT}
|
|
||||||
Prompts a short help message.
|
|
||||||
${SCRIPT} -h
|
|
||||||
This help.
|
|
||||||
${SCRIPT} -i <av_file> -m <md5_file>
|
${SCRIPT} -i <av_file> -m <md5_file>
|
||||||
Pass to the script the audio-visual file and the corresponding MD5
|
Pass to the script the audio-visual file and the corresponding MD5
|
||||||
file to check.
|
file to check.
|
||||||
|
${SCRIPT} -h
|
||||||
|
This help.
|
||||||
Dependency:
|
Dependency:
|
||||||
ffmpeg
|
ffmpeg
|
||||||
About:
|
About:
|
||||||
@@ -40,11 +38,11 @@ EOF
|
|||||||
unset input_file
|
unset input_file
|
||||||
unset input_hash
|
unset input_hash
|
||||||
|
|
||||||
while getopts ":hi:m:" opt; do
|
while getopts ":i:m:h" opt; do
|
||||||
case "${opt}" in
|
case "${opt}" in
|
||||||
|
i) input_file=${OPTARG} ;;
|
||||||
|
m) input_hash=${OPTARG} ;;
|
||||||
h) _output_help ;;
|
h) _output_help ;;
|
||||||
i) input_file=$OPTARG ;;
|
|
||||||
m) input_hash=$OPTARG ;;
|
|
||||||
:) echo -e "${RED}Error: option -${OPTARG} requires an argument${NC}" ; _output_prompt ;;
|
:) echo -e "${RED}Error: option -${OPTARG} requires an argument${NC}" ; _output_prompt ;;
|
||||||
*) echo -e "${RED}Error: bad option -${OPTARG}${NC}" ; _output_prompt ;;
|
*) echo -e "${RED}Error: bad option -${OPTARG}${NC}" ; _output_prompt ;;
|
||||||
esac
|
esac
|
||||||
@@ -53,7 +51,7 @@ done
|
|||||||
[[ -z "${#}" || ! ${input_file} || ! ${input_hash} ]] && _output_prompt
|
[[ -z "${#}" || ! ${input_file} || ! ${input_hash} ]] && _output_prompt
|
||||||
echo -e "${BLUE}Please wait...${NC}"
|
echo -e "${BLUE}Please wait...${NC}"
|
||||||
unset md5_tmp
|
unset md5_tmp
|
||||||
if [[ $OSTYPE = "cygwin" ]]; then
|
if [[ "${OSTYPE}" = "cygwin" ]]; then
|
||||||
md5_tmp="${USERPROFILE}/$(basename "${input_hash}").tmp"
|
md5_tmp="${USERPROFILE}/$(basename "${input_hash}").tmp"
|
||||||
else
|
else
|
||||||
md5_tmp="${HOME}/$(basename "${input_hash}").tmp"
|
md5_tmp="${HOME}/$(basename "${input_hash}").tmp"
|
||||||
|
@@ -1,26 +1,27 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# This allows to open ffmprovisr locally from the terminal.
|
# This allows to open the online version of the ffmprovisr, when the computer is
|
||||||
|
# connected to the Web, and the local version otherwise.
|
||||||
|
|
||||||
if [[ ${OSTYPE} = "darwin"* ]] ; then
|
if [[ "$(uname -s)" = "Darwin" ]] ; then
|
||||||
default_browser=$(plutil -convert json ~/Library/Preferences/com.apple.LaunchServices/com.apple.launchservices.secure.plist -r -o - | grep https -b1 | tail -n1 | cut -d'"' -f4)
|
default_browser=$(plutil -convert json ~/Library/Preferences/com.apple.LaunchServices/com.apple.launchservices.secure.plist -r -o - | grep https -b1 | tail -n1 | cut -d'"' -f4)
|
||||||
if [ -d /usr/local/Cellar/ffmprovisr ] ; then
|
if ping -c 1 amiaopensource.github.io >/dev/null 2>&1 ; then
|
||||||
ffmprovisr_path=$(find /usr/local/Cellar/ffmprovisr -iname 'index.html' | sort -M | tail -n1)
|
|
||||||
fi
|
|
||||||
if [ -z "${ffmprovisr_path}" ] ; then
|
|
||||||
ffmprovisr_path='https://amiaopensource.github.io/ffmprovisr/'
|
ffmprovisr_path='https://amiaopensource.github.io/ffmprovisr/'
|
||||||
|
else
|
||||||
|
ffmprovisr_path=$(find /usr/local/Cellar/ffmprovisr -iname 'index.html' | sort -M | tail -n1)
|
||||||
fi
|
fi
|
||||||
if [ -n "${default_browser}" ] ; then
|
if [ -n "${default_browser}" ] ; then
|
||||||
open -b "${default_browser}" "${ffmprovisr_path}"
|
open -b "${default_browser}" "${ffmprovisr_path}"
|
||||||
else
|
else
|
||||||
open "${ffmprovisr_path}"
|
open "${ffmprovisr_path}"
|
||||||
fi
|
fi
|
||||||
elif [[ ${OSTYPE} = "linux-gnu" ]] ; then
|
elif [[ "$(uname -s)" = "Linux" ]] ; then
|
||||||
if [ -d ~/.linuxbrew/Cellar/ffmprovisr ] ; then
|
if ping -c 1 amiaopensource.github.io >/dev/null 2>&1 ; then
|
||||||
|
ffmprovisr_path='https://amiaopensource.github.io/ffmprovisr/'
|
||||||
|
else
|
||||||
ffmprovisr_path=$(find ~/.linuxbrew/Cellar/ffmprovisr -iname 'index.html' | sort -M | tail -n1)
|
ffmprovisr_path=$(find ~/.linuxbrew/Cellar/ffmprovisr -iname 'index.html' | sort -M | tail -n1)
|
||||||
fi
|
fi
|
||||||
if [ -z "${ffmprovisr_path}" ] ; then
|
|
||||||
ffmprovisr_path='https://amiaopensource.github.io/ffmprovisr/'
|
|
||||||
fi
|
|
||||||
xdg-open "${ffmprovisr_path}"
|
xdg-open "${ffmprovisr_path}"
|
||||||
|
else
|
||||||
|
echo "Please locate the 'ffmprovisr' folder, and open the 'index.html' file in a browser."
|
||||||
fi
|
fi
|
||||||
|