1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 // MARKER(update_precomp.py): autogen include statement, do not remove 25 #include "precompiled_framework.hxx" 26 27 //________________________________ 28 // my own includes 29 30 #include <jobs/jobresult.hxx> 31 #include <jobs/jobconst.hxx> 32 #include <threadhelp/readguard.hxx> 33 #include <threadhelp/writeguard.hxx> 34 #include <general.h> 35 #include <services.h> 36 37 //________________________________ 38 // interface includes 39 40 //________________________________ 41 // includes of other projects 42 43 #include <rtl/ustrbuf.hxx> 44 #include <vcl/svapp.hxx> 45 #include <comphelper/sequenceashashmap.hxx> 46 47 //________________________________ 48 // namespace 49 50 namespace framework{ 51 52 //________________________________ 53 // non exported const 54 55 //________________________________ 56 // non exported definitions 57 58 //________________________________ 59 // declarations 60 61 //________________________________ 62 /** 63 @short standard dtor 64 @descr It does nothing else ... 65 but it marks this new instance as non valid! 66 */ 67 JobResult::JobResult() 68 : ThreadHelpBase(&Application::GetSolarMutex()) 69 { 70 // reset the flag mask! 71 // It will reset the accessible state of this object. 72 // That can be usefull if something will fail here ... 73 m_eParts = E_NOPART; 74 } 75 76 //________________________________ 77 /** 78 @short special ctor 79 @descr It initialize this new instance with a pure job execution result 80 and analyze it. Doing so, we update our other members. 81 82 <p> 83 It's a list of named values, packed inside this any. 84 Following protocol is used: 85 <p> 86 <ul> 87 <li> 88 "SaveArguments" [sequence< css.beans.NamedValue >] 89 <br> 90 The returned list of (for this generic implementation unknown!) 91 properties, will be written directly to the configuration and replace 92 any old values there. There will no check for changes and we doesn't 93 support any mege feature here. They are written only. The job has 94 to modify this list. 95 </li> 96 <li> 97 "SendDispatchResult" [css.frame.DispatchResultEvent] 98 <br> 99 The given event is send to all current registered listener. 100 But it's not guaranteed. In case no listener are available or 101 this job isn't part of the dispatch environment (because it was used 102 by the css..task.XJobExecutor->trigger() implementation) this option 103 will be ignored. 104 </li> 105 <li> 106 "Deactivate" [boolean] 107 <br> 108 The job whish to be disabled. But note: There is no way, to enable it later 109 again by using this implementation. It can be done by using the configuration 110 only. (Means to register this job again.) 111 If a job knows, that there exist some status or result listener, it must use 112 the options "SendDispatchStatus" and "SendDispatchResult" (see before) too, to 113 inform it about the deactivation of this service. 114 </li> 115 </ul> 116 117 @param aResult 118 the job result 119 */ 120 JobResult::JobResult( /*IN*/ const css::uno::Any& aResult ) 121 : ThreadHelpBase(&Application::GetSolarMutex()) 122 { 123 // safe the pure result 124 // May someone need it later ... 125 m_aPureResult = aResult; 126 127 // reset the flag mask! 128 // It will reset the accessible state of this object. 129 // That can be usefull if something will fail here ... 130 m_eParts = E_NOPART; 131 132 // analyze the result and update our other members 133 ::comphelper::SequenceAsHashMap aProtocol(aResult); 134 if ( aProtocol.empty() ) 135 return; 136 137 ::comphelper::SequenceAsHashMap::const_iterator pIt = aProtocol.end(); 138 139 pIt = aProtocol.find(JobConst::ANSWER_DEACTIVATE_JOB()); 140 if (pIt != aProtocol.end()) 141 { 142 pIt->second >>= m_bDeactivate; 143 if (m_bDeactivate) 144 m_eParts |= E_DEACTIVATE; 145 } 146 147 pIt = aProtocol.find(JobConst::ANSWER_SAVE_ARGUMENTS()); 148 if (pIt != aProtocol.end()) 149 { 150 pIt->second >>= m_lArguments; 151 if (m_lArguments.getLength() > 0) 152 m_eParts |= E_ARGUMENTS; 153 } 154 155 pIt = aProtocol.find(JobConst::ANSWER_SEND_DISPATCHRESULT()); 156 if (pIt != aProtocol.end()) 157 { 158 if (pIt->second >>= m_aDispatchResult) 159 m_eParts |= E_DISPATCHRESULT; 160 } 161 } 162 163 //________________________________ 164 /** 165 @short copy dtor 166 @descr - 167 */ 168 JobResult::JobResult( const JobResult& rCopy ) 169 : ThreadHelpBase(&Application::GetSolarMutex()) 170 { 171 m_aPureResult = rCopy.m_aPureResult ; 172 m_eParts = rCopy.m_eParts ; 173 m_lArguments = rCopy.m_lArguments ; 174 m_bDeactivate = rCopy.m_bDeactivate ; 175 m_aDispatchResult = rCopy.m_aDispatchResult ; 176 } 177 178 //________________________________ 179 /** 180 @short standard dtor 181 @descr Free all internaly used ressources at the end of living. 182 */ 183 JobResult::~JobResult() 184 { 185 // Nothing realy to do here. 186 } 187 188 //________________________________ 189 /** 190 @short =operator 191 @descr Must be implemented to overwrite this instance with another one. 192 193 @param rCopy 194 reference to the other instance, which should be used for copying. 195 */ 196 void JobResult::operator=( const JobResult& rCopy ) 197 { 198 /* SAFE { */ 199 WriteGuard aWriteLock(m_aLock); 200 m_aPureResult = rCopy.m_aPureResult ; 201 m_eParts = rCopy.m_eParts ; 202 m_lArguments = rCopy.m_lArguments ; 203 m_bDeactivate = rCopy.m_bDeactivate ; 204 m_aDispatchResult = rCopy.m_aDispatchResult ; 205 aWriteLock.unlock(); 206 /* } SAFE */ 207 } 208 209 //________________________________ 210 /** 211 @short checks for existing parts of the analyzed result 212 @descr The internal flag mask was set after analyzing of the pure result. 213 An user of us can check here, if the required part was realy part 214 of this result. Otherwhise it would use invalid informations ... 215 by using our other members! 216 217 @param eParts 218 a flag mask too, which will be compared with our internaly set one. 219 220 @return We return true only, if any set flag of the given mask match. 221 */ 222 sal_Bool JobResult::existPart( sal_uInt32 eParts ) const 223 { 224 /* SAFE { */ 225 ReadGuard aReadLock(m_aLock); 226 return ((m_eParts & eParts) == eParts); 227 /* } SAFE */ 228 } 229 230 //________________________________ 231 /** 232 @short provides access to our internal members 233 @descr The return value will be valid only in case a call of 234 existPart(E_...) before returned true! 235 236 @return It returns the state of the internal member 237 without any checks! 238 */ 239 css::uno::Sequence< css::beans::NamedValue > JobResult::getArguments() const 240 { 241 /* SAFE { */ 242 ReadGuard aReadLock(m_aLock); 243 return m_lArguments; 244 /* } SAFE */ 245 } 246 247 //________________________________ 248 249 css::frame::DispatchResultEvent JobResult::getDispatchResult() const 250 { 251 /* SAFE { */ 252 ReadGuard aReadLock(m_aLock); 253 return m_aDispatchResult; 254 /* } SAFE */ 255 } 256 257 } // namespace framework 258