Creating Packages in Julia

Author: Arsh Sharma

December 22nd, 2020


We are well aware that in order to use the functionality that Julia offers we often need to write out own packages so that we and many people across the world can use those packages into their workflow. Julia has a very rich package ecosystem and a powerful package manager.

This article is a step by step detail of how one can write his/her own package manager in Julia.

Step 1: Creating a Package Template


In the above picture you can see that apart from the src folder that holds the main code pertaining to the package, there are many other files and folder like Project.TOML, test,, codecov.yml etc. that are required by julia for things like version control, testing etc. To automatically generate this for our package we will use the PkgTemplates.jl package to create a template.

using Pkg
using PkgTemplates


A template can be created using the Template() method.

t = Template(;
             authors=["gfguser", "juliapkg"],

Some more examples are given here.

Step 2: Generating a package from the template

Now we need to generate our package using the template that we created above using the generate() method.

#generates a package named 


It says that the new package is available by the name of isteforlife.jl !

Step 3: Adding code to the package


If you head over to the .julia/dev/isteforlife folder, you will find a directory structure similar to the one that we saw above. Head on to the src folder and open the isteforlife.jl file and add some basic code to it.

println("This is my first julia package")
println(20 + 20)

Step 4: Running the package

Now that we have added some started code, let's take the package out for a spin!

# tell julia that it can use the new package
using Pkg

using isteforlife


This article highlighted the very basic ways of creating packages. For complex workflows one can refer to the PkgTemplates documentation.

Wanna talk to ISTE? Or be a part of it? You can contact any of our members personally or 📧 us at!