Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Switching from Madoko to AsciiDoc for P4Runtime specification #510

Open
wants to merge 44 commits into
base: main
Choose a base branch
from

Conversation

Dscano
Copy link
Contributor

@Dscano Dscano commented Nov 16, 2024

I am currently in the process of transitioning the P4Runtime specification from Madoko to AsciiDoc. Below is an overview of the remaining tasks:

  • I need to fix the layout of two tables in the P4Runtime-spec.adoc file.
  • Finalize the reorganization and changes necessary for folder structure to support the switch from Madoko to AsciiDoc.

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 16, 2024

I tried make in the docs/v1 directory on a Linux system, and got this error:

$ make
make: *** No rule to make target 'P4Runtime-Spec.adoc', needed by 'P4Runtime-Spec.pdf'.  Stop.

Note the capitalization of the S in Spec. The file name in your PR is P4Runtime-spec.adoc with a lower-case s in spec.

I would recommend leaving the Makefile as it is now, and renaming the .adoc file to match the current capitalization of the Madoko source file.

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 17, 2024

The file logo.png is missing.

@jafingerhut
Copy link
Contributor

Need to update the markup for the URL at the end of Section 1 -- in the PDF output it shows up as https://...

@jafingerhut
Copy link
Contributor

At least some cross-references to figures are rendered in PDF as "Figure Figure 1". In Madoko it was necessary to say "Figure [#crossref-tag]" in the source, but the "Figure" is redundant in AsciiDoc. Similarly for section and table references.

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 17, 2024

In the first paragraph of Section 4, a sentence in the PDF ends with "are described in a laterChapter 5." It would be better if it were "are described in Chapter 5". Either that or if "later chapter" were a link to Chapter 5, like I see for some other cross-references.

@jafingerhut
Copy link
Contributor

Most or all of the figures could use some tweaking on the percent of the column width they occupy, to make them smaller. See the P4 language spec AsciiDoc source for examples.

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 17, 2024

You use [source,p4] at the beginning of snippet of Protobuf definitions. Does Rouge support [source,protobuf]? I am guessing from the existence of a lexer for Protobuf here that it should: https://github.com/rouge-ruby/rouge/blob/master/lib/rouge/lexers/protobuf.rb

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 17, 2024

The paragraph at the end of Section 6.4.3 ActionProfile looks blank in the PDF, probably because in the source it has spaces at the beginning of each line. Something should be done to improve that, probably deleting those leading spaces so the text comes out as a normal paragraph after the bullet list.

It is not clear to me, but perhaps those spaces were there intending for that text to be part of the last bullet, or something like that? If so, there are probably different markups in AsciiDoc that can achieve that, but given that it looks like a separate paragraph in the current Madoko PDF output, making it look like a separate paragraph in the AsciiDoc PDF output is a good start.

Similarly for some text inside a bullet list in the section with title "Meter & DirectMeter".

Also for a bullet list in the section with title "Batch Atomicity".

I experimented in a few places with ways to achieve this in the P4 language spec AsciiDoc source. I don't recall exactly which parts right now, but if you have trouble finding examples of it, let me know and I can try to find them. In the P4-16-spec.adoc file, search for the string "interface of a Match-Action" for an example of using a line containing only + to continue a bullet item in the next paragraph (if I recall correctly), or surrounding a paragraph with -- lines before and after.

Here is some AsciiDoctor documentation on this topic: https://docs.asciidoctor.org/asciidoc/latest/lists/continuation/

@jafingerhut
Copy link
Contributor

Compare the section heading "depths" of all section headings in the current Madoko PDF output, and the AsciiDoc PDF output. At least "Counter & DirectCounter" is Section 6.4.4 in Madoko PDF output, but Section 6.5 in AsciiDoc PDF output.

@jafingerhut
Copy link
Contributor

In the section titled "Extern", need whitespace after "reserved range" and before the range.

@jafingerhut
Copy link
Contributor

In one of the markups that should be "cite:", it is misspelled "cte:"

@jafingerhut
Copy link
Contributor

In the section titled "Bytestrings" there are some LaTeX math formulas. There are a few such formulas in the P4 language spec, too, that I was able to get to render properly using AsciiDoc. Search for occurrences of "latexmath" in the P4 language spec AsciiDoc source for examples.

@jafingerhut
Copy link
Contributor

There is at least one remaining occurrence of [@PSATranslation] that should be updated to cite:[PSATranslation]. Also one occurrence of [@PSAActionSelector].

@jafingerhut
Copy link
Contributor

One cross-reference with text [P4 Entity Messages](#sec-p4-entity-msgs) section needs to be updated to AsciiDoc.

@jafingerhut
Copy link
Contributor

There is an occurrence of "WriteRequests" that should be replaced with "WriteRequests" for AsciiDoc. See here for some examples of differences I found when translating the P4 language spec: https://github.com/jafingerhut/learn-asciidoc/blob/main/p4-spec-next/README-madoko-to-asciidoc-notes.md#monospace

@jafingerhut
Copy link
Contributor

Probably most occurrences of using $ to mark up algebra or math should be replaced with a backtick, unless they need fancier symbols, then latexmath is probably needed. There are many occurrences of $ remaining in the P4Runtime AsciiDoc.

@jafingerhut
Copy link
Contributor

jafingerhut commented Nov 17, 2024

The section heading for the section named "Examples of StreamError Messages" needs at least one blank line before it, or else AsciiDoc does not interpret it as a section header.

There is also an old Madoko-style cross-reference markup on the line before that.

Similarly for section heading "Changes in v1.3.0"

@jafingerhut
Copy link
Contributor

In the section "Changes in v1.4.0", the first sub-bullet item under "Actions" needs to be nested one level deeper.

@jafingerhut
Copy link
Contributor

In section "P4Runtime Entries files" the sequence of bash commands needs different markup. Not sure, but maybe [source,bash] will work?

@Dscano
Copy link
Contributor Author

Dscano commented Nov 17, 2024

FYI, the comments were I "react" with a thumbs-up have been addressed in c43d938

@jafingerhut
Copy link
Contributor

FYI, the comments were I "react" with a thumbs-up have been addressed in c43d938

Great! Please let me know when you are ready for another round of review, i.e. when for each review comment you have either made changes, or replied in some way that you believe no changes are needed.

@Dscano
Copy link
Contributor Author

Dscano commented Nov 19, 2024

You use [source,p4] at the beginning of snippet of Protobuf definitions. Does Rouge support [source,protobuf]? I am guessing from the existence of a lexer for Protobuf here that it should: https://github.com/rouge-ruby/rouge/blob/master/lib/rouge/lexers/protobuf.rb

I applied it to a few proto code blocks (such as 6.1.2) so we can compare and see how it looks.

@Dscano
Copy link
Contributor Author

Dscano commented Dec 24, 2024

I have resolved the issues:

I have proposed a solution for issue #525


build:
mkdir -p build

# Note: Brute-force image rendering; could use more precise file-by-file make rules
images: build assets/*.odg
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we need to restore lines like these in the Makefile, otherwise running make in the docs/v1 directory fails to find the .svg and .png image files.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Indeed, we have 2 use cases:

  • If the Docker runs on a host machine, the user needs to generate the PNG images and then compile.
  • If the Docker has to run on a CI server, the images must be generated within the make process or checked in beforehand.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But we can reduce all cases to behave in a way where whether it is a bare metal system, a VM, or a container, the Makefile has the commands that generate the .svg/.png files from the OpenOffice source files, by installing LibreOffice on the system, yes? I thought that was the preference that Chris expressed earlier, and that is why we only have the OpenOffice files checked in, not the .svg/.png files.

Even if there are cases where the .svg/.png files are sitting there, running make with a Makefile that contains rules for generating those files will only generate them if they are needed, so I don't see only advantages to having these rules in the Makefile that can generate them.

Copy link
Contributor

@jafingerhut jafingerhut Dec 25, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, one more quick comment, in case this is something I am confused about.

If there are any containers anywhere that anyone wants to use to generate the PDF & HTML for the P4Runtime spec, I think we should tell them: "Install LibreOffice in that container, or it won't work."

And if there is some container published by someone in the P4 community that you want to use, that installs asciidoctor, but not LibreOffice, I think we should ask them to update that container so that it does contain LibreOffice, even if LibreOffice is only needed for generating the P4Runtime spec.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Totally agree with you. Does this mean we need to implement it for the container running in the CI environment?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems like a very good idea to me that the container used by CI to build PDF and HTML should have LibreOffice installed, so that it can create the formats of image files required.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agreed, good catch.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Dscano, can you please add back to the Makefile the rules for generating the .svg and .png files from the .odg files?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Dscano, can you please add back to the Makefile the rules for generating the .svg and .png files from the .odg files?

Sorry, I see you have added those rules back.

Can you please add images as a dependency of the generated PDF and HTML files, so that if the .svg and .png files do not currently exist on the file system, then running make with no target will run the commands that generate them, before generating PDF and HTML files?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No problem. So I added it

@jafingerhut
Copy link
Contributor

I have resolved the issues:

I have proposed a solution for issue #525

I have regenerated the PDF and HTML files for the latest version of AsciiDoc input files on this PR as of 2024-Dec-24, with the commits Davide mentions above, and put them in the same place I put earlier versions, here: https://github.com/jafingerhut/learn-asciidoc/tree/main/p4runtime-spec-next/sample-generates-files

I spot-checked the fixes for the em-dashes and the correct link, and they both look good to me. Thanks.

@@ -23,5 +22,11 @@ ${SPEC}.html: ${SPEC}.adoc
-r asciidoctor-lists \
-a rouge-css=$(ROUGE_CSS) $<

images:
soffice --convert-to png --outdir resources/figs resources/figs/*.odg > /dev/null 2>&1
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

svg are also generated by the current docs/v1/Makefile. Are they no longer necessary with AsciiDoc PDF and HTML?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

From my understanding, no. As you can see in the .adoc file, the figures used are PNGs."

Copy link
Contributor

@jafingerhut jafingerhut left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@@ -18,6 +18,14 @@ jobs:
- name: Run linter
run: |
./tools/asciidoclint.py docs/v1/P4Runtime-Spec.adoc

docker:
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would not make a separate CI step. Doing this will build an ephemeral docker image, which will disappear by the time build-spec is run. Call the make -C docs/tools/ command just before the docker run command in build-spec step.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I implemented the fix in this commit 5229d7c, but I'm now encountering a different issue.

@Dscano
Copy link
Contributor Author

Dscano commented Jan 10, 2025

I removed the ls docs/v1/build command because we no longer generate the build directory as was previously done in the Makefile for the spec generation.

In my opinion, the ls docs/v1/build command acts as a canary to confirm that the spec generation is successful. Therefore, I believe it is important to reintroduce the generation of the build folder in the Makefile for the spec generation. What do you think about it?

@jafingerhut
Copy link
Contributor

I removed the ls docs/v1/build command because we no longer generate the build directory as was previously done in the Makefile for the spec generation.

In my opinion, the ls docs/v1/build command acts as a canary to confirm that the spec generation is successful. Therefore, I believe it is important to reintroduce the generation of the build folder in the Makefile for the spec generation. What do you think about it?

It definitely seems like there should be some way to ensure that the CI run fails, if the desired output files (i.e. PDF and HTML) are not created.

I don't see how ls docs/v1/build could actually achieve that purpose, though.

If there were bash commands that checked for the existence of the .pdf and .html output files, and did an exit 1 if they did not exist, that sounds like it would do so.

But the ls docs/v1/build only fails if that entire directory does not exist, and the directory would be something you create as a separately almost-never-failing step before generating the .pdf and .html files.

@jafingerhut
Copy link
Contributor

That madoko-lint step seems unlikely to ever be run, so all CI steps that are able to run are passing now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants