Hi Thomas, *,<br><br>On Thursday, May 1, 2014, Thomas Hackert <<a href="javascript:_e(%7B%7D,'cvml','thackert@nexgo.de');" target="_blank">thackert@nexgo.de</a>> wrote<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
><br>
> Oh, to be clear: Just randomly mailing documents to people is not<br>
> the way to go. Instead up show up on the #libreoffice-dev channel<br>
<br>
sigh ... Maybe I will find the time this weekend, and than I will<br>
try to join IRC.<br></blockquote><div><br></div><div>No need to sigh - just meant as it is just not nice to just randomly mail documents to people without asking first. That basically means "I expect you to fix it, no matter how many other things you need to do" and that's just not nice.</div>
<div>IRC just is easiest medium for quick feedback regarding this - you're not forced to used IRC.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
[discus, disk or something else?]<br></blockquote><div><br></div><div>Ring, CD, but not discus or disk - that is misleading. And write that it is one with big radius, otherwise the screenshot in the bug doesn't make it clear what is being talked about.</div>
<div>And no need to rewrite the comment again. </div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">>> It depends, how you do define "easily done" ... ;) They are named<br>
>> something like "U1.E1.001.odt" up to "U8.E1.001.odt" (not to<br>
>> forget a copyright and a copyright file for something else) ...<br>
>> :( I would not know an easy way to do this ... :(<br>
><br>
> for file in *.odt; do cp -f my-one-sample.odt "$i"; done<br>
><br>
> i.e. for each file U1.... whatever, it copies (and overwrites,<br>
> that's what the -f switch does) a single document, in this case<br>
> "my-one-sample.odt". over the file.<br>
<br>
I get an<br>
<quote><br>
cp: cannot stat 'my-one-sample.odt': No such file or directory<br>
</quote><br>
here ... :(<br></blockquote><div><br></div><div>Well - that is the placeholder for the one filename you want to use. Obviously I have no idea how you name your documents / how the documents in the example are all called :-) </div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
> but it might just be a drawing shape.<br>
><br>
> for file in *.odt; do zipgrep 'draw:type="ring"' "$file"<br>
> >/dev/null && echo "Ringshape in file $file"; done<br>
<br>
Again, only an error message:<br>
<quote><br>
bash: syntax error near unexpected token `&&'<br>
</quote><br></blockquote><div><br></div><div>PS: - Just use a blank line - that makes it easier to parse quickly (at least for me :-)) the lenghty "<quote>" isn't necessary.</div><div><br></div>
<div>And yes, it is a copy'n'paste error. the whole commans is meant to be put on a single line.</div><div>And it is meant to be run from the directory where all the odts are - otherwise the "*.odt" won't match anything.</div>
<div><br></div><div>for file in *.odt;</div><div><br></div><div>means get a list of all files with odt extension and run a loop with it. For each file you encounter, assign the filename to the variable "file" </div>
<div><br></div><div>do zipgrep 'draw:type="ring"' "$file" > /dev/null && echo "Ringshape in file $file"</div><div><br></div><div>means: for each file, run the command "zipgrep". Search for the string 'draw:type="ring"' in the file named $file (that is where we reuse the variable define in the previous part), and discard the output if it matches (redirect stdout to /dev/null , that is the "> /dev/null" part. content.xml has no linebreaks, and when the zipgrep matches, it would pint a huuuuge line to the terminal that we're not interested in anyway. If zipgrep did find something, then output the name of the file with the echo statement.</div>
<div><br></div><div>&& means. If the previous command returned without error, then run the second one.</div><div>|| would be the opposite: if the previous command returned with error (in the case of zipgrep: string wasn't found), then run the second one.</div>
<div>; is the third way: No matter whether previous command was successful or not, just run the second one anyway.</div><div><br></div><div>done</div><div><br></div><div>marks the end of the statement that should be repeated. so everything between the "do" and "done" is executed for each file.</div>
<div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
... :( First I thought, some kind of c&p errors with your commands,<br>
changed any quotation mark and inverted comma, but this does not<br>
solve the problem ... :( /me thinks, I should learn a little bit<br>
more of these Bash internals ... ;)<br></blockquote><div><br></div><div>Wouldn't hurt to know some basic shell-scripting :-))</div><div><br></div><div>ciao</div><div>Christian</div>