openstudio-workflow 1.3.3 → 1.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +77 -72
- data/README.md +93 -93
- data/Rakefile +36 -36
- data/lib/openstudio-workflow.rb +65 -49
- data/lib/openstudio/workflow/adapters/input/local.rb +324 -301
- data/lib/openstudio/workflow/adapters/output/local.rb +161 -97
- data/lib/openstudio/workflow/adapters/output/socket.rb +107 -91
- data/lib/openstudio/workflow/adapters/output/web.rb +82 -66
- data/lib/openstudio/workflow/adapters/output_adapter.rb +163 -147
- data/lib/openstudio/workflow/job.rb +57 -22
- data/lib/openstudio/workflow/jobs/resources/monthly_report.idf +222 -222
- data/lib/openstudio/workflow/jobs/run_energyplus.rb +70 -54
- data/lib/openstudio/workflow/jobs/run_ep_measures.rb +73 -57
- data/lib/openstudio/workflow/jobs/run_initialization.rb +203 -171
- data/lib/openstudio/workflow/jobs/run_os_measures.rb +89 -73
- data/lib/openstudio/workflow/jobs/run_postprocess.rb +73 -57
- data/lib/openstudio/workflow/jobs/run_preprocess.rb +104 -80
- data/lib/openstudio/workflow/jobs/run_reporting_measures.rb +118 -102
- data/lib/openstudio/workflow/jobs/run_translation.rb +84 -68
- data/lib/openstudio/workflow/multi_delegator.rb +62 -46
- data/lib/openstudio/workflow/registry.rb +172 -137
- data/lib/openstudio/workflow/run.rb +328 -312
- data/lib/openstudio/workflow/time_logger.rb +96 -53
- data/lib/openstudio/workflow/util.rb +49 -14
- data/lib/openstudio/workflow/util/energyplus.rb +605 -570
- data/lib/openstudio/workflow/util/io.rb +68 -33
- data/lib/openstudio/workflow/util/measure.rb +650 -615
- data/lib/openstudio/workflow/util/model.rb +151 -100
- data/lib/openstudio/workflow/util/post_process.rb +238 -187
- data/lib/openstudio/workflow/util/weather_file.rb +143 -108
- data/lib/openstudio/workflow/version.rb +40 -24
- data/lib/openstudio/workflow_json.rb +476 -443
- data/lib/openstudio/workflow_runner.rb +268 -252
- metadata +23 -23
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bd5e1d2530fa9c784c895a46aa301e0dd2ff8ed3
|
4
|
+
data.tar.gz: d969e8477b3f95eb62fcf00d1f610e18564f7cf6
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 37a2892034e72bd02e8fcb298138eeb80eb5084a52bc3c5afbd369de65d3e3af561d0d1253676ddb1e0499e4643e9023c45e7fa28725f492cdad46c0cb64b9df
|
7
|
+
data.tar.gz: 5ca11c5f3ab37a66293fc2b5039e124ae4ad6fe1a7ac3867b75afaa0cbf363bd4406814852c99a057d19064e85f757e8aef81e9288de3c8399965b1547e2c319
|
data/CHANGELOG.md
CHANGED
@@ -1,72 +1,77 @@
|
|
1
|
-
OpenStudio::Workflow Change Log
|
2
|
-
==================================
|
3
|
-
|
4
|
-
Version
|
5
|
-
|
6
|
-
*
|
7
|
-
*
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
*
|
13
|
-
* Remove
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
*
|
19
|
-
* Update
|
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
|
-
*
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
*
|
55
|
-
*
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
*
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
*
|
1
|
+
OpenStudio::Workflow Change Log
|
2
|
+
==================================
|
3
|
+
|
4
|
+
Version 1.3.4 (Unreleased)
|
5
|
+
--------------------------
|
6
|
+
* Remove support for Ruby 2.0
|
7
|
+
* Update license
|
8
|
+
|
9
|
+
Version '1.0.0-rc1'
|
10
|
+
-------------------
|
11
|
+
* Use specific version of OpenStudio Analysis Gem
|
12
|
+
* Fix tests
|
13
|
+
* Remove to_underscore method (use OpenStudio.toUnderscoreCase(...) if needed)
|
14
|
+
|
15
|
+
Version '1.0.0-alpha.0'
|
16
|
+
-----------------------
|
17
|
+
* Support new workflow for PAT 2.0. Many of these changes are breaking changes
|
18
|
+
* Remove rake from gemspec
|
19
|
+
* Update rubyzip to version 1.2
|
20
|
+
|
21
|
+
Version 0.2.0
|
22
|
+
------------------
|
23
|
+
* Use EnergyPlus that is packaged with OpenStudio. The branch of this repo is no longer tied to the version of EnergyPlus
|
24
|
+
* Update find_energyplus to use new OpenStudio method instead of RUBYLIB env var
|
25
|
+
* Update dependencies
|
26
|
+
* Support tests running on Docker
|
27
|
+
* Skip the PAT tests for now since they are broken
|
28
|
+
* Remove snake_case method as it conflicts with another libraries method, now called to_underscore
|
29
|
+
* Add test for persisting JSONs as reports. Rename reports in the form of <measure_name_underscored>_<report_name>.<ext>
|
30
|
+
* Always add in Monthly Reports (Deprecate the :run_monthly_reports option)
|
31
|
+
* Remove the old Standard Reports and use the version in the OpenStudio Release (along with the calibration report)
|
32
|
+
|
33
|
+
Version 0.1.1
|
34
|
+
------------------
|
35
|
+
* Catch exception when loading a measure file.
|
36
|
+
* Enable running simulations on windows and mac
|
37
|
+
* Use rubyzip gem instead of system call
|
38
|
+
* Fix the double directory which caused the zip files to behave strangely on windows
|
39
|
+
* New find_energyplus method which tries to use OpenStudio's version of EnergyPlus
|
40
|
+
* Copy all EnergyPlus files into run directory
|
41
|
+
* Better cleanup after EnergyPlus simulation
|
42
|
+
* Read machine information from /etc/openstudio-server directory, if available
|
43
|
+
|
44
|
+
Version 0.1.0
|
45
|
+
-------------
|
46
|
+
* Tests for programmatically creating the analysis.json files from the OpenStudio-analysis-gem
|
47
|
+
* Upgrade to EnergyPlus 8.2. Right now the run energyplus and run runmanager job hard code these paths.
|
48
|
+
* Upgrade and fix Facter facts to grab the correct ip address when running on EC2
|
49
|
+
|
50
|
+
Version 0.0.4
|
51
|
+
-------------
|
52
|
+
* Include rubyXL gem for reading/writing MS Excel files
|
53
|
+
* Remove invalid characters from OpenStudio Measure Attributes. /[|!@#\$%^&\*\(\)\{\}\\\[\]|;:'",<.>\/?\+=]+/
|
54
|
+
* Fix objective functions to read from any of the results hash, not just the standard report legacy
|
55
|
+
* Add time logger and reporting measure
|
56
|
+
|
57
|
+
Version 0.0.3
|
58
|
+
--------------
|
59
|
+
* Allow measures to set weather file in a measure and have it update what EnergyPlus uses for the weather file.
|
60
|
+
* OpenStudio::Workflow.run_energyplus method added to just run energyplus.
|
61
|
+
* Remove AASM (act as state machine) and replace with simple tracking of the state. Interface is the same except there is now no need to pass in the States.
|
62
|
+
* Catch EnergyPlus errors (non-zero exits), Fatal Errors in eplusout.err, and invalid weather files.
|
63
|
+
* Force UTF-8 version upon reading the eplusout.err file
|
64
|
+
|
65
|
+
Version 0.0.2
|
66
|
+
--------------
|
67
|
+
|
68
|
+
* Support reporting measures
|
69
|
+
* Reduce logging messages
|
70
|
+
* Keep IDF files
|
71
|
+
* Remove mtr and eso files after simulation completes
|
72
|
+
* If measure changes weather file, then use the new weather file with the analysis.json weather path
|
73
|
+
|
74
|
+
Version 0.0.1
|
75
|
+
--------------
|
76
|
+
|
77
|
+
* Initial release with basic workflow implemented to support running OpenStudio measure-based workflows
|
data/README.md
CHANGED
@@ -1,93 +1,93 @@
|
|
1
|
-
# OpenStudio::Workflow
|
2
|
-
|
3
|
-
[](https://circleci.com/gh/NREL/OpenStudio-workflow-gem/tree/develop)
|
4
|
-
[](https://coveralls.io/github/NREL/OpenStudio-workflow-gem?branch=develop)
|
5
|
-
[](https://www.versioneye.com/user/projects/5531fb7b10e714121100102e)
|
6
|
-
|
7
|
-
## OpenStudio Workflow Gem
|
8
|
-
|
9
|
-
This branch is the development branch for the OpenStudio workflow gem.
|
10
|
-
## Installation
|
11
|
-
|
12
|
-
The OpenStudio Workflow Gem has the following dependencies:
|
13
|
-
|
14
|
-
* Ruby 2.0
|
15
|
-
* OpenStudio with Ruby 2.0 bindings
|
16
|
-
* EnergyPlus 8.3 (assuming OpenStudio >= 1.7.2)
|
17
|
-
* MongoDB if using MongoDB Adapter (or when running rspec)
|
18
|
-
|
19
|
-
[OpenStudio](http://developer.nrel.gov/downloads/buildings/openstudio/builds/) needs to be installed
|
20
|
-
and in your path. On Mac/Linux it is easiest to add the following to your .bash_profile or /etc/profile.d/<file>.sh to ensure OpenStudio can be loaded.
|
21
|
-
|
22
|
-
export OPENSTUDIO_ROOT=/usr/local
|
23
|
-
export RUBYLIB=$OPENSTUDIO_ROOT/lib/ruby/site_ruby/2.0.0
|
24
|
-
|
25
|
-
Add this line to your application's Gemfile:
|
26
|
-
|
27
|
-
gem 'OpenStudio-workflow'
|
28
|
-
|
29
|
-
And then execute:
|
30
|
-
|
31
|
-
Mac/Linux:
|
32
|
-
|
33
|
-
$ bundle
|
34
|
-
|
35
|
-
Windows (avoids native extensions):
|
36
|
-
|
37
|
-
$ bundle install --without xml profile
|
38
|
-
|
39
|
-
Or install it yourself as:
|
40
|
-
|
41
|
-
$ gem install OpenStudio-workflow
|
42
|
-
|
43
|
-
## Usage
|
44
|
-
|
45
|
-
Note that the branches of the Workflow Gem depict which version of EnergyPlus is in use. The develop branch at the
|
46
|
-
moment should not be used.
|
47
|
-
|
48
|
-
There are currently two adapters to run OpenStudio workflow. The first is a simple Local adapter
|
49
|
-
allowing the user to pass in the directory to simulation. The directory must have an
|
50
|
-
[analysis/problem JSON file](spec/files/local_ex1/analysis_1.json) and a [datapoint JSON file](spec/files/local_ex1/datapoint_1.json).
|
51
|
-
The workflow manager will use these data (and the measures, seed model, and weather data) to assemble and
|
52
|
-
execute the standard workflow of (preflight->openstudio measures->energyplus->postprocess).
|
53
|
-
|
54
|
-
r = OpenStudio::Workflow.load 'Local', '/home/user/a_directory', options
|
55
|
-
r.run
|
56
|
-
|
57
|
-
The workflow manager can also use MongoDB to receive instructions on the workflow to run and the data point values.
|
58
|
-
|
59
|
-
## Caveats and Todos
|
60
|
-
|
61
|
-
### Todos
|
62
|
-
|
63
|
-
* Add a test to ensure that the models being returned contain alterations after apply_measure
|
64
|
-
* Add unit tests for each util method
|
65
|
-
* Define and document the complete set of options for the adapter and run classes
|
66
|
-
* Implement better error handling with custom exception classes
|
67
|
-
|
68
|
-
## Testing
|
69
|
-
|
70
|
-
The preferred way for testing is to run rspec either natively or via docker.
|
71
|
-
|
72
|
-
### Locally
|
73
|
-
|
74
|
-
```
|
75
|
-
rspec spec/
|
76
|
-
```
|
77
|
-
|
78
|
-
### Docker
|
79
|
-
|
80
|
-
```
|
81
|
-
export OPENSTUDIO_VERSION=1.13.0
|
82
|
-
docker run -v $(pwd):/var/simdata/openstudio \
|
83
|
-
nrel/openstudio:$OPENSTUDIO_VERSION \
|
84
|
-
/var/simdata/openstudio/test/bin/docker-run.sh
|
85
|
-
```
|
86
|
-
|
87
|
-
## Contributing
|
88
|
-
|
89
|
-
1. Fork it ( https://github.com/NREL/OpenStudio-workflow/fork )
|
90
|
-
2. Create your feature branch (`git checkout -b my-new-feature`)
|
91
|
-
3. Commit your changes (`git commit -am 'Add some feature'`)
|
92
|
-
4. Push to the branch (`git push origin my-new-feature`)
|
93
|
-
5. Create a new Pull Request
|
1
|
+
# OpenStudio::Workflow
|
2
|
+
|
3
|
+
[](https://circleci.com/gh/NREL/OpenStudio-workflow-gem/tree/develop)
|
4
|
+
[](https://coveralls.io/github/NREL/OpenStudio-workflow-gem?branch=develop)
|
5
|
+
[](https://www.versioneye.com/user/projects/5531fb7b10e714121100102e)
|
6
|
+
|
7
|
+
## OpenStudio Workflow Gem
|
8
|
+
|
9
|
+
This branch is the development branch for the OpenStudio workflow gem.
|
10
|
+
## Installation
|
11
|
+
|
12
|
+
The OpenStudio Workflow Gem has the following dependencies:
|
13
|
+
|
14
|
+
* Ruby 2.0
|
15
|
+
* OpenStudio with Ruby 2.0 bindings
|
16
|
+
* EnergyPlus 8.3 (assuming OpenStudio >= 1.7.2)
|
17
|
+
* MongoDB if using MongoDB Adapter (or when running rspec)
|
18
|
+
|
19
|
+
[OpenStudio](http://developer.nrel.gov/downloads/buildings/openstudio/builds/) needs to be installed
|
20
|
+
and in your path. On Mac/Linux it is easiest to add the following to your .bash_profile or /etc/profile.d/<file>.sh to ensure OpenStudio can be loaded.
|
21
|
+
|
22
|
+
export OPENSTUDIO_ROOT=/usr/local
|
23
|
+
export RUBYLIB=$OPENSTUDIO_ROOT/lib/ruby/site_ruby/2.0.0
|
24
|
+
|
25
|
+
Add this line to your application's Gemfile:
|
26
|
+
|
27
|
+
gem 'OpenStudio-workflow'
|
28
|
+
|
29
|
+
And then execute:
|
30
|
+
|
31
|
+
Mac/Linux:
|
32
|
+
|
33
|
+
$ bundle
|
34
|
+
|
35
|
+
Windows (avoids native extensions):
|
36
|
+
|
37
|
+
$ bundle install --without xml profile
|
38
|
+
|
39
|
+
Or install it yourself as:
|
40
|
+
|
41
|
+
$ gem install OpenStudio-workflow
|
42
|
+
|
43
|
+
## Usage
|
44
|
+
|
45
|
+
Note that the branches of the Workflow Gem depict which version of EnergyPlus is in use. The develop branch at the
|
46
|
+
moment should not be used.
|
47
|
+
|
48
|
+
There are currently two adapters to run OpenStudio workflow. The first is a simple Local adapter
|
49
|
+
allowing the user to pass in the directory to simulation. The directory must have an
|
50
|
+
[analysis/problem JSON file](spec/files/local_ex1/analysis_1.json) and a [datapoint JSON file](spec/files/local_ex1/datapoint_1.json).
|
51
|
+
The workflow manager will use these data (and the measures, seed model, and weather data) to assemble and
|
52
|
+
execute the standard workflow of (preflight->openstudio measures->energyplus->postprocess).
|
53
|
+
|
54
|
+
r = OpenStudio::Workflow.load 'Local', '/home/user/a_directory', options
|
55
|
+
r.run
|
56
|
+
|
57
|
+
The workflow manager can also use MongoDB to receive instructions on the workflow to run and the data point values.
|
58
|
+
|
59
|
+
## Caveats and Todos
|
60
|
+
|
61
|
+
### Todos
|
62
|
+
|
63
|
+
* Add a test to ensure that the models being returned contain alterations after apply_measure
|
64
|
+
* Add unit tests for each util method
|
65
|
+
* Define and document the complete set of options for the adapter and run classes
|
66
|
+
* Implement better error handling with custom exception classes
|
67
|
+
|
68
|
+
## Testing
|
69
|
+
|
70
|
+
The preferred way for testing is to run rspec either natively or via docker.
|
71
|
+
|
72
|
+
### Locally
|
73
|
+
|
74
|
+
```
|
75
|
+
rspec spec/
|
76
|
+
```
|
77
|
+
|
78
|
+
### Docker
|
79
|
+
|
80
|
+
```
|
81
|
+
export OPENSTUDIO_VERSION=1.13.0
|
82
|
+
docker run -v $(pwd):/var/simdata/openstudio \
|
83
|
+
nrel/openstudio:$OPENSTUDIO_VERSION \
|
84
|
+
/var/simdata/openstudio/test/bin/docker-run.sh
|
85
|
+
```
|
86
|
+
|
87
|
+
## Contributing
|
88
|
+
|
89
|
+
1. Fork it ( https://github.com/NREL/OpenStudio-workflow/fork )
|
90
|
+
2. Create your feature branch (`git checkout -b my-new-feature`)
|
91
|
+
3. Commit your changes (`git commit -am 'Add some feature'`)
|
92
|
+
4. Push to the branch (`git push origin my-new-feature`)
|
93
|
+
5. Create a new Pull Request
|
data/Rakefile
CHANGED
@@ -1,36 +1,36 @@
|
|
1
|
-
require 'bundler'
|
2
|
-
Bundler.setup
|
3
|
-
|
4
|
-
require 'rspec/core/rake_task'
|
5
|
-
|
6
|
-
# Always create spec reports
|
7
|
-
require 'ci/reporter/rake/rspec'
|
8
|
-
|
9
|
-
# Gem tasks
|
10
|
-
require 'bundler/gem_tasks'
|
11
|
-
|
12
|
-
RSpec::Core::RakeTask.new('spec:unit') do |spec|
|
13
|
-
spec.rspec_opts = %w(--format progress --format CI::Reporter::RSpec)
|
14
|
-
spec.pattern = FileList['spec/**/*_spec.rb']
|
15
|
-
end
|
16
|
-
|
17
|
-
task 'spec:unit' => 'ci:setup:rspec'
|
18
|
-
task default: 'spec:unit'
|
19
|
-
|
20
|
-
require 'rubocop/rake_task'
|
21
|
-
desc 'Run RuboCop on the lib directory'
|
22
|
-
RuboCop::RakeTask.new(:rubocop) do |task|
|
23
|
-
task.options = ['--no-color', '--out=rubocop-results.xml']
|
24
|
-
task.formatters = ['RuboCop::Formatter::CheckstyleFormatter']
|
25
|
-
task.requires = ['rubocop/formatter/checkstyle_formatter']
|
26
|
-
# don't abort rake on failure
|
27
|
-
task.fail_on_error = false
|
28
|
-
end
|
29
|
-
|
30
|
-
require 'openstudio-workflow'
|
31
|
-
desc 'test extracting zip'
|
32
|
-
task :test_zip do
|
33
|
-
f = File.join(File.dirname(__FILE__), 'spec/files/example_models/the_project.zip')
|
34
|
-
puts "Trying to extract #{f}"
|
35
|
-
OpenStudio::Workflow.extract_archive(f, 'junk_out', true)
|
36
|
-
end
|
1
|
+
require 'bundler'
|
2
|
+
Bundler.setup
|
3
|
+
|
4
|
+
require 'rspec/core/rake_task'
|
5
|
+
|
6
|
+
# Always create spec reports
|
7
|
+
require 'ci/reporter/rake/rspec'
|
8
|
+
|
9
|
+
# Gem tasks
|
10
|
+
require 'bundler/gem_tasks'
|
11
|
+
|
12
|
+
RSpec::Core::RakeTask.new('spec:unit') do |spec|
|
13
|
+
spec.rspec_opts = %w(--format progress --format CI::Reporter::RSpec)
|
14
|
+
spec.pattern = FileList['spec/**/*_spec.rb']
|
15
|
+
end
|
16
|
+
|
17
|
+
task 'spec:unit' => 'ci:setup:rspec'
|
18
|
+
task default: 'spec:unit'
|
19
|
+
|
20
|
+
require 'rubocop/rake_task'
|
21
|
+
desc 'Run RuboCop on the lib directory'
|
22
|
+
RuboCop::RakeTask.new(:rubocop) do |task|
|
23
|
+
task.options = ['--no-color', '--out=rubocop-results.xml']
|
24
|
+
task.formatters = ['RuboCop::Formatter::CheckstyleFormatter']
|
25
|
+
task.requires = ['rubocop/formatter/checkstyle_formatter']
|
26
|
+
# don't abort rake on failure
|
27
|
+
task.fail_on_error = false
|
28
|
+
end
|
29
|
+
|
30
|
+
require 'openstudio-workflow'
|
31
|
+
desc 'test extracting zip'
|
32
|
+
task :test_zip do
|
33
|
+
f = File.join(File.dirname(__FILE__), 'spec/files/example_models/the_project.zip')
|
34
|
+
puts "Trying to extract #{f}"
|
35
|
+
OpenStudio::Workflow.extract_archive(f, 'junk_out', true)
|
36
|
+
end
|
data/lib/openstudio-workflow.rb
CHANGED
@@ -1,49 +1,65 @@
|
|
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
|
-
|
49
|
-
|
1
|
+
# *******************************************************************************
|
2
|
+
# OpenStudio(R), Copyright (c) 2008-2018, Alliance for Sustainable Energy, LLC.
|
3
|
+
# All rights reserved.
|
4
|
+
# Redistribution and use in source and binary forms, with or without
|
5
|
+
# modification, are permitted provided that the following conditions are met:
|
6
|
+
#
|
7
|
+
# (1) Redistributions of source code must retain the above copyright notice,
|
8
|
+
# this list of conditions and the following disclaimer.
|
9
|
+
#
|
10
|
+
# (2) Redistributions in binary form must reproduce the above copyright notice,
|
11
|
+
# this list of conditions and the following disclaimer in the documentation
|
12
|
+
# and/or other materials provided with the distribution.
|
13
|
+
#
|
14
|
+
# (3) Neither the name of the copyright holder nor the names of any contributors
|
15
|
+
# may be used to endorse or promote products derived from this software without
|
16
|
+
# specific prior written permission from the respective party.
|
17
|
+
#
|
18
|
+
# (4) Other than as required in clauses (1) and (2), distributions in any form
|
19
|
+
# of modifications or other derivative works may not use the "OpenStudio"
|
20
|
+
# trademark, "OS", "os", or any other confusingly similar designation without
|
21
|
+
# specific prior written permission from Alliance for Sustainable Energy, LLC.
|
22
|
+
#
|
23
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
24
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
25
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
26
|
+
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER, THE UNITED STATES
|
27
|
+
# GOVERNMENT, OR ANY CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
28
|
+
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
29
|
+
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
30
|
+
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
31
|
+
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
32
|
+
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
33
|
+
# EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
34
|
+
# *******************************************************************************
|
35
|
+
|
36
|
+
require 'fileutils'
|
37
|
+
require 'json'
|
38
|
+
require 'pathname'
|
39
|
+
|
40
|
+
require_relative 'openstudio/workflow/version'
|
41
|
+
require_relative 'openstudio/workflow/multi_delegator'
|
42
|
+
require_relative 'openstudio/workflow/run'
|
43
|
+
require_relative 'openstudio/workflow/job'
|
44
|
+
require_relative 'openstudio/workflow/time_logger'
|
45
|
+
require_relative 'openstudio/workflow/registry'
|
46
|
+
require_relative 'openstudio/workflow/util'
|
47
|
+
require 'openstudio'
|
48
|
+
require_relative 'openstudio/workflow_runner'
|
49
|
+
|
50
|
+
module OpenStudio
|
51
|
+
module Workflow
|
52
|
+
extend self
|
53
|
+
|
54
|
+
# Extract an archive to a specific location
|
55
|
+
#
|
56
|
+
# @param archive_filename [String] Path and name of the file to extract
|
57
|
+
# @param destination [String] Path to extract to
|
58
|
+
# @param overwrite [Boolean] If true, will overwrite any extracted file that may already exist
|
59
|
+
#
|
60
|
+
def extract_archive(archive_filename, destination, overwrite = true)
|
61
|
+
zf = OpenStudio::UnzipFile.new(archive_filename)
|
62
|
+
zf.extractAllFiles(destination)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|