I do all the development and testing (HTML syntax checking, link testing, etc.) on my home computer — an » Apple Macintosh mini (1.42 GHz PowerPC G4; 1GB RAM; 70GB HD) running OS X 10.3.9. This great little machine measures only 6"x6"x2" (a shade bigger than a stack of five CD jewel boxes). Of all the development platforms I've worked on, OS X is by far the best: you get all the benefits of the Mac's elegant user interface plus the stability and flexibility of Unix.
Here's an overview of what I do:
- Step 1: Edit the HTML files
-
I rely on » BBEdit, an extremely powerful and full-featured general-purpose Macintosh text editor that has almost all the HTML coding features you'll ever need. Its find-and-replace capability (based on grep, a tried-and-true Unix "regular expression" text search tool) makes it easy to do complex text edits across the entire website with just a few clicks and keystrokes. (If you're not familiar with regex commands, be forewarned: it can take a little time to master its cryptic syntax. But the time invested will amply reward you in time saved.)
On rare occasions, when I want to test experimental chunks of HTML for browser compatibility, I use DreamWeaver.
- Step 2: Prep the files for the web
-
Once I've edited the files on my Mac, I run a bunch of Unix shell scripts to take care of a number of pesky housekeeping details: applying time-stamps, assembling zip file archives, building master file lists, etc.
- Step 3: Upload
-
When I'm satisfied that the site looks good on my Mac, I run another shell script to upload all the newly modified files to the live website.
That's the overview. Read on if you want to learn more about how I update the website or work with Microsoft Word files.
How to update the website
After making all the changes to the html pages...
- Update and check HTML. Using BBEdit:
-
- Do "Update/Site..." This makes sure that all the include'd portions of the site are properly brought up to date as needed. The update process is the BBEdit analogy to Unix makefiles: BBEdit compares the mod date of the file against those of the files on which it depends (i.e., its include files). If any of the dependencies are newer than the file, then BBEdit re-inserts the includes into the file. The upshot is that only those files whose underlying dependencies have changed are modified.
- Do "Check/Site Syntax..." and "Check/Site Links..."
- If you made any changes based on Step 2, run "Update/Site..." once more (or just update the file(s) that you fixed).
- Final global checks. Using Terminal:
-
- Run cksite to validate (a) links to remote sites and (b) the CR/LF status of all html files. If any errors are found, correct the affected files and re-run BBEdit's "Check/Document Syntax" and "Check/Document Links." Re-run cksite until it's clean.
- Final build and upload. Using Terminal:
-
For the gory details, see the shell scripts and related files.
How to work with MS Word files.
In this example, we're presented with a Microsoft Word file named "Book.doc", and we're going to convert it to an ATI webpage named "book.html".
- Proofread & spellcheck. Using Microsoft Word:
-
- Open "Book.doc"
- Print & proofread
- Apply corrections
- Spell-check
- Save As... Web page ("Book.htm")
- Close "Book.htm" (or Quit from Word)
- Strip all the non-standard HTML grunge that Word introduced.
-
When you use Word's "Save As..." command to save a file in HTML format, Word throws in a ton of nonstandard and useless HTML code. That grunge must always be removed before publishing a file on ATI. One of the most popular tools for doing that is the shareware program HTMLTidy, which is nice, but it does weird things like unconverting perfectly good HTML entities (e.g., &) to their ASCII equivalents (&) — requiring a follow-up cleanup session. So I put together a BBEdit "Text Factory" that does most of the needed cleanup.
- Standardize the HTML. (back in BBEdit:)
-
- Open "book.html"
- Select All
- Hard Wrap to 10000 (cmd-\)
- Run AppleScript "CSS prep" (details available on request)
- Copy and paste header and footer "include" chunks from another document. Edit the header chunk accordingly.
- Do "Update document"
- Tidy, tweak, fiddle, and fudge the HTML 'til it's the way you want it.
- Integrate it into the website. (still in BBEdit:)
-
- Add relevant entries to the Indexes.
- Cross-references: are there any other docs that should link to this one?
- Write a summary blurb for the document and incorporate it in the associated index.html file.
- Copy the blurb to the "What's New" page, editing as needed.
- Add entry to the RSS feed. Edit (update) the revision date in the RSS file.
- Check website syntax.
- Check website links.