From db307dc88aa8d45754238edaeb3b2c028d8653f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonatan=20K=C5=82osko?= Date: Sat, 22 Feb 2025 01:53:24 +0900 Subject: [PATCH] Show an error when an unexpected version of Pythonx is installed --- lib/livebook/runtime/definitions.ex | 2 ++ lib/livebook/runtime/evaluator.ex | 34 +++++++++++++++------ lib/livebook/runtime/evaluator/formatter.ex | 9 ------ 3 files changed, 26 insertions(+), 19 deletions(-) diff --git a/lib/livebook/runtime/definitions.ex b/lib/livebook/runtime/definitions.ex index 386d2a872..6bb07a144 100644 --- a/lib/livebook/runtime/definitions.ex +++ b/lib/livebook/runtime/definitions.ex @@ -508,4 +508,6 @@ defmodule Livebook.Runtime.Definitions do def pythonx_dependency() do %{dep: {:pythonx, "~> 0.4.0"}, config: []} end + + def pythonx_requirement(), do: "~> 0.4.0" end diff --git a/lib/livebook/runtime/evaluator.ex b/lib/livebook/runtime/evaluator.ex index 4e2a5d009..1931a56c9 100644 --- a/lib/livebook/runtime/evaluator.ex +++ b/lib/livebook/runtime/evaluator.ex @@ -1053,21 +1053,35 @@ defmodule Livebook.Runtime.Evaluator do end defp ensure_pythonx() do - if Code.ensure_loaded?(Pythonx) do - :ok - else - message = - """ - Pythonx is missing, make sure to add it as a dependency: + pythonx_requirement = Livebook.Runtime.Definitions.pythonx_requirement() - #{Macro.to_string(Livebook.Runtime.Definitions.pythonx_dependency().dep)} - """ + cond do + not Code.ensure_loaded?(Pythonx) -> + message = + """ + Pythonx is missing, make sure to add it as a dependency: - exception = RuntimeError.exception(message) - {{:error, :error, exception, []}, []} + #{Macro.to_string(Livebook.Runtime.Definitions.pythonx_dependency().dep)} + """ + + exception = RuntimeError.exception(message) + {{:error, :error, exception, []}, []} + + not Version.match?(pythonx_version(), pythonx_requirement) -> + message = + "this Livebook version requires Pythonx #{pythonx_requirement}," <> + " but #{pythonx_version()} is installed, please update the dependency" + + exception = RuntimeError.exception(message) + {{:error, :error, exception, []}, []} + + true -> + :ok end end + defp pythonx_version(), do: List.to_string(Application.spec(:pythonx)[:vsn]) + defp identifier_dependencies(context, tracer_info, prev_context) do identifiers_used = MapSet.new() identifiers_defined = %{} diff --git a/lib/livebook/runtime/evaluator/formatter.ex b/lib/livebook/runtime/evaluator/formatter.ex index 2400b02bf..4a359654f 100644 --- a/lib/livebook/runtime/evaluator/formatter.ex +++ b/lib/livebook/runtime/evaluator/formatter.ex @@ -85,15 +85,6 @@ defmodule Livebook.Runtime.Evaluator.Formatter do %{type: :terminal_text, text: "Ok", chunk: false} end - def format_result(:"pyproject.toml", {:error, _kind, _error, _stacktrace}) do - formatted = - "Error, see the output above for details" - |> error_color() - |> IO.iodata_to_binary() - - %{type: :error, message: formatted, context: nil} - end - def format_result(_language, {:error, kind, error, stacktrace}) do formatted = format_error(kind, error, stacktrace) %{type: :error, message: formatted, context: error_context(error)}