LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
butlerFactory.py
Go to the documentation of this file.
1#!/usr/bin/env python
2
3#
4# LSST Data Management System
5# Copyright 2008, 2009, 2010 LSST Corporation.
6#
7# This product includes software developed by the
8# LSST Project (http://www.lsst.org/).
9#
10# This program is free software: you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation, either version 3 of the License, or
13# (at your option) any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the LSST License Statement and
21# the GNU General Public License along with this program. If not,
22# see <http://www.lsstcorp.org/LegalNotices/>.
23#
24
25# -*- python -*-
26
27"""This module defines the ButlerFactory class."""
28
29from lsst.daf.persistence import Butler
30
31
33 """ButlerFactory creates data Butlers containing data mappers. Use of it
34 is deprecated in favor of the direct Butler constructor.
35
36 The ButlerFactory class takes a mapper for a data collection.
37 It can then create Butlers with these mappers.
38
39 A data identifier is a dictionary. The keys match those understood by a
40 mapper; the values select particular data sets or collections of data
41 sets. For example, one key might be "visit". Specifying a value of
42 "695934" for this key might select a collection of images.
43
44 The mappers perform four functions:
45 1. Determine what keys are valid for dataset ids.
46 2. Obtain a collection of potential dataset ids matching a
47 partial dataset id.
48 3. Map a dataset id to the location of the dataset, including its
49 C++ and Python types.
50 4. Manipulate a retrieved dataset object so that it conforms to a
51 standard.
52
53 Public methods:
54
55 __init__(self, mapper)
56
57 create(self)
58 """
59
60 def __init__(self, mapper):
61 """Construct a ButlerFactory.
62
63 @param mapper mapper object.
64 """
65
66 self.mappermapper = mapper
67
68 def create(self):
69 """Create a Butler.
70
71 @returns a new Butler.
72 """
73
74 if hasattr(self.mappermapper, 'root'):
75 root = self.mappermapper.root
76 else:
77 root = None
78 return Butler(root=root, mapper=self.mappermapper)
char * data
Definition: BaseRecord.cc:61
table::Key< int > a