Modules and Revise

The most practical way to develop code in Julia, particularly when the code becomes more complex, is to write modules and use the Revise package.

To install the Revise package, do:

julia> ] add Revise

The workflow is, then:

Create a function

Create a file with a function, for example: f.jl

function f(x)
    y = 2*x
    return y
end

Create a module

Create a file called, for example, MyModule.jl, in which you define a module of the same name. Include the files with your function definitions in this module:

module MyModule
    export f
    include("./f.jl")  
end

The export f command makes the f function visible from outside the module. That is, later when you load the module with using MyModule you will be able to directly call f(x) instead of having to type MyModule.f(1). Exporting or not functions is optional.

Develop using Revise

Now, start Julia and load the module with the following commands:

using Revise
push!(LOAD_PATH,"/path/to/MyModule")
using MyModule

(it is a good idea to put these commands in a file, lets say devel.jl, to load it with julia -i devel.jl every time you start a development section).

This will load the module with its functions. Since the module was loaded after Revise, the changes to the files included in that module will be tracked and updated automatically.

That means that:

julia> using Revise

julia> push!(LOAD_PATH,"/path/to/MyModule")

julia> using MyModule

julia> f(1)
2

Now, if I modify the file f.jl such that the function multiplies the value of x by 5, and save it, we have:

julia> f(1)
5

Thus, the REPL section can be kept open and I can change and modify my package functions without having to load all the packages all the time. The only situation, for now, that will require the restart of Julia is the redefinition of a struct, which for complicated reasons Revise is not able to track appropriately and update the state of the Julia section.