Example updates that UpStare has been able to successfully carry out include:
Recursion: Updating an application recursively computing Fibonacci numbers, while nested deep in the stack, to report additional information when the recursion unwinds.
Network Sockets: Updating a server application while serving multiple clients without closing the network socket.
Multi-threaded Applications: Updating the main function body executed by multiple threads of an application. Also, updating in a producer/consumer multi-threaded application only the consumer threads while the producer threads remained unmodified.
Multi-nested Long-Lived Loops: Updating in the middle of executing Bubblesort, a multi-nested long-lived loop, to continue executing from the middle of a different multi-nested long-lived loop implementing Selectionsort while reusing the existing program state. Additionally, updating from Bubblesort to Heapsort, which is a drastically different sorting algorithm executing over different loop iterators.
vsFTPd: Updating the multi-process (forked processes do not communicate) FTP server while serving 50 clients.
PostgreSQL: Updating the multi-process (forked processes communicate) PostgreSQL database server while serving 10 clients.