xref: /aosp_15_r20/external/pdfium/fxjs/cjs_result.h (revision 3ac0a46f773bac49fa9476ec2b1cf3f8da5ec3a4)
1*3ac0a46fSAndroid Build Coastguard Worker // Copyright 2017 The PDFium Authors
2*3ac0a46fSAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*3ac0a46fSAndroid Build Coastguard Worker // found in the LICENSE file.
4*3ac0a46fSAndroid Build Coastguard Worker 
5*3ac0a46fSAndroid Build Coastguard Worker // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6*3ac0a46fSAndroid Build Coastguard Worker 
7*3ac0a46fSAndroid Build Coastguard Worker #ifndef FXJS_CJS_RESULT_H_
8*3ac0a46fSAndroid Build Coastguard Worker #define FXJS_CJS_RESULT_H_
9*3ac0a46fSAndroid Build Coastguard Worker 
10*3ac0a46fSAndroid Build Coastguard Worker #include "fxjs/js_resources.h"
11*3ac0a46fSAndroid Build Coastguard Worker #include "third_party/abseil-cpp/absl/types/optional.h"
12*3ac0a46fSAndroid Build Coastguard Worker #include "v8/include/v8-forward.h"
13*3ac0a46fSAndroid Build Coastguard Worker 
14*3ac0a46fSAndroid Build Coastguard Worker class CJS_Result {
15*3ac0a46fSAndroid Build Coastguard Worker  public:
16*3ac0a46fSAndroid Build Coastguard Worker   // Wrap constructors with static methods so we can apply [[nodiscard]],
17*3ac0a46fSAndroid Build Coastguard Worker   // otherwise we can't catch places where someone mistakenly writes:
18*3ac0a46fSAndroid Build Coastguard Worker   //
19*3ac0a46fSAndroid Build Coastguard Worker   //     if (error)
20*3ac0a46fSAndroid Build Coastguard Worker   //       CJS_Result(JS_ERROR_CODE);
21*3ac0a46fSAndroid Build Coastguard Worker   //
22*3ac0a46fSAndroid Build Coastguard Worker   // instead of
23*3ac0a46fSAndroid Build Coastguard Worker   //
24*3ac0a46fSAndroid Build Coastguard Worker   //     if (error)
25*3ac0a46fSAndroid Build Coastguard Worker   //       return CJS_Result(JS_ERROR_CODE);
26*3ac0a46fSAndroid Build Coastguard Worker   //
Success()27*3ac0a46fSAndroid Build Coastguard Worker   [[nodiscard]] static CJS_Result Success() { return CJS_Result(); }
Success(v8::Local<v8::Value> value)28*3ac0a46fSAndroid Build Coastguard Worker   [[nodiscard]] static CJS_Result Success(v8::Local<v8::Value> value) {
29*3ac0a46fSAndroid Build Coastguard Worker     return CJS_Result(value);
30*3ac0a46fSAndroid Build Coastguard Worker   }
Failure(const WideString & str)31*3ac0a46fSAndroid Build Coastguard Worker   [[nodiscard]] static CJS_Result Failure(const WideString& str) {
32*3ac0a46fSAndroid Build Coastguard Worker     return CJS_Result(str);
33*3ac0a46fSAndroid Build Coastguard Worker   }
Failure(JSMessage id)34*3ac0a46fSAndroid Build Coastguard Worker   [[nodiscard]] static CJS_Result Failure(JSMessage id) {
35*3ac0a46fSAndroid Build Coastguard Worker     return CJS_Result(id);
36*3ac0a46fSAndroid Build Coastguard Worker   }
37*3ac0a46fSAndroid Build Coastguard Worker 
38*3ac0a46fSAndroid Build Coastguard Worker   CJS_Result(const CJS_Result&);
39*3ac0a46fSAndroid Build Coastguard Worker   ~CJS_Result();
40*3ac0a46fSAndroid Build Coastguard Worker 
HasError()41*3ac0a46fSAndroid Build Coastguard Worker   bool HasError() const { return error_.has_value(); }
Error()42*3ac0a46fSAndroid Build Coastguard Worker   const WideString& Error() const { return error_.value(); }
43*3ac0a46fSAndroid Build Coastguard Worker 
HasReturn()44*3ac0a46fSAndroid Build Coastguard Worker   bool HasReturn() const { return !return_.IsEmpty(); }
Return()45*3ac0a46fSAndroid Build Coastguard Worker   v8::Local<v8::Value> Return() const { return return_; }
46*3ac0a46fSAndroid Build Coastguard Worker 
47*3ac0a46fSAndroid Build Coastguard Worker  private:
48*3ac0a46fSAndroid Build Coastguard Worker   CJS_Result();                               // Successful but empty return.
49*3ac0a46fSAndroid Build Coastguard Worker   explicit CJS_Result(v8::Local<v8::Value>);  // Successful return with value.
50*3ac0a46fSAndroid Build Coastguard Worker   explicit CJS_Result(const WideString&);     // Error with custom message.
51*3ac0a46fSAndroid Build Coastguard Worker   explicit CJS_Result(JSMessage id);          // Error with stock message.
52*3ac0a46fSAndroid Build Coastguard Worker 
53*3ac0a46fSAndroid Build Coastguard Worker   absl::optional<WideString> error_;
54*3ac0a46fSAndroid Build Coastguard Worker   v8::Local<v8::Value> return_;
55*3ac0a46fSAndroid Build Coastguard Worker };
56*3ac0a46fSAndroid Build Coastguard Worker 
57*3ac0a46fSAndroid Build Coastguard Worker #endif  // FXJS_CJS_RESULT_H_
58