aboutsummaryrefslogtreecommitdiff
path: root/entries/perryliao/fib.groovy
blob: af1c4dfd8dfc958b3ae34e16cb9195efc9d1d29f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
pipeline {
    agent any

    parameters {
        string defaultValue: '2', description: 'Number to compute in the Fibonacci Sequence', name: 'num', trim: true
    }

    stages {
        stage('Create Cache') {
            steps {
                script {
                    if (!fileExists("fibbonacciCache")) {
                        sh 'echo "0\n1" > fibbonacciCache'
                    }
                }
            }
        }
        stage('Validate Parameter') {
            steps {
                script {
                    assert params.num.isInteger()
                }
            }
        }
        stage('Get Fibbonacci') {
            steps {
                script {
                    result = fib(params.num.toInteger())
                    println("The result is F(${params.num}) = ${result}")
                }
            }
        }
    }
}

int fib(int n, cache = 'fibbonacciCache') {
    nComputed = sh(returnStdout: true, script: "wc -l < ${cache}").trim().toInteger()
    if (n >= nComputed) {
        // Need to do more recursion
        result = fib(n - 2, cache) + fib(n - 1, cache)
        sh "echo '${result}' >> ${cache}"
        return result
    } else {
        // Already have what we need, so read from cache
        return sh(returnStdout: true, script: "sed -n '${n + 1}p' ${cache}").trim().toInteger()
    }
}