| Conditions | 5 | 
| Paths | 3 | 
| Total Lines | 21 | 
| Code Lines | 10 | 
| Lines | 0 | 
| Ratio | 0 % | 
| Tests | 10 | 
| CRAP Score | 5 | 
| Changes | 1 | ||
| Bugs | 0 | Features | 0 | 
| 1 | <?php  | 
            ||
| 56 | 32 | protected function applyLimit($stm)  | 
            |
| 57 |     { | 
            ||
| 58 | 32 |         if (! $this->limit && ! $this->offset) { | 
            |
| 59 | 30 | return $stm; // no limit or offset  | 
            |
| 60 | }  | 
            ||
| 61 | |||
| 62 | // limit but no offset?  | 
            ||
| 63 | 2 |         if ($this->limit && ! $this->offset) { | 
            |
| 64 | // use TOP in place  | 
            ||
| 65 | 1 | return preg_replace(  | 
            |
| 66 | 1 | '/^(SELECT( DISTINCT)?)/',  | 
            |
| 67 | 1 |                 "$1 TOP {$this->limit}", | 
            |
| 68 | $stm  | 
            ||
| 69 | 1 | );  | 
            |
| 70 | }  | 
            ||
| 71 | |||
| 72 | // both limit and offset. must have an ORDER clause to work; OFFSET is  | 
            ||
| 73 | // a sub-clause of the ORDER clause. cannot use FETCH without OFFSET.  | 
            ||
| 74 | 2 |         return $stm . PHP_EOL . "OFFSET {$this->offset} ROWS " | 
            |
| 75 | 2 |                     . "FETCH NEXT {$this->limit} ROWS ONLY"; | 
            |
| 76 | }  | 
            ||
| 77 | }  | 
            ||
| 78 |