mirror of
https://github.com/panda3d/panda3d.git
synced 2025-10-04 10:54:24 -04:00
FAQ for PythonRedefine
This commit is contained in:
parent
7fefe01e6a
commit
b34f7efeec
48
direct/src/doc/howto.PythonRedefine
Executable file
48
direct/src/doc/howto.PythonRedefine
Executable file
@ -0,0 +1,48 @@
|
||||
Python Redefine FAQ
|
||||
|
||||
Q: So, what is Ctrl-C-Ctrl-V?
|
||||
|
||||
A: Since Python is an interpreted language, you can redefine code on the
|
||||
fly. Lets say you have a class method that creates and plays a sword slash
|
||||
interval, carefully timing an animation, a particle effect, and a sound
|
||||
effect. If you could tweak the timing and properties of this interval in
|
||||
your code and magically hit a hotkey to see the change immediately in-game,
|
||||
it would cut your iteration time from a 5 minute restart down to 1
|
||||
second. ctrl-c-ctrl-v is that magic hotkey. Of course it works on arbitrary
|
||||
Python classes, not just intervals. If you are show-coding in Emacs, you
|
||||
really should try it -- it can save you lots of time!
|
||||
|
||||
|
||||
Q: How do I use it?
|
||||
|
||||
A: In your Emacs buffer within your class definition, make a change to a
|
||||
function and hit control-c-control-v. This will redefine the function, and
|
||||
in fact the entire class and thus all objects that are defined by that
|
||||
class. Some feedback will be printed out at the Python prompt.
|
||||
|
||||
|
||||
Q: Does it only work in Emacs?
|
||||
|
||||
A: Yes, unfortunately it only works from inside Emacs right now, but it can
|
||||
probably be adapted to any scriptable editor. Most of the code is in
|
||||
Python, not in emacs (lisp). Ask if you are curious about getting this
|
||||
working in your favorite editor.
|
||||
|
||||
|
||||
Q: Can I redefine code on the client and the AI?
|
||||
|
||||
A: If you are using multi-python Emacs buffers, it will actually redefine
|
||||
this class on the AI, Uberdog, and client simultaneously. Otherwise, you
|
||||
must control-c-control-v from the Emacs where you are running the process
|
||||
you want the class redefined in. Note, if the class does not exist on the
|
||||
AI or client, it will safely ignore.
|
||||
|
||||
|
||||
Q: What about systems that store function callbacks?
|
||||
|
||||
A: The common systems that store function callbacks are properly searched
|
||||
and replaced when you control-c-control-v. This includes the TaskManager,
|
||||
FunctionIntervals (new), ClassicFSMs, the Messenger, and DistributedObject
|
||||
dc updates. If you are storing a function pointer in your own code ad hoc,
|
||||
the Finder will not currently replace that; though I could imagine a brute
|
||||
force way to find those too.
|
Loading…
x
Reference in New Issue
Block a user