Menu

[291208]: / doc / notecase-HTML.sh  Maximize  Restore  History

Download this file

418 lines (398 with data), 14.2 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
#
# Ed-based script to convert notecase.ncd tree structure -> HTML active web-based tree
#
# This is a shell script for a linux or Cygwin operating system
# Select the script (ONLY the script, if copying this from the HTML tree) and
# save it as your shell script, perhaps notecase-HTML.sh
# It will check there's an 'ed' on your system when it runs.
# Help available with the --help switch.
#
# Feedback etc to the rod<at>rodericksmith<dot>plus<dot>com , please
#
# By: Rod Smith rod<at>rodericksmith<dot>plus<dot>com
# Integration licensed under the GNU / MIT licences.
#
versionNumber="0.01, February 2010"
#
helpmsg="
Help on notecase-HTML $version
Usage - notecase-HTML [-dbg] [-noframes] [sourceFile] [destinationFile]
The script converts Notecase .ncd files to an active HTML tree
If sourceFile is missing, assume m.ncd
if m.ncd doesn\'t exist, print this message
If destinationFile is missing, assume: \n sourcefile[less .ncd extension, plus .html extension]
Any additional HTML in the Notecase must start with a line containing < [ html ] > with the spaces removed
and end with a line containing </[html]>. It's case sensitive.
"
# First check the host operating system has ED installed
#
if [ ! ed <<<Q ] ; then echo The ' ed ' editor isn\'t installed. Please download and install it. ; quit; fi
#
# Configure the command line options for the debug option
#
if [ x$1 == x-dbg ] ; then shift ; a=dbg ; fi
#
if [ x$1 == x-noframes ] ; then shift ; b=noframes ; fi
#
# Any other flag in the first paramter location triggers online help
echo $1;
if [ x$1 == x--help ] ; then echo "$helpmsg" ; exit; fi
#
# Action on missing source file parameter -- (a) assume m.mcd - if not found, give help message and quit
#
sourceFile=$1 ; destFile=$2
if [ x$sourceFile == x ] ; then
if [ -e m.ncd ] ; then
sourceFile=m.ncd ; echo No start file specified -- using $sourceFile ;
else echo -e $"helpmsg" ; exit ; fi ;
fi
#
# See http://tldp.org/LDP/abs/html/refcards.html#AEN22098 for the fancy string operations
# Verify the extension of the sourcefile is .ncd
#
if [ XX${sourceFile##*\.} != XXncd ] && [ XX${sourceFile##*\.} != XXNCD ] ; then
echo notecase-HTML: Source file \($sourceFile\) extension must be ncd or NCD ;
echo "$helpmsg" exit;
fi
#
# Check the source file exists, quit if not
#
if [ -e $sourceFile ] ; then echo $sourceFile : $a ; else echo notecase-HTML: $sourceFile - file not Found ; exit ; fi
#
# Extract the base filename without the extension, add HTML suffix
#
if [ x$2 == x ] ; then
destFile=`echo ${sourceFile%\.*}.HTML` ;
else
destFile=$2 ;
fi ;
#
echo Destination=$destFile ;
#
# Check for rogue strings. £ used since Notecase escapes it, so ncd string differs
# since Notecase escapes it, and the ncd string would be \&pound
#
if `grep £NOT $sourceFile >/dev/null` ; then
echo ------------- ;
echo Rogue string £NOT lies in the file $sourceFile; echo
grep -Hn £NOT $sourceFile ;
echo ------------- ;echo; echo Run aborted -- unpredictable results.
exit
fi
#
if [ -f tmp_notecase.html ] ; then
echo notecase-HTML: A temporary file tmp_notecase.html exists ;
echo probably from a previous run of this command. ;
echo Please delete it and re-run me. ;
exit ;
fi
#
#
# Create the editing script, to be fed as commands to ED
#
editingCommands=`cat -v <<"!endscript"
#
#enable debug messages
#
H
# Replace the .ncd source text prior to <TITLE>
# (the dummy command prevents printing line)
/TITLE/s/^//
1,.-1d
#
# Insert new header to include the javascript files needed from in-line text (terminates witha solitary . on a line)
#
i
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN"
"http://www.wapforum.org/DTD/xhtml-mobile10.dtd">
<html>
<head>
<!-- First try the local URL/file system -->
<script type="text/javascript">
/* only load locally if not already present locally */
var jQueryLoadedFrom="";
if(typeof jQuery == 'function') jQueryLoadedFrom="already loaded";
else
document.write("<script type=\"text/javascript\" src=\"jquery-1.4.1.min.js\"></"+"script>");
</script>
<script type="text/javascript">
/* only load jQuery from Google if not present locally */
var jQueryLoadedFrom="";
if(typeof jQuery == 'function' && jQueryLoadedFrom == "") jQueryLoadedFrom="local url";
else
document.write("<script type=\"text/javascript\" src=\"http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js\"></"+"script>");
</script>
<script type="text/javascript">
/* if Google is down */
if(typeof jQuery == 'function' && jQueryLoadedFrom == "") jQueryLoadedFrom="Google url";
else
document.write("<script type=\"text/javascript\" src=\"/lib/js/jquery.min.js\"></"+"script>");
</script>
<script type="text/javascript">
diagnostics="";
if(typeof jQuery == 'function')
{ if(jQueryLoadedFrom == "") jQueryLoadedFrom="jQuery url";
}
else { jQueryLoadedFrom ="nowhere";
diagnostics=" ++++ jQuery library inaccessible, so only a passive list is visible."
diagnostics=diagnostics+"<br>For offline use, please download from <br> http://code.jquery.com/jquery-1.4.1.min.js";
diagnostics=diagnostics+"<br> Then copy it into my local url as file named jquery-1.4.1.min.js";
diagnostics=diagnostics+"<br>"+diagnostics+"<br>++++<br>"
}
var plaudits=" Integrated by <a href=\"http://www.rodericksmith.plus.com\">Rod Smith.</a> "
plaudits=plaudits+"jQuery libs loaded from: "+jQueryLoadedFrom+". " ;
plaudits=plaudits+" Version:"+"notecase_HTML_versionNumber";
document.write(plaudits+diagnostics);
</script>
<script></script>
.
#
# end of inserted header
#
# Insert style sheet
a
<style type="text/css" > ul {
list-style: none;
margin: 0;
padding: 0;
}
li {
/*background-image: url(page.png);*/
background-image: url("");
background-position: 0 1px;
background-repeat: no-repeat;
padding-left: 20px;
}
li.folder {
/*background-image: url(folder.png); */
background-image:url()
}
a {
color: #000080;
cursor: pointer;
text-decoration: underline;
}
a:hover {
text-decoration: underline;
}
</style>
.
# Insert the javascript file folding.js (relatively small)
a
<script type="text/javascript">
function activateTree() {
// Find list items representing folders and
// style them accordingly. Also, turn them
// into links that can expand/collapse the
// tree leaf.
$('li > ul').each(function(i) {
// Find this list's parent list item.
var parent_li = $(this).parent('li');
// Style the list item as folder.
parent_li.addClass('folder');
// Temporarily remove the list from the
// parent list item, wrap the remaining
// text in an anchor, then reattach it.
var sub_ul = $(this).remove();
parent_li.wrapInner('<a/>').find('a').click(function() {
// Make the anchor toggle the leaf display.
sub_ul.toggle();
});
parent_li.append(sub_ul);
});
// Hide all lists except the outermost.
$('ul ul').hide();
}
$(function() activateTree() );
window.onerror="none";
</script>
.
# Replace occurrences of escape character ¨ (a mathematical NOT), in the source
#
# Replace occurrences of escape characters {} ¨ (a maths NOT), in the source
#
g/¨/s/¨/£NOT/g
g/{/s/{/£Lbrace/g
g/}/s/}/£Rbrace/g
#
# Remove comments specific to Notecase -- dates, folder image defs
#
g/<!--/d
# delete all null lines or whitespace
g/^ *$/d
#
# identify (most) blank frames
# After each title ends, prepend a marker to the following line
# OR a title ends </DT> followed immeditely by a list ending </DL>
#
# Put a marker 1 line after each definition title . .
#
g/<\/DT>$/ .+1s/^/¨/
#
# In both cases -- start of another folder title (<DT>) or end of a
# definition list (</DL>), prepend the closing actions for:
# the frame text list item (</li>)
# the list that defines the frame text (</ul>)
# the node's own list item (</li>)#
#
g/^¨/ s/¨<DT>/{|oooo|}<\/li><\/ul><\/li><DT>/
g/^¨/ s/¨<\/DL>/{|oooo|}<\/li><\/ul><\/li><\/DL>/
#
# Extra optional diagnostic to see what's left after titles . . .
#g/^¨/p
#
# END OF TABLE MARKS
## g/^¨/p # commented out -- its for a debugging check
#
# End of node description (RHS) marks:
# These may end with <\DD> OR with <DL>. We need to distinguish the two.
# So, we
#
# Place ¨ markers after each RHS frame
#
,s/<\/DD>/¨&/
,s/<DL>/¨&/
#
# Insert end-of-table at end of each RHS frame (each RHS starts with <DD> )
#
# After every <DD>, look for the single first subsequent ¨ marker, and double that marker
#
g/<DD>/ /¨/s/¨/¨¨/
#
# On those double markers only
#
#
g/¨¨<DL>/ s/¨¨<DL>/<\/td><\/tr><\/table> <\/li>{|+DL|}/
g/¨¨<\/DD>/s/¨¨<\/DD>/<\/td><\/tr><\/table> <\/li>{|-dd|}<\/ul> <\/li> /
#
# clean up -- remove markers
#
,s/¨//g
#
# Definition list maps to unordered list, at the start of any node
#
,s/<DL>/{| +DL |}<ul> /g
#
# Insert start-of-table for RHS frame
#
,s/<DD>/{|+DD|}<table border="1" cellpadding="1" cellspacing="0" bordercolor="#80E0E0" ><tr><td>/g
#
#
g/<\/DL>/s/<\/DL>/{|-dl|}<\/ul> /g
g/<\/DD>/s/<\/DD>/{|-dd|}<\/li> /g
#
# DT -- always surrounds node title
# ( HTML title in a definiton list )
#
# -- generate a list item <li> to hold the node and sub-nodes
#
,s/<DT>/{|+DT|}<li> /g
#
# /DT -- always ends a node title. When his occurs, we must:
# -- start a list ( <ul> ) to contain any subnodes and node's own text
# -- start a list item ( <li> ) to contain the node text
# --- we'll only know if its needed by lack of a definition list <DL>
# -- these are put onto separate lines to ease debugging on a folding editor
#
,s/<\/DT>/{|-dt|}\\
<ul> \\
<li> /g
#
# Put all the table (RHS) opening into a single line to improve readability of HTML as text
# and allow detection of empty table (RHS)
#
g/<table/.,.+1j
#
# Remove any empty tables of RHS text -- otherwise ghosted tables appear in HTML
#
## g/<td><\/td>/.-1,.p
g/<td><\/td>/.-1s/<li>//
g/<td><\/td>/.d
#
# then kill any blank lines
#
g/^$/d
#
# Restore occurrences of escape characters in the source
#
g/£NOT/s/£NOT/¨/g
g/£Lbrace/s/£Lbrace/{/g
g/£Rbrace/s/£Rbrace/}/g
#
# Save the modified text
#
w tmp_notecase.HTML
# (End of inline script)
q
!endscript
`
echo This is Version: $versionNumber
editingCommands=`sed "s/notecase_HTML_versionNumber/ $versionNumber/" <<<"$editingCommands"` ;
# --------------------------------------------------------
#
# Remove debug tag (enclosed in braces) insertion when not debugging
# End of immediate string MUST BE QUOTED
# see http://tldp.org/LDP/abs/html/here-docs.html
#
if [ x$a != xdbg ] ; then
echo Removing debugging commands;
editingCommands=`sed 's/{|.*|}//g' <<<"$editingCommands"` ;
fi ;
if [ x$b == xnoframes ] ; then
echo Removing frame commands;
editingCommands=`sed 's/<\/td><\/tr><\/table>//g' <<<"$editingCommands"` ;
editingCommands=`sed 's/<table .*<td>//g' <<<"$editingCommands"` ;
#
# editingCommands=`sed '/td>/d' <<<"$editingCommands"` ;
fi ;
#
# --------------------------------------------------------
ed $sourceFile <<<"$editingCommands"
#
#
# Fix up any HTML that embedded in .ncd's source
#
#
if grep -n "&lt;\[html\]&gt;" <tmp_notecase.HTML >/dev/null ; then
if grep -n "&lt;\/\[html\]&gt;" <tmp_notecase.HTML >/dev/null ; then
echo Processing embedded HTML;
if [ XX$b == XX ] ; then echo -e \\n You may want to use -noframes to improve the layout \\n\\n ; fi
( ed tmp_notecase.HTML <<!
# Fix between start and end on different lines
#
g/&lt;\[html\]&gt;/.,/&lt;\/\[html\]&gt;/s/&lt;/</g
g/<\[html\]&gt;/.,/<\/\[html\]&gt;/ s/&gt;/>/g
g/<\[html\]>/.,/<\/\[html\]>/ s/&quot;/\"/g
#
g/<\[html\]>/ s/<\[html\]>/<html>/g
g/<\[\/html\]>/ s/<\/\[html\]>/<\/html>//g
#
wq
!
#
) ;
else echo No unusual HTML in file
fi ;
fi;
#
#
# Give the destination file to its proper name
mv tmp_notecase.HTML $destFile
#
exit
#
---------------------------------------------------------------------------------------------------------
# Explanation of the conversion process
#
# DL ( HTML: defines a list)
#
#
# DD -- precedes text. /dd OR DL ends the text. /dd ends list level
# DL always ends text, OR starts whole body
# ( HTML description in a definiton list )
#
#
# DT -- always surrounds node name
# ( HTML title in a definiton list )
#
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.