2019-06-10 16:18:27 +07:00
|
|
|
##
|
|
|
|
# This module defines the interface for interacting with and loading a project
|
|
|
|
# with Ceedling.
|
|
|
|
module Ceedling
|
|
|
|
##
|
|
|
|
# Returns the location where the gem is installed.
|
|
|
|
# === Return
|
|
|
|
# _String_ - The location where the gem lives.
|
|
|
|
def self.location
|
|
|
|
File.join( File.dirname(__FILE__), '..')
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Return the path to the "built-in" plugins.
|
|
|
|
# === Return
|
|
|
|
# _String_ - The path where the default plugins live.
|
|
|
|
def self.load_path
|
|
|
|
File.join( self.location, 'plugins')
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Return the path to the Ceedling Rakefile
|
|
|
|
# === Return
|
|
|
|
# _String_
|
|
|
|
def self.rakefile
|
|
|
|
File.join( self.location, 'lib', 'ceedling', 'rakefile.rb' )
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# This method selects the project file that Ceedling will use by setting the
|
|
|
|
# CEEDLING_MAIN_PROJECT_FILE environment variable before loading the ceedling
|
|
|
|
# rakefile. A path supplied as an argument to this method will override the
|
|
|
|
# current value of the environment variable. If no path is supplied as an
|
|
|
|
# argument then the existing value of the environment variable is used. If
|
|
|
|
# the environment variable has not been set and no argument has been supplied
|
|
|
|
# then a default path of './project.yml' will be used.
|
|
|
|
#
|
|
|
|
# === Arguments
|
|
|
|
# +options+ _Hash_::
|
|
|
|
# A hash containing the options for ceedling. Currently the following
|
|
|
|
# options are supported:
|
|
|
|
# * +config+ - The path to the project YAML configuration file.
|
|
|
|
# * +root+ - The root of the project directory.
|
|
|
|
# * +prefix+ - A prefix to prepend to plugin names in order to determine the
|
|
|
|
# corresponding gem name.
|
|
|
|
# * +plugins+ - The list of ceedling plugins to load
|
|
|
|
def self.load_project(options = {})
|
|
|
|
# Make sure our path to the yaml file is setup
|
|
|
|
if options.has_key? :config
|
|
|
|
ENV['CEEDLING_MAIN_PROJECT_FILE'] = options[:config]
|
|
|
|
elsif ENV['CEEDLING_MAIN_PROJECT_FILE'].nil?
|
|
|
|
ENV['CEEDLING_MAIN_PROJECT_FILE'] = './project.yml'
|
|
|
|
end
|
|
|
|
|
|
|
|
# Register the plugins
|
|
|
|
if options.has_key? :plugins
|
|
|
|
options[:plugins].each do |plugin|
|
|
|
|
register_plugin( plugin, options[:prefix] )
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Define the root of the project if specified
|
|
|
|
Object.const_set('PROJECT_ROOT', options[:root]) if options.has_key? :root
|
|
|
|
|
|
|
|
# Load ceedling
|
|
|
|
load "#{self.rakefile}"
|
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Register a plugin for ceedling to use when a project is loaded. This method
|
|
|
|
# *must* be called prior to calling the _load_project_ method.
|
|
|
|
#
|
|
|
|
# This method is intended to be used for loading plugins distributed via the
|
|
|
|
# RubyGems mechanism. As such, the following gem structure is assumed for
|
|
|
|
# plugins.
|
|
|
|
#
|
|
|
|
# * The gem name must be prefixed with 'ceedling-' followed by the plugin
|
|
|
|
# name (ex. 'ceedling-bullseye')
|
|
|
|
#
|
2023-03-17 17:27:34 +07:00
|
|
|
# * The contents of the plugin must be installed into a subdirectory of
|
2019-06-10 16:18:27 +07:00
|
|
|
# the gem with the same name as the plugin (ex. 'bullseye/')
|
|
|
|
#
|
|
|
|
# === Arguments
|
|
|
|
# +name+ _String_:: The name of the plugin to load.
|
|
|
|
# +prefix+ _String_::
|
|
|
|
# (optional, default = nil) The prefix to use for the full gem name.
|
|
|
|
def self.register_plugin(name, prefix=nil)
|
|
|
|
# Figure out the full name of the gem and location
|
|
|
|
prefix ||= 'ceedling-'
|
|
|
|
gem_name = prefix + name
|
|
|
|
gem_dir = Gem::Specification.find_by_name(gem_name).gem_dir()
|
|
|
|
|
|
|
|
# Register the plugin with Ceedling
|
|
|
|
require 'ceedling/defaults'
|
|
|
|
DEFAULT_CEEDLING_CONFIG[:plugins][:enabled] << name
|
|
|
|
DEFAULT_CEEDLING_CONFIG[:plugins][:load_paths] << gem_dir
|
|
|
|
end
|
|
|
|
end
|