From 07b2c6279297bfa227dfdb229a6096d7cc1f238a Mon Sep 17 00:00:00 2001
From: Jonathan Hanks <jonathan.hanks@ligo.org>
Date: Thu, 4 Jan 2018 20:47:39 +0000
Subject: [PATCH] Forward port of r4610.  Updated calc_gps_offset.py to apply
 the offsets.

Use the new flag -n/--dry-run if you just want to calculate the offsets.


git-svn-id: https://redoubt.ligo-wa.caltech.edu/svn/advLigoRTS/trunk@4624 6dcd42c9-f523-4c6d-aada-af552506706e
---
 .../calc_gps_offset/calc_gps_offset.py        | 30 ++++++++++++++++---
 1 file changed, 26 insertions(+), 4 deletions(-)

diff --git a/src/drv/gpstime/calc_gps_offset/calc_gps_offset.py b/src/drv/gpstime/calc_gps_offset/calc_gps_offset.py
index 02949ca90..778564faa 100755
--- a/src/drv/gpstime/calc_gps_offset/calc_gps_offset.py
+++ b/src/drv/gpstime/calc_gps_offset/calc_gps_offset.py
@@ -68,7 +68,7 @@ class YMD(object):
 
 
 class Config(object):
-    def __init__(self, do_auto, do_year, do_system, leap_filename, ref_time, status_only):
+    def __init__(self, do_auto, do_year, do_system, leap_filename, ref_time, status_only, dry_run):
         def valid_flags():
             if do_auto:
                 return do_year == False and do_system == False
@@ -78,7 +78,6 @@ class Config(object):
             with open("/sys/kernel/gpstime/offset_type", "rt") as f:
                 return int(f.readline().strip())
 
-
         if not valid_flags() and not status_only:
             errmsg = "You must choose auto, year based, system based offsets"
             raise ValueError(errmsg)
@@ -99,6 +98,7 @@ class Config(object):
         self.__ref_time = YMD.convert(ref_time)
         self.__filename = leap_filename
         self.__status_only = status_only
+        self.__dry_run = dry_run
 
     def year_based(self):
         return self.__do_year
@@ -115,6 +115,9 @@ class Config(object):
     def status_only(self):
         return self.__status_only
 
+    def dry_run(self):
+        return self.__dry_run
+
     def __unicode__(self):
         mode = "year"
         if self.system_time_based():
@@ -140,6 +143,10 @@ for the LIGO gpstime driver.""")
     help_txt = "Location of a leap-second database [{0}]".format(default)
     parser.add_argument("-l", "--leap-second-db", help=help_txt,
                         default=default)
+
+    help_txt = "Do NOT attempt to set the gps_offset to the computed value"
+    parser.add_argument("-n", "--dry-run", help=help_txt, action="store_true",
+                        default=False)
     default = None
     help_txt = "Time to calculate the offset for "
     "(UNIX time in seconds) defaults to now"
@@ -163,7 +170,8 @@ for the LIGO gpstime driver.""")
                       opts.system_time,
                       opts.leap_second_db,
                       tm,
-                      opts.status)
+                      opts.status,
+                      opts.dry_run)
     except ValueError as e:
         parser.error(e)
 
@@ -318,6 +326,16 @@ def print_card_status():
             read_val("time")))
 
 
+def apply_offset(offset):
+    fname = '/sys/kernel/gpstime/offset'
+    try:
+        with open('/sys/kernel/gpstime/offset', 'wt') as f:
+            f.write("{0}".format(offset))
+    except:
+        print("Unable to apply offset of {0} to {1}.  Please make sure the gpstime module is loaded and you have "
+              "permission to write to the offset file.".format(offset, fname))
+        sys.exit(1)
+
 def main(argv):
     cfg = parse_arguments(argv)
     leap_sec_db = parse_leap_sec_to_unix(cfg.leapsec_filename())
@@ -330,8 +348,12 @@ def main(argv):
         offset = system_time_based_offset(leap_sec_db, cfg.reference_time())
     else:
         offset = 0
-    print("{0}".format(offset))
+    if cfg.dry_run():
+        print("{0}".format(offset))
+    else:
+        apply_offset(offset)
 
 
 if __name__ == '__main__':
     main(sys.argv)
+    sys.exit(0)
-- 
GitLab