Skip to content

Latest commit

 

History

History
40 lines (28 loc) · 4.19 KB

publishing-process.md

File metadata and controls

40 lines (28 loc) · 4.19 KB

Repo organization and the publishing process

The index.html file in this directory is the respec source, plus the possible other accompanying files. The respec config typically says something like

specStatus: "CG-DRAFT",
// publishDate: "",
previousPublishDate: "2014-03-04"

this directory contains dated milestone publications, e.g., 2017-03-17 for a copy of what is officially published. This means all the relevant data files from the top-level directory, plus a generated index.html file as a pure HTML5 file (i.e., not a respec source).

The publication process

(Obviously, many of these steps are typically done in your local repo and then committed to github when appropriate.)

  1. Create a new subdirectory shex-semantics-20170327.
  2. Copy all the auxiliary files (e.g., data files, BNF files, images, etc.) from the main repo area. Note that not all the files may be necessary for final publications; e.g., the diagrams may have a .key and/or .pdf versions that are used in the process of creating the diagrams, but only the .svg and .png files are used in the final document.
  3. Generate the pure HTML file:
    1. Finalize/change the index.html file
    2. Commit all the files to github
    3. Check whether respec signals a possible problem (a red or orange button should appear on the upper right hand corner for errors or warnings, respectively).
    4. Push the button called respec on the upper right hand corner, choose Save Snapshot, then Save as HTML. You should either see the HTML source in your screen (e.g., in Safari or IE) or asked to download the HTML file on your disk.
    5. Create/update a file called index.html file in the snapshot directory, and commit it to github
      1. If you are in the main (i.e., gh-pages) branch, http://shexspec.github.io/spec/publishing-snapshots/2017-03-27/index.html is a copy of the publication-to-be in pure HTML.
  4. Copy snapshot to http://shexspec.github.io/shex.io/www and update symlinks. 1. Use the W3C link checker with this URI to check the links in the document (there is a link to the checker from the result generated by the pub rules checker). If there are problems, go back to the first step.
  5. Generate diff from previous version:
    1. Push the button called respec on the upper right hand corner, choose Save Snapshot then Diff,
    2. Save diff to publication directory using path set in otherLinks/Changes/Diff to previous version/href.
  6. Update working version of file, preferably when the publication is done:
    1. Set otherLinks/Changes/Diff previous version/href based on last publication date (in case the choice is to include a date in the diff file’s name)
    2. Update previousPublishDate, previousSpecStatus and previousURI based on the publication snapshot.
  7. Once all pubrules issues are solved, you are ready. The next step is for the staff contact to make a copy of the snapshot and push it on the W3C server at http://www.w3.org/TR/2014/...

The process may become slightly simpler if you run a local Web server on your machine that has an access to the local github repository. Indeed, in that case, step 5.2. can be omitted, i.e., the Overview.html file can be generated locally. Alternatively, you may choose to make a local copy of index.html and open the file from your browser locally. The danger, in this case, is to loose sync with the "master" copy, but if you are sure you have that under control, then this is probably the simplest approach. (Note, however, that you still have to push the new version to github to let the W3C rule checkers do their work…)

This process is based on the assumption that index.html (i.e., respec format) differs from the final document only in terms of the specification status and date (or other configuration option that can be set in the URI). If that is not the case, then a local copy of the file has to be added to the snapshot and be manipulated in that directory; of course, in that case the simplest is to set the specStatus and other options in that copy. Again, the danger of course is to loose sync with the "master" copy.