# ********************************************************************************* # URBANopt, Copyright (c) 2019-2020, Alliance for Sustainable Energy, LLC, and other # contributors. All rights reserved. # # Redistribution and use in source and binary forms, with or without modification, # are permitted provided that the following conditions are met: # # Redistributions of source code must retain the above copyright notice, this list # of conditions and the following disclaimer. # # Redistributions in binary form must reproduce the above copyright notice, this # list of conditions and the following disclaimer in the documentation and/or other # materials provided with the distribution. # # Neither the name of the copyright holder nor the names of its contributors may be # used to endorse or promote products derived from this software without specific # prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. # IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, # INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF # LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE # OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED # OF THE POSSIBILITY OF SUCH DAMAGE. # ********************************************************************************* require 'urbanopt/reporting/version' require 'openstudio/extension' module URBANopt module Reporting class Extension < OpenStudio::Extension::Extension def initialize # :nodoc: @root_dir = File.absolute_path(File.join(File.dirname(__FILE__), '..', '..', '..')) end ## # Returns the absolute path of the measures or returns nil, in case no measures are # added. It can be used while configuring OSWs. def measures_dir return File.absolute_path(File.join(@root_dir, 'lib/measures')) end ## # The directory containign relevant files such as weather data, design days, etc. # The method returns nil if no files are present. It is used while configuring OSWs. def files_dir return nil end # The directory containing common files like copyright and license notices which are used to update measures and other code. # This method will only be applied to measures in the current repository and # returns the absolute path of the +doc_templates_dir+ or nil if there is none. def doc_templates_dir return File.absolute_path(File.join(@root_dir, 'doc_templates')) end end end end