From 2fed17b029ccc594e45b4369c8d7243b0d9e393e Mon Sep 17 00:00:00 2001 From: mloubout Date: Fri, 25 Oct 2024 10:09:03 -0400 Subject: [PATCH] add build --- deps/build.jl | 16 ++++++++++++++++ docs/Project.toml | 2 +- src/SlimPlotting.jl | 38 ++++++++++++-------------------------- 3 files changed, 29 insertions(+), 27 deletions(-) create mode 100644 deps/build.jl diff --git a/deps/build.jl b/deps/build.jl new file mode 100644 index 0000000..88bfa56 --- /dev/null +++ b/deps/build.jl @@ -0,0 +1,16 @@ +using PythonPlot + +deps = ("colorcet", "seiscm") + +function install_pkg(pkg) + if get(ENV, "JULIA_CONDAPKG_BACKEND", "conda") == "Null" + pyexe = PythonPlot.PythonCall.python_executable_path() + run(Cmd(`$(pyexe) -m pip install --user $(pkg)`)) + else + PythonPlot.PythonCall.C.CondaPkg.add_pip(pkg) + end +end + +for pkg in deps + install_pkg(pkg) +end \ No newline at end of file diff --git a/docs/Project.toml b/docs/Project.toml index 6b7d759..ff71bab 100644 --- a/docs/Project.toml +++ b/docs/Project.toml @@ -2,7 +2,7 @@ Documenter = "e30172f5-a6a5-5a46-863b-614d45cd2de4" JLD = "4138dd39-2aa7-5051-a626-17a0bb65d9c8" JLD2 = "033835bb-8acc-5ee8-8aae-3f567f8a3819" -PyPlot = "d330b81b-6aea-500a-939a-2ce795aea3ee" +PythonPlot = "274fc56d-3b97-40fa-a1cd-1b4a50311bf9" SegyIO = "157a0f19-4d44-4de5-a0d0-07e2f0ac4dfa" Weave = "44d3d7a6-8a23-5bf8-98c5-b353f8df5ec9" diff --git a/src/SlimPlotting.jl b/src/SlimPlotting.jl index 017533e..e538be6 100644 --- a/src/SlimPlotting.jl +++ b/src/SlimPlotting.jl @@ -4,34 +4,20 @@ using Statistics, ColorSchemes, Reexport @reexport using PythonPlot const cc = PythonPlot.PythonCall.pynew() -scm = Dict() - - -function tryimport(pkg::String) - pyi = try - PythonPlot.pyimport(pkg) - catch e - if get(ENV, "JULIA_CONDAPKG_BACKEND", "conda") == "Null" - pyexe = PythonPlot.python_executable_path() - run(Cmd(`$(pyexe) -m pip install --user $(pkg)`)) - else - PythonPlot.PythonCall.C.CondaPkg.add_pip(pkg) - end - PythonPlot.pyimport(pkg) - end - return pyi -end +const scm = PythonPlot.PythonCall.pynew() +scmp = Dict( + "seismic" => scm.seismic, + "bwr" => scm.bwr, + "phase" => scm.phase, + "frequency" => scm.frequency, +) function __init__() - # import seiscm - scmp = tryimport("seiscm") - global scm["seismic"] = scmp.seismic() - global scm["bwr"] = scmp.bwr() - global scm["phase"] = scmp.phase() - global scm["frequency"] = scmp.frequency() # Import colorcet - PythonPlot.PythonCall.pycopy!(cc, tryimport("colorcet")) + PythonPlot.PythonCall.pycopy!(cc, pyimport("colorcet")) + # Import SeisCM + PythonPlot.PythonCall.pycopy!(scm, pyimport("seiscm")) end export plot_fslice, plot_velocity, plot_simage, plot_sdata, wiggle_plot, compare_shots @@ -49,8 +35,8 @@ to_symbol(x) = x Return the colormap `name` for seiscm. These colormap are preimported as a dictionnary """ -seiscm(s::Symbol) = scm[to_string(s)] -seiscm(s::String) = scm[s] +seiscm(s::Symbol) = scmp[to_string(s)]() +seiscm(s::String) = scmp[s]() """ _plot_with_units(image, spacing; perc=95, cmap=:cet_CET_L1,