1# http://pyrocko.org - GPLv3 

2# 

3# The Pyrocko Developers, 21st Century 

4# ---|P------/S----------~Lg---------- 

5 

6import logging 

7 

8# from pyrocko.squirrel.error import SquirrelError 

9from pyrocko.squirrel import model 

10 

11logger = logging.getLogger('psq.cli.update') 

12 

13headline = 'Update remote sources inventories.' 

14 

15 

16def make_subparser(subparsers): 

17 return subparsers.add_parser( 

18 'update', 

19 help=headline, 

20 description=headline) 

21 

22 

23def setup(parser): 

24 parser.add_squirrel_selection_arguments() 

25 parser.add_squirrel_query_arguments() 

26 

27 parser.add_argument( 

28 '--promises', 

29 action='store_true', 

30 dest='promises', 

31 default=False, 

32 help='Update waveform promises.') 

33 

34 parser.add_argument( 

35 '--responses', 

36 action='store_true', 

37 dest='responses', 

38 default=False, 

39 help='Update responses.') 

40 

41 

42def run(parser, args): 

43 d = args.squirrel_query 

44 squirrel = args.make_squirrel() 

45 

46 tmin = d.get('tmin', model.g_tmin) 

47 tmax = d.get('tmax', model.g_tmax) 

48 codes = d.get('codes', None) 

49 

50 squirrel.update(tmin=tmin, tmax=tmax) 

51 if args.promises: 

52 squirrel.update_waveform_promises(tmin=tmin, tmax=tmax, codes=codes) 

53 

54 if args.responses: 

55 squirrel.update_responses() 

56 

57 stats = str(squirrel) 

58 stats = '\n'.join(' ' + s for s in stats.splitlines()) 

59 

60 logger.info('Squirrel stats:\n%s' % stats)