def getBranch() {
    if (env.BRANCH_NAME != null && !env.BRANCH_NAME.isEmpty() ) {
        return env.BRANCH_NAME
    } else {
        return 'develop'
    }
}

void checkout_riscv_vp() {
	sh("rm -rf *")
    checkout([
        $class: 'GitSCM',
        branches: [
            [name: 'refs/heads/' + getBranch()]
        ],
        extensions: [
            [$class: 'CleanBeforeCheckout'],
            [$class: 'SubmoduleOption', 
                disableSubmodules: false, 
                recursiveSubmodules: true, 
                trackingSubmodules: false,
                parentCredentials: true, 
                shallow: true
            ]
        ],
        submoduleCfg: [],
        userRemoteConfigs: [
            [url: 'https://github.com/eyck/RISCV-VP.git']
        ]
    ])
}

void build_riscv_vp() {
    try {
        sh("conan profile new default --detect --force")
        sh("conan profile update settings.compiler.libcxx=libstdc++11 default")
        sh("conan remote add minres https://git.minres.com/api/packages/Tooling/conan --force")
        sh("conan --version && cmake --version")
    }
    catch (exc) {
        echo 'Conan configured'
    }
    sh("rm -rf build")
    sh("git submodule update --recursive")
    sh("cmake -S . -B build  --preset Release -DWITH_TCC=OFF && cmake --build build -j16")
    fingerprint 'build/src/riscv-vp'
}

pipeline {
    agent none

    options { 
        // using the Timestamper plugin we can add timestamps to the console log
        timestamps() 
        skipStagesAfterUnstable() 
    }

    stages {
        stage('RISCV-VP pipeline') {
           parallel {
	            stage('ubuntu20'){
	                agent {docker { image 'ubuntu-20.04' } }
	                stages {
	                    stage('Checkout on Ubuntu20.04') { steps {    checkout_riscv_vp() }}
	                    stage('Build') { steps {    build_riscv_vp() }    }
	                }
	            }
	            stage('ubuntu22'){
	                agent {docker { image 'ubuntu-22.04' } }
	                stages {
	                    stage('Checkout on Ubuntu22.04') { steps {    checkout_riscv_vp() }}
	                    stage('Build') { steps {    build_riscv_vp() }    }
	                }
	            }
	            stage('CentOS7'){
	                agent {docker { image 'centos7' } }
	                stages {
	                    stage('Checkout on Ubuntu') { steps {checkout_riscv_vp()}}
	                    stage('Build') { steps {build_riscv_vp()}
	                    }
	                }
	            }
	            stage('RockyLinux8'){
	                agent {docker { image 'rockylinux8' } }
	                stages {
	                    stage('Checkout on Ubuntu') { steps {checkout_riscv_vp()}}
	                    stage('Build') { steps {build_riscv_vp()}
	                    }
	                }
	            }
         	}
        }
    }
    post {
        success {
            rocketSend ":thumbsup: RISCV-VP verification run passed, results at ${env.RUN_DISPLAY_URL} " 
        }
        failure {
            archiveArtifacts artifacts: 'failed_seeds_*.txt', followSymlinks: false, onlyIfSuccessful: false 
            rocketSend ":thumbsdown: RISCV-VP verification failed, please check ${env.RUN_DISPLAY_URL} " 
            emailext recipientProviders: [culprits(), requestor()],
                subject: "RISCV-VP Pipeline Failed: ${currentBuild.fullDisplayName}",
                body: """
                <p>Build Status: ${currentBuild.currentResult}</p>
                <p> Check logs at <a href='${env.BUILD_URL}console'> Build Console Logs </a> or at <a href='${env.RUN_DISPLAY_URL}'> Overview </a></p>
                """
        }
    }
}