File Coverage

blib/lib/auto/share/dist/App-Dochazka-REST/sql/schedintvls_Config.pm
Criterion Covered Total %
statement 6 6 100.0
branch n/a
condition n/a
subroutine 2 2 100.0
pod n/a
total 8 8 100.0


line stmt bran cond sub pod time code
1             # *************************************************************************
2             # Copyright (c) 2014-2015, SUSE LLC
3             #
4             # All rights reserved.
5             #
6             # Redistribution and use in source and binary forms, with or without
7             # modification, are permitted provided that the following conditions are met:
8             #
9             # 1. Redistributions of source code must retain the above copyright notice,
10             # this list of conditions and the following disclaimer.
11             #
12             # 2. Redistributions in binary form must reproduce the above copyright
13             # notice, this list of conditions and the following disclaimer in the
14             # documentation and/or other materials provided with the distribution.
15             #
16             # 3. Neither the name of SUSE LLC nor the names of its contributors may be
17             # used to endorse or promote products derived from this software without
18             # specific prior written permission.
19             #
20             # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21             # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22             # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23             # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
24             # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25             # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26             # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27             # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28             # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29             # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30             # POSSIBILITY OF SUCH DAMAGE.
31             # *************************************************************************
32             #
33             # sql/schedintvls_Config.pm
34             #
35             # SQL statements related to schedintvls
36              
37             #
38             # SQL_SCRATCH_SID
39             # SQL to get next value from scratch_sid_seq
40             #
41             set( 'SQL_SCRATCH_SID', q/
42             SELECT nextval('scratch_sid_seq');
43             / );
44              
45             #
46             # SQL_SCHEDINTVLS_INSERT
47             # SQL to insert a single record in the 'scratchintvls' table
48             #
49             set( 'SQL_SCHEDINTVLS_INSERT', q/
50             INSERT INTO schedintvls (ssid, intvl)
51             VALUES (?, ?)
52             / );
53              
54             #
55             # SQL_SCHEDINTVLS_SELECT
56             # SQL to select all the schedintvls belonging to a given SID,
57             # translated, all in one go, resulting in n rows, each containing
58             # four columns: low_dow, low_time, high_dow, high_time
59             set( 'SQL_SCHEDINTVLS_SELECT', q/
60             -- ORDER BY intvl sorts the intervals!
61             SELECT
62             (translate_schedintvl(int_id)).low_dow,
63             (translate_schedintvl(int_id)).low_time,
64             (translate_schedintvl(int_id)).high_dow,
65             (translate_schedintvl(int_id)).high_time
66             FROM (
67             SELECT int_id FROM schedintvls WHERE ssid = ?
68             ORDER BY intvl
69             ) AS int_ids
70             / );
71              
72             #
73             # SQL_SCHEDINTVLS_DELETE
74             # SQL to delete scratch intervals once they are no longer needed
75             set( 'SQL_SCHEDINTVLS_DELETE', q/
76             DELETE FROM schedintvls WHERE ssid = ?
77             / );
78              
79             # -----------------------------------
80             # DO NOT EDIT ANYTHING BELOW THIS LINE
81             # -----------------------------------
82 41     41   25582 use strict;
  41         103  
  41         1087  
83 41     41   210 use warnings;
  41         96  
  41         1300  
84              
85             1;