diff options
author | Jason Sams <rjsams@android.com> | 2011-11-22 12:49:11 -0800 |
---|---|---|
committer | Jason Sams <rjsams@android.com> | 2011-11-22 13:17:18 -0800 |
commit | dd39fdfe99a08b0bbb03eba8f32cad4018271def (patch) | |
tree | 01ae28f76d5edc975ad53b881de6fd73d392af5b /libs/rs/rsScriptC.cpp | |
parent | ec99c62e8b7c223c86a89008219be6c78f14eab8 (diff) |
Fix script init error handling.
Change-Id: I7ceb0af4dfd12db0274985ff658f678d7af829ff
Diffstat (limited to 'libs/rs/rsScriptC.cpp')
-rw-r--r-- | libs/rs/rsScriptC.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/libs/rs/rsScriptC.cpp b/libs/rs/rsScriptC.cpp index b45366beb109..a5b1902765bc 100644 --- a/libs/rs/rsScriptC.cpp +++ b/libs/rs/rsScriptC.cpp @@ -44,8 +44,10 @@ ScriptC::~ScriptC() { BT = NULL; } #endif - mRSC->mHal.funcs.script.invokeFreeChildren(mRSC, this); - mRSC->mHal.funcs.script.destroy(mRSC, this); + if (mInitialized) { + mRSC->mHal.funcs.script.invokeFreeChildren(mRSC, this); + mRSC->mHal.funcs.script.destroy(mRSC, this); + } } void ScriptC::setupScript(Context *rsc) { @@ -212,8 +214,11 @@ bool ScriptC::runCompiler(Context *rsc, bitcodeLen = BT->getTranslatedBitcodeSize(); #endif - rsc->mHal.funcs.script.init(rsc, this, resName, cacheDir, bitcode, bitcodeLen, 0); + if (!rsc->mHal.funcs.script.init(rsc, this, resName, cacheDir, bitcode, bitcodeLen, 0)) { + return false; + } + mInitialized = true; mEnviroment.mFragment.set(rsc->getDefaultProgramFragment()); mEnviroment.mVertex.set(rsc->getDefaultProgramVertex()); mEnviroment.mFragmentStore.set(rsc->getDefaultProgramStore()); |