Skip to content

Commit

Permalink
Backport PR #1158: Update /generate to not split classes & function…
Browse files Browse the repository at this point in the history
…s across cells (#1164)

Co-authored-by: Sanjiv Das <srdas@scu.edu>
  • Loading branch information
meeseeksmachine and srdas authored Dec 20, 2024
1 parent 6c895bf commit 93751eb
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions packages/jupyter-ai/jupyter_ai/chat_handlers/generate.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import ast
import asyncio
import os
import time
Expand Down Expand Up @@ -198,6 +199,15 @@ async def afill_outline(outline, llm, verbose=False):
await asyncio.gather(*all_coros)


# Check if the content of the cell is python code or not
def is_not_python_code(source: str) -> bool:
try:
ast.parse(source)
except:
return True
return False


def create_notebook(outline):
"""Create an nbformat Notebook object for a notebook outline."""
nbf = nbformat.v4
Expand All @@ -212,6 +222,26 @@ def create_notebook(outline):
nb["cells"].append(nbf.new_markdown_cell("## " + section["title"]))
for code_block in section["code"].split("\n\n"):
nb["cells"].append(nbf.new_code_cell(code_block))

# Post process notebook for hanging code cells: merge hanging cell with the previous cell
merged_cells = []
for cell in nb["cells"]:
# Fix a hanging code cell
follows_code_cell = merged_cells and merged_cells[-1]["cell_type"] == "code"
is_incomplete = cell["cell_type"] == "code" and cell["source"].startswith(" ")
if follows_code_cell and is_incomplete:
merged_cells[-1]["source"] = (
merged_cells[-1]["source"] + "\n\n" + cell["source"]
)
else:
merged_cells.append(cell)

# Fix code cells that should be markdown
for cell in merged_cells:
if cell["cell_type"] == "code" and is_not_python_code(cell["source"]):
cell["cell_type"] = "markdown"

nb["cells"] = merged_cells
return nb


Expand Down

0 comments on commit 93751eb

Please sign in to comment.