Skip to content

Commit

Permalink
deploy: 7276252
Browse files Browse the repository at this point in the history
  • Loading branch information
github-actions[bot] committed Feb 15, 2024
0 parents commit b3773f2
Show file tree
Hide file tree
Showing 24 changed files with 6,771 additions and 0 deletions.
Empty file added .nojekyll
Empty file.
629 changes: 629 additions & 0 deletions comm.html

Large diffs are not rendered by default.

593 changes: 593 additions & 0 deletions index.html

Large diffs are not rendered by default.

627 changes: 627 additions & 0 deletions reacton.html

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions robots.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Sitemap: https://itepifanio.github.io/debugbar/sitemap.xml
52 changes: 52 additions & 0 deletions search.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
[
{
"objectID": "reacton.html",
"href": "reacton.html",
"title": "Reacton",
"section": "",
"text": "_original_state_get = _RenderContext.state_get\n_original_state_set = _RenderContext.state_set\n\ndef _patched_state_get(self, context: Optional[ComponentContext] = None):\n state = context.state if context is not None else context\n print(f'_patched_state_get::{state}')\n\n _original_state_get(self, context)\n\ndef _patched_state_set(self, context: ComponentContext, state):\n print(f'_patched_state_set::{state}')\n\n _original_state_set(self, context, state)\n\n_RenderContext.state_get = _patched_state_get\n_RenderContext.state_set = _patched_state_set\n\nThe following example was adapted from reacton test suite. Patching state_get and state_set didn’t seems to track the widget changes.\n\[email protected]\ndef Test():\n value, set_value = react.use_state(0)\n return react_widgets.IntSlider(value=value)\n\nslider, rc = react.render_fixed(Test())\nstate = rc.state_get()\nbox = widgets.VBox()\nhbox, rc = react.render(Test(), box, initial_state=state, handle_error=False)\nslider\n\n\nint_value = solara.reactive(42)\nsolara.SliderInt(\"Another Test Slider:\", value=int_value, min=-10, max=120)",
"crumbs": [
"Reacton"
]
},
{
"objectID": "index.html",
"href": "index.html",
"title": "Debugbar",
"section": "",
"text": "Welcome to the Debugbar project, a proof of concept (POC) aimed at exploring various strategies to develop a debugging tool for IPyWidgets, Reacton, and Solara components. This project serves as an investigative stage, focusing on identifying effective methods to debug and track the state and interactions within these frameworks.\nThe Debugbar project represents the first step towards a sophisticated debugging solution for developers working with IPyWidgets, Reacton, and Solara. By methodically exploring and refining the strategies outlined, we aim to enhance the development experience and enable more efficient debugging workflows for complex applications.",
"crumbs": [
"Debugbar"
]
},
{
"objectID": "index.html#strategies",
"href": "index.html#strategies",
"title": "Debugbar",
"section": "Strategies",
"text": "Strategies\nBelow are the strategies currently under exploration, each offering a unique angle to approach debugging within the Jupyter ecosystem and Reacton/Solara components.\n\nComm\n\nDescription: The Comm API, part of the Jupyter notebook’s infrastructure, facilitates communication between the front-end and back-end by sending JSON-able blobs. This API is used by widgets for maintaining state synchronization.\nApproach: By monkey-patching the comm.create_comm function, we can intercept and log all messages exchanged between widgets. This allows the Debugbar to track and modify states dynamically, providing a tool-agnostic method for debugging that doesn’t rely directly on the internal state management of Reacton.\n\n\n\nReacton\n\nDescription: Reacton’s RenderContext object plays a crucial role in state management, especially with its state_get method, which is pivotal during state restoration post-hot reloads (1, 2).\nApproach:\n\nState Tracking: Implementing tracking for the state_get call within RenderContext offers insight into state restoration processes.\nPre-Render Event: Introducing a pre_render event in Reacton could allow for state_get invocations before each rendering phase, enhancing visibility into state changes.\nIntegration with Chrome Tracing: Exploring the potential of Reacton’s tracer, previously developed by the Widgetti team, to generate trace data compatible with chrome://tracing for a detailed analysis of rendering and state management performance.",
"crumbs": [
"Debugbar"
]
},
{
"objectID": "comm.html",
"href": "comm.html",
"title": "Comm",
"section": "",
"text": "Ipykernel employs the Comm class for facilitating communication between the front-end and back-end. It builds on a base Comm implementation, which includes a send function for messaging the front-end. Monkey-patching this send function presents a direct approach to intercept Comm communications.\n_original_send = Comm.send\n\ndef _patched_send(self, data=None, metadata=None, buffers=None):\n widget = widgets.Widget.widgets.get(self.comm_id)\n widget_type = type(widget).__name__ if widget else \"Unknown\"\n print(f\"Comm message sent by {widget_type} ({self.comm_id}): {data}\")\n\n _original_send(self, data, metadata, buffers)\n\nComm.send = _patched_send",
"crumbs": [
"Comm"
]
},
{
"objectID": "comm.html#testing",
"href": "comm.html#testing",
"title": "Comm",
"section": "Testing",
"text": "Testing\nThe following cells displays ipywidgets and solara example of monitoring state changes. Interact with the following widgets to intercept its state changes.\n\nslider = widgets.IntSlider(value=7, min=0, max=10, step=1, description='Test Slider:')\ndisplay(slider)\n\n\nint_value = solara.reactive(42)\nsolara.SliderInt(\"Another Test Slider:\", value=int_value, min=-10, max=120)",
"crumbs": [
"Comm"
]
}
]
Loading

0 comments on commit b3773f2

Please sign in to comment.