ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/COMP/CRAB/python/PsetManipulator.py
(Generate patch)

Comparing COMP/CRAB/python/PsetManipulator.py (file contents):
Revision 1.23 by slacapra, Thu Nov 6 17:51:43 2008 UTC vs.
Revision 1.29 by spiga, Tue May 26 10:23:01 2009 UTC

# Line 3 | Line 3
3   import os
4   import common
5   import imp
6 + import pickle
7  
8   from crab_util import *
9   from crab_exceptions import *
9 from crab_logger import Logger
10  
11   from ProdCommon.CMSConfigTools.ConfigAPI.CfgInterface import CfgInterface
12   from FWCore.ParameterSet.DictTypes import SortedKeysDict
# Line 25 | Line 25 | class PsetManipulator:
25          self.pset = pset
26          #convert Pset
27          from FWCore.ParameterSet.Config import include
28 <        common.logger.debug(3,"PsetManipulator::__init__: PSet file = "+self.pset)
28 >        common.logger.debug("PsetManipulator::__init__: PSet file = "+self.pset)
29 >        # FUTURE: Can drop cfg mode for CMSSW < 2_1_x
30          if self.pset.endswith('py'):
31              handle = open(self.pset, 'r')
32              try:   # Nested form for Python < 2.5
# Line 55 | Line 56 | class PsetManipulator:
56          self.cfg.maxEvents.setMaxEventsInput(maxEv)
57          return
58  
59 +    def skipEvent(self, skipEv):
60 +        """
61 +        Set max event in the standalone untracked module
62 +        """
63 +        self.cfg.inputSource.setSkipEvents(skipEv)
64 +        return
65 +
66      def psetWriter(self, name):
67          """
68          Write out modified CMSSW.cfg
# Line 64 | Line 72 | class PsetManipulator:
72          outFile = open(common.work_space.jobDir()+name,"w")
73          if name.endswith('py'):
74              outFile.write("import FWCore.ParameterSet.Config as cms\n")
75 <            try:
76 <                outFile.write(self.cmsProcess.dumpPython())
77 <            except Exception, ex:
70 <                msg =  "Your cfg file is not valid, %s\n" % str(ex)
71 <                msg += "  https://twiki.cern.ch/twiki/bin/view/CMS/SWGuideCrabFaq#Problem_with_ParameterSet_parsin\n"
72 <                msg += "  may help you understand the problem."
73 <                raise CrabException(msg)
74 <
75 >            outFile.write("import pickle\n")
76 >            outFile.write("pickledCfg=\"\"\"%s\"\"\"\n" % pickle.dumps(self.cmsProcess))
77 >            outFile.write("process = pickle.loads(pickledCfg)\n")
78          else:
79              outFile.write(self.cfg.data.dumpConfig())
80          outFile.close()
81  
82          return
83  
81    def addCrabFJR(self,name):
82        """
83        _addCrabFJR_
84        add CRAB specific FrameworkJobReport (FJR)
85        if a FJR already exists in input CMSSW parameter-set, add a second one.
86        This code is not needed for CMSSW >= 1.5.x and is non-functional in CMSSW >= 1.7.x.
87        It should be removed at some point in the future.
88        """
89
90        # Check if MessageLogger service already exists in configuration. If not, add it
91        svcs = self.cfg.data.services
92        if not svcs.has_key('MessageLogger'):
93            self.cfg.data.add_(CfgModules.Service("MessageLogger"))
94
95        messageLogger = self.cfg.data.services['MessageLogger']
96
97        # Add fwkJobReports to Message logger if it doesn't exist
98        if "fwkJobReports" not in messageLogger.parameterNames_():
99            messageLogger.fwkJobReports = CfgTypes.untracked(CfgTypes.vstring())
100
101        # should figure out how to remove "name" if it is there.
102
103        if name not in messageLogger.fwkJobReports:
104            messageLogger.fwkJobReports.append(name)
105
106        return
107
84      def getTFileService(self):
85          """ Get Output filename from TFileService and return it. If not existing, return None """
86          if not self.cfg.data.services.has_key('TFileService'):
# Line 123 | Line 99 | class PsetManipulator:
99          for out in poolOutputModule:
100              return poolOutputModule[out].fileName.value()
101  
102 +    def getBadFilesSetting(self):
103 +        setting = False
104 +        try:
105 +            if self.cfg.data.source.skipBadFiles.value():
106 +                setting = True
107 +        except AttributeError:
108 +            pass # Either no source or no setting of skipBadFiles
109 +        return setting

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines