The IPython startup script
~/.config/ipython/profile_spockdoor/startup/00-start.py
is used to:
To purge versioned files:
$ vrsn Usage: Display all versions: # vrsn file_name Create a new version: # vrsn -s file_name Purge, keeping nk (def 2): # vrsn -p [nk] file_name Rename the files, starting from 1: # vrsn -reset file_name -nolog is optional, suppresses informational output
#!/usr/bin/env python # # file name ~/.config/ipython/profile_spockdoor/startup/00-start.py # import os, time, atexit import PyTango # # make sure that ipython_log.py is in PWD and /online_dir # def _spockExitHandler(): if os.path.exists( '/online_dir/ipython_log.py'): os.system( 'vrsn -nolog -s /online_dir/ipython_log.py') # # register exit handler # atexit.register( _spockExitHandler) # if os.path.exists( "%s/ipython_log.py" % os.environ['PWD']): os.system( "vrsn -nolog -s %s/ipython_log.py" % os.environ['PWD']) os.system( "/bin/rm %s/ipython_log.py" % os.environ['PWD']) # # get the ipython shell # ip = get_ipython() # # -o log include output # -r raw log 'wm exp_dmy01' instead of get_ipython().magic(u'wm exp_dmy01') # -t with timestamp # ip.magic( '%logstart -o -r -t') # # store the current motor attributes in a new version of /online_dir/MotorLogs/motorLog.lis # # -x execute # -q quiet # -c the name of the calling program is written to the log file # os.system('MotorLogger.py -x -q -c spock') os.system( "ln -sf %s/ipython_log.py /online_dir/ipython_log.py" % os.environ['PWD']) # # write some text to the log file # # ip.logger.log_write( unicode( "# some text \n")) # # execute some commands in a Door, make sure # that the Door is in ON state before the next # command is submitted. # door = PyTango.DeviceProxy("haspp14:10000/p14/door/haspp14.01") door.RunMacro(["gh_enable"]) count = 0 while str( door.state()) == "RUNNING" and count < 5: time.sleep(0.1) count += 1 door.RunMacro(["gs_enable"]) count = 0 while str( door.state()) == "RUNNING" and count < 5: time.sleep(0.1) count += 1 # # prepare aliases for SardanaMonitor, SardanaInfoViewer and SardanaMotorMonitor # ip.magic( '%alias sm ! SardanaMonitor.py &') print "use 'sm' to launch the SardanaMonitor" ip.magic( '%alias iv ! SardanaInfoViewer.py &') print "use 'iv' to launch the SardanaInfoViewer" ip.magic( '%alias smm ! SardanaMotorMonitor.py &') print "use 'smm' to launch the SardanaMotorMonitor"