Skip to content

Commit

Permalink
Add support for classes to generated python common API index (#2401)
Browse files Browse the repository at this point in the history
### What

Classes such as `ClassDescription` and `AnnotationInfo` make up an
import part of the API surface for many rerun APIs. Add support for the
classes to `gen_common_index.py`.

TODO:
 - [ ] After landing, cherry-pick into release-0.6

Additional:
- set the heading_level for these generated components to 4, which
matches the styling from the full package index and results in better
TOC representation.
- Add the same template modification that we use from functions to
disable `first` so we get a continuity bar for the class rendering like
we do for functions.
 - Modify the CSS so that links are visible.

Previews:

![image](https://github.com/rerun-io/rerun/assets/3312232/ec0bd281-da4e-4a9a-886b-1689a41ea0ca)



![image](https://github.com/rerun-io/rerun/assets/3312232/3e48e72a-abef-408c-8731-18fead234679)

Related to: #2385
Closes: #2393


### Checklist
* [x] I have read and agree to [Contributor
Guide](https://github.com/rerun-io/rerun/blob/main/CONTRIBUTING.md) and
the [Code of
Conduct](https://github.com/rerun-io/rerun/blob/main/CODE_OF_CONDUCT.md)
* [ ] I've included a screenshot or gif (if applicable)

<!-- This line will get updated when the PR build summary job finishes.
-->
PR Build Summary: https://build.rerun.io/pr/2401

<!-- pr-link-docs:start -->
Docs preview: https://rerun.io/preview/b58a10c/docs
Examples preview: https://rerun.io/preview/b58a10c/examples
<!-- pr-link-docs:end -->
  • Loading branch information
jleibs authored Jun 13, 2023
1 parent 2cf3d39 commit d8d6445
Show file tree
Hide file tree
Showing 6 changed files with 48 additions and 11 deletions.
6 changes: 5 additions & 1 deletion rerun_py/docs/css/mkdocstrings.css
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ body {
color: inherit;
}

.md-typeset p + h1 {
.md-typeset p+h1 {
margin-top: 2rem;
}

Expand All @@ -51,3 +51,7 @@ code {
--md-code-bg-color: #e3e3e3;
font-family: "JetBrains Mono", monospace;
}

.md-typeset a {
--md-typeset-a-color: #526cfe;
}
40 changes: 35 additions & 5 deletions rerun_py/docs/gen_common_index.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ class Section:
title: str
module_summary: str | None
func_list: list[str]
class_list: list[str]


# This is the list of sections and functions that will be included in the index
Expand All @@ -50,16 +51,19 @@ class Section:
title="Initialization",
module_summary=None,
func_list=["init", "connect", "disconnect", "spawn", "serve", "memory_recording"],
class_list=[],
),
Section(
title="Viewer Control",
module_summary=None,
func_list=["save"],
class_list=[],
),
Section(
title="Time",
module_summary=None,
func_list=["set_time_sequence", "set_time_seconds", "set_time_nanos"],
class_list=[],
),
Section(
title="Spatial Primitives",
Expand All @@ -77,31 +81,37 @@ class Section:
"log_meshes",
"log_mesh_file",
],
class_list=[],
),
Section(
title="Images",
module_summary=None,
func_list=["log_image", "log_image_file", "log_depth_image", "log_segmentation_image"],
class_list=[],
),
Section(
title="Tensors",
module_summary=None,
func_list=["log_tensor"],
class_list=[],
),
Section(
title="Annotations",
module_summary=None,
func_list=["log_annotation_context"],
class_list=["ClassDescription", "AnnotationInfo"],
),
Section(
title="Extension Components",
module_summary=None,
func_list=["log_extension_components"],
class_list=[],
),
Section(
title="Plotting",
module_summary=None,
func_list=["log_scalar"],
class_list=[],
),
Section(
title="Transforms",
Expand All @@ -114,23 +124,27 @@ class Section:
"log_disconnected_space",
"log_view_coordinates",
],
class_list=[],
),
Section(
title="Text",
module_summary=None,
# TODO(#1251): Classes aren't supported yet
# "LogLevel", "LoggingHandler"
func_list=["log_text_entry"],
class_list=["LogLevel", "LoggingHandler"],
),
Section(
title="Clearing Entities",
module_summary=None,
func_list=["log_cleared"],
class_list=[],
),
Section(
title="Helpers",
module_summary="script_helpers",
func_list=["script_add_args", "script_setup", "script_teardown"],
class_list=[],
),
Section(
title="Experimental",
Expand All @@ -142,6 +156,7 @@ class Section:
"experimental.set_panels",
"experimental.set_auto_space_views",
],
class_list=[],
),
]

Expand Down Expand Up @@ -213,14 +228,29 @@ def make_slug(s: str) -> str:
fd.write("----\n")
for func_name in section.func_list:
fd.write(f"::: rerun.{func_name}\n")
fd.write(" options:\n")
fd.write(" heading_level: 4\n")
for class_name in section.class_list:
# fd.write(f"::: rerun.{class_name}\n")
fd.write(f"::: rerun.{class_name}\n")
fd.write(" options:\n")
fd.write(" heading_level: 4\n")

# Write out a table for the section in the index_file
index_file.write(f"## {section.title}\n")
index_file.write("Function | Description\n")
index_file.write("-------- | -----------\n")
for func_name in section.func_list:
func = rerun_pkg[func_name]
index_file.write(f"[`rerun.{func_name}()`]({md_name}#rerun.{func_name}) | {func.docstring.lines[0]}\n")
if section.func_list:
index_file.write("Function | Description\n")
index_file.write("-------- | -----------\n")
for func_name in section.func_list:
func = rerun_pkg[func_name]
index_file.write(f"[`rerun.{func_name}()`]({md_name}#rerun.{func_name}) | {func.docstring.lines[0]}\n")
if section.class_list:
index_file.write("\n")
index_file.write("Class | Description\n")
index_file.write("-------- | -----------\n")
for class_name in section.class_list:
cls = rerun_pkg[class_name]
index_file.write(f"[`rerun.{class_name}`]({md_name}#rerun.{class_name}) | {cls.docstring.lines[0]}\n")

index_file.write("\n")

Expand Down
2 changes: 1 addition & 1 deletion rerun_py/docs/package/index.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Full Package

- [rerun][]: Top-level User-facing APIs. See also: [Common APIs](/common)
- [rerun][]: Top-level User-facing APIs. See also: [Common APIs](../common/)
- [rerun.log][]: APIs for logging data
- [rerun.color_conversion][]: Conversion utilities related to colors
- [rerun.components][]: Helpers for constructing arrow components
Expand Down
5 changes: 4 additions & 1 deletion rerun_py/docs/templates/python/material/class.html
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,10 @@
{% set heading_level = heading_level - 1 %}
{% endif %}

<div class="doc doc-contents {% if root %}first{% endif %}">
{# CHANGE Relative to Upstream: don't apply the 'first' class since it causes worse CSS formatting for our #}
{# generated common API index since we inline bare functions that become root-level rather than modules. #}
{#<div class="doc doc-contents {% if root %}first{% endif %}">#}
<div class="doc doc-contents">
{% if config.show_bases and class.bases %}
<p class="doc doc-class-bases">
Bases: {% for expression in class.bases -%}
Expand Down
5 changes: 3 additions & 2 deletions rerun_py/docs/templates/python/material/function.html
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,10 @@
{% set heading_level = heading_level - 1 %}
{% endif %}

{# CHANGE: disable gating of first for root docstring #}
{# CHANGE Relative to Upstream: don't apply the 'first' class since it causes worse CSS formatting for our #}
{# generated common API index since we inline bare functions that become root-level rather than modules. #}
{#<div class="doc doc-contents {% if root %}first{% endif %}">#}
<div class="doc doc-contents {% if root %}{% endif %}">
<div class="doc doc-contents">
{% with docstring_sections = function.docstring.parsed %}
{% include "docstring.html" with context %}
{% endwith %}
Expand Down
1 change: 0 additions & 1 deletion rerun_py/mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -62,4 +62,3 @@ extra:
version:
provider: mike
default: latest

1 comment on commit d8d6445

@github-actions
Copy link

Choose a reason for hiding this comment

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

⚠️ Performance Alert ⚠️

Possible performance regression was detected for benchmark 'Rust Benchmark'.
Benchmark result of this commit is worse than the previous benchmark result exceeding threshold 1.25.

Benchmark suite Current: d8d6445 Previous: 2cf3d39 Ratio
mono_points_arrow_batched/encode_log_msg 603605 ns/iter (± 1387) 421399 ns/iter (± 1248) 1.43
batch_points_arrow/encode_log_msg 117155 ns/iter (± 211) 58192 ns/iter (± 111) 2.01

This comment was automatically generated by workflow using github-action-benchmark.

Please sign in to comment.