1: <?php
2: /**
3: * LICENSE (BSD)
4: *
5: * Copyright (c) 2013, Gerd Christian Kunze
6: * All rights reserved.
7: *
8: * Redistribution and use in source and binary forms, with or without
9: * modification, are permitted provided that the following conditions are
10: * met:
11: *
12: * * Redistributions of source code must retain the above copyright
13: * notice, this list of conditions and the following disclaimer.
14: *
15: * * Redistributions in binary form must reproduce the above copyright
16: * notice, this list of conditions and the following disclaimer in the
17: * documentation and/or other materials provided with the distribution.
18: *
19: * * Neither the name of Gerd Christian Kunze nor the names of the
20: * contributors may be used to endorse or promote products derived from
21: * this software without specific prior written permission.
22: *
23: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
24: * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
25: * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
27: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34: *
35: * Fix
36: * 18.02.2013 08:38
37: */
38: namespace MOC\Core\Changelog;
39: use MOC\Api;
40: use MOC\Generic\Device\Core;
41:
42: /**
43: *
44: */
45: class Fix implements Core {
46: /**
47: * Get Dependencies
48: *
49: * @static
50: * @return \MOC\Core\Depending
51: */
52: public static function InterfaceDepending() {
53: return Api::Core()->Depending();
54: }
55:
56: /**
57: * Get Singleton/Instance
58: *
59: * @static
60: * @return \MOC\Core\Changelog\Fix
61: */
62: public static function InterfaceInstance() {
63: return new Fix();
64: }
65:
66: /**
67: * Get Changelog
68: *
69: * @static
70: * @return \MOC\Core\Changelog
71: */
72: public static function InterfaceChangelog() {
73: return Api::Core()->Changelog()->Create( __CLASS__ )
74: ->Fix()->DocFix( '18.02.2013 10:58', 'Add description to HotFix()' )
75: ->Fix()->DocFix( '18.02.2013 11:23', 'Add description to BugFix()' )
76: ->Fix()->DocFix( '18.02.2013 12:02', 'Add description DocFix()' )
77: ->Build()->Clearance( '18.02.2013 13:17', 'Alpha' )
78: ;
79: }
80:
81: /**
82: * A hotfix is a very important (urgent) fix, but contains no new features.
83: *
84: * @param $Timestamp
85: * @param $Message
86: *
87: * @return \MOC\Core\Changelog
88: */
89: public function HotFix( $Timestamp, $Message ) {
90: $Record = Record::InterfaceInstance();
91: $Record->Timestamp( $Timestamp );
92: $Record->Method( __METHOD__ );
93: $Record->Message( $Message );
94: return Api::Core()->Changelog()->Append( $Record );
95: }
96:
97: /**
98: * A bugfix corrects errors in the program source code, which could otherwise cause malfunctions.
99: *
100: * @param $Timestamp
101: * @param $Message
102: *
103: * @return \MOC\Core\Changelog
104: */
105: public function BugFix( $Timestamp, $Message ) {
106: $Record = Record::InterfaceInstance();
107: $Record->Timestamp( $Timestamp );
108: $Record->Method( __METHOD__ );
109: $Record->Message( $Message );
110: return Api::Core()->Changelog()->Append( $Record );
111: }
112:
113: /**
114: * A docfix corrects errors in the documentation code block
115: *
116: * @param $Timestamp
117: * @param $Message
118: *
119: * @return \MOC\Core\Changelog
120: */
121: public function DocFix( $Timestamp, $Message ) {
122: $Record = Record::InterfaceInstance();
123: $Record->Timestamp( $Timestamp );
124: $Record->Method( __METHOD__ );
125: $Record->Message( $Message );
126: return Api::Core()->Changelog()->Append( $Record );
127: }
128: }
129: