Infelizmente, essa é uma das poucas limitações de Revise.jl
(e se houvesse uma maneira de fazê-lo, provavelmente seria implementada no Revise
). Portanto, mesmo usando Revise
você atualmente, você deve reiniciar julia para alterar a definição de um tipo.
Deixe-me apenas tentar ilustrar o motivo pelo qual isso atualmente não é possível:
julia> struct Person
name :: String
end
julia> alice = Person("Alice")
Person("Alice")
# Imagine you have some magic trick that makes this possible:
julia> struct Person
id :: Int
name :: String
end
julia> bob = Person(42, "Bob")
Person(42, "Bob")
# What should be the type of alice now?
julia> alice
Person("Alice") # Not consistent with the current definition of Person
Às vezes, uso o seguinte truque durante o estágio de desenvolvimento de um novo tipo. É um pouco complicado, no entanto, e não tenho certeza se devo aconselhá-lo: use por seu próprio risco.
A ideia consiste em numerar suas definições de tipo reais, nomear seus tipos como Person1
, Person2
com um número de versão que é incrementado cada vez que a definição é alterada. Para ter usos desses nomes de tipo numerados espalhados por todo o código nas definições de método, você pode temporariamente alias a definição mais recente para um nome comum não numerado.
Suponha, por exemplo, que você tenha uma primeira implementação do seu Person
tipo, com apenas um nome:
# First version of the type
julia> struct Person1
name :: String
end
# Aliased to just "Person"
julia> Person = Person1
Person1
# Define methods and instances like usual, using the "Person" alias
julia> hello(p::Person) = println("Hello $(p.name)")
hello (generic function with 1 method)
julia> alice = Person("Alice")
Person1("Alice")
julia> hello(alice)
Hello Alice
Agora, suponha que você queira alterar a definição do Person
tipo para adicionar um id
campo:
# Second version of the type: increment the number
# This is strictly a new, different type
julia> struct Person2
id :: Int
name :: String
end
# But you can alias "Person" to this new type
julia> Person = Person2
Person2
# It looks as though you update the definition of the same "hello" method...
julia> hello(p::Person) = println("Hello $(p.name), you have id: $(p.id)")
hello (generic function with 2 methods)
# ...when in reality you are defining a new method
julia> methods(hello)
# 2 methods for generic function "hello":
[1] hello(p::Person2) in Main at REPL[8]:1
[2] hello(p::Person1) in Main at REPL[3]:1
julia> bob = Person(42, "Bob")
Person2(42, "Bob")
julia> hello(bob)
Hello Bob, you have id: 42
# alice is still of type "Person1", and old methods still work
julia> hello(alice)
Hello Alice
Revise
?