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.24 by ewv, Tue Dec 16 17:07:08 2008 UTC vs.
Revision 1.39 by ewv, Wed Oct 6 13:57:46 2010 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 + # FIXME: Cleanup includes from FWCore. Most of this is not needed.
13 + #from FWCore.ParameterSet.Config    import include
14   from FWCore.ParameterSet.DictTypes import SortedKeysDict
15 + from FWCore.ParameterSet.Modules   import OutputModule
16   from FWCore.ParameterSet.Modules   import Service
17   from FWCore.ParameterSet.Types     import *
18  
19   import FWCore.ParameterSet.Types   as CfgTypes
20   import FWCore.ParameterSet.Modules as CfgModules
21 + import FWCore.ParameterSet.Config  as cms
22  
23   class PsetManipulator:
24      def __init__(self, pset):
# Line 23 | Line 27 | class PsetManipulator:
27          """
28  
29          self.pset = pset
30 <        #convert Pset
31 <        from FWCore.ParameterSet.Config import include
32 <        common.logger.debug(3,"PsetManipulator::__init__: PSet file = "+self.pset)
33 <        if self.pset.endswith('py'):
30 <            handle = open(self.pset, 'r')
31 <            try:   # Nested form for Python < 2.5
32 <                try:
33 <                    self.cfo = imp.load_source("pycfg", self.pset, handle)
34 <                    self.cmsProcess = self.cfo.process
35 <                except Exception, ex:
36 <                    msg = "Your config file is not valid python: %s" % str(ex)
37 <                    raise CrabException(msg)
38 <            finally:
39 <                handle.close()
40 <        else:
30 >
31 >        common.logger.debug("PsetManipulator::__init__: PSet file = "+self.pset)
32 >        handle = open(self.pset, 'r')
33 >        try:   # Nested form for Python < 2.5
34              try:
35 <                self.cfo = include(self.pset)
36 <                self.cmsProcess = self.cfo
35 >                self.cfo = imp.load_source("pycfg", self.pset, handle)
36 >                self.cmsProcess = self.cfo.process
37              except Exception, ex:
38 <                msg =  "Your cfg file is not valid, %s\n" % str(ex)
46 <                msg += "  https://twiki.cern.ch/twiki/bin/view/CMS/SWGuideCrabFaq#Problem_with_ParameterSet_parsin\n"
47 <                msg += "  may help you understand the problem."
38 >                msg = "Your config file is not valid python: %s" % str(ex)
39                  raise CrabException(msg)
40 +        finally:
41 +            handle.close()
42 +
43          self.cfg = CfgInterface(self.cmsProcess)
44 +        try: # Quiet the output
45 +            if self.cfg.data.MessageLogger.cerr.FwkReport.reportEvery.value() < 100:
46 +                self.cfg.data.MessageLogger.cerr.FwkReport.reportEvery = cms.untracked.int32(100)
47 +        except AttributeError:
48 +            pass
49  
50      def maxEvent(self, maxEv):
51          """
# Line 59 | Line 58 | class PsetManipulator:
58          """
59          Set max event in the standalone untracked module
60          """
61 <        self.cfg.inputSource.setSkipEvents(skipEv)
61 >        if self.cfg.inputSource.sourceType not in ['EmptySource']:
62 >            self.cfg.inputSource.setSkipEvents(skipEv)
63          return
64  
65      def psetWriter(self, name):
66          """
67 <        Write out modified CMSSW.cfg
67 >        Write out modified CMSSW.py
68          """
69  
70 <        # FUTURE: Can drop cfg mode for CMSSW < 2_1_x
71 <        outFile = open(common.work_space.jobDir()+name,"w")
72 <        if name.endswith('py'):
73 <            outFile.write("import FWCore.ParameterSet.Config as cms\n")
74 <            try:
75 <                outFile.write(self.cmsProcess.dumpPython())
76 <            except Exception, ex:
77 <                msg =  "Your cfg file is not valid, %s\n" % str(ex)
78 <                msg += "  https://twiki.cern.ch/twiki/bin/view/CMS/SWGuideCrabFaq#Problem_with_ParameterSet_parsin\n"
79 <                msg += "  may help you understand the problem."
80 <                raise CrabException(msg)
81 <
82 <        else:
83 <            outFile.write(self.cfg.data.dumpConfig())
70 >        pklFileName = common.work_space.jobDir() + name + ".pkl"
71 >        pklFile = open(pklFileName, "wb")
72 >        myPickle = pickle.Pickler(pklFile)
73 >        myPickle.dump(self.cmsProcess)
74 >        pklFile.close()
75 >
76 >        outFile = open(common.work_space.jobDir()+name, "w")
77 >        outFile.write("import FWCore.ParameterSet.Config as cms\n")
78 >        outFile.write("import pickle\n")
79 >        outFile.write("process = pickle.load(open('%s', 'rb'))\n" % (name + ".pkl"))
80          outFile.close()
81  
86        return
87
88    def addCrabFJR(self,name):
89        """
90        _addCrabFJR_
91        add CRAB specific FrameworkJobReport (FJR)
92        if a FJR already exists in input CMSSW parameter-set, add a second one.
93        This code is not needed for CMSSW >= 1.5.x and is non-functional in CMSSW >= 1.7.x.
94        It should be removed at some point in the future.
95        """
96
97        # Check if MessageLogger service already exists in configuration. If not, add it
98        svcs = self.cfg.data.services
99        if not svcs.has_key('MessageLogger'):
100            self.cfg.data.add_(CfgModules.Service("MessageLogger"))
101
102        messageLogger = self.cfg.data.services['MessageLogger']
103
104        # Add fwkJobReports to Message logger if it doesn't exist
105        if "fwkJobReports" not in messageLogger.parameterNames_():
106            messageLogger.fwkJobReports = CfgTypes.untracked(CfgTypes.vstring())
107
108        # should figure out how to remove "name" if it is there.
109
110        if name not in messageLogger.fwkJobReports:
111            messageLogger.fwkJobReports.append(name)
82  
83          return
84  
# Line 124 | Line 94 | class PsetManipulator:
94  
95      def getPoolOutputModule(self):
96          """ Get Output filename from PoolOutputModule and return it. If not existing, return None """
97 <        if not self.cfg.data.outputModules:
98 <            return None
99 <        poolOutputModule = self.cfg.data.outputModules
100 <        for out in poolOutputModule:
101 <            return poolOutputModule[out].fileName.value()
97 >        outputFinder = PoolOutputFinder()
98 >        for p  in self.cfg.data.endpaths.itervalues():
99 >            p.visit(outputFinder)
100 >        return outputFinder.getDict()
101 >        #return outputFinder.getList()
102 >
103 >    def getBadFilesSetting(self):
104 >        setting = False
105 >        try:
106 >            if self.cfg.data.source.skipBadFiles.value():
107 >                setting = True
108 >        except AttributeError:
109 >            pass # Either no source or no setting of skipBadFiles
110 >        return setting
111 >
112 > class PoolOutputFinder(object):
113 >
114 >    def __init__(self):
115 >        self._poolList = []
116 >        self._poolDict = {}
117 >
118 >    def enter(self,visitee):
119 >        if isinstance(visitee,OutputModule) and visitee.type_() == "PoolOutputModule":
120 >            filename=visitee.fileName.value().split(":")[-1]
121 >            self._poolList.append(filename)
122  
123 +            try:
124 +                selectEvents = visitee.SelectEvents.SelectEvents.value()
125 +            except AttributeError:
126 +                selectEvents = None
127 +            try:
128 +                dataset = visitee.dataset.filterName.value()
129 +            except AttributeError:
130 +                dataset = None
131 +            self._poolDict.update({filename:{'dataset':dataset, 'selectEvents':selectEvents}})
132 +
133 +    def leave(self,visitee):
134 +        pass
135 +
136 +    def getList(self):
137 +        return self._poolList
138 +
139 +    def getDict(self):
140 +        #### FEDE FOR MULTI ####
141 +        return self._poolDict

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines