summaryrefslogtreecommitdiffstats
path: root/dom/xslt/xpath/txLiteralExpr.cpp
blob: 93ea2c8f1d9a70f91e52dec130824be01694e335 (plain)
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "txExpr.h"

nsresult txLiteralExpr::evaluate(txIEvalContext* aContext,
                                 txAExprResult** aResult) {
  NS_ENSURE_TRUE(mValue, NS_ERROR_OUT_OF_MEMORY);

  *aResult = mValue;
  NS_ADDREF(*aResult);

  return NS_OK;
}

static Expr::ResultType resultTypes[] = {
    Expr::NODESET_RESULT,  // NODESET
    Expr::BOOLEAN_RESULT,  // BOOLEAN
    Expr::NUMBER_RESULT,   // NUMBER
    Expr::STRING_RESULT,   // STRING
    Expr::RTF_RESULT       // RESULT_TREE_FRAGMENT
};

Expr::ResultType txLiteralExpr::getReturnType() {
  return resultTypes[mValue->getResultType()];
}

Expr* txLiteralExpr::getSubExprAt(uint32_t aPos) { return nullptr; }
void txLiteralExpr::setSubExprAt(uint32_t aPos, Expr* aExpr) {
  MOZ_ASSERT_UNREACHABLE("setting bad subexpression index");
}

bool txLiteralExpr::isSensitiveTo(ContextSensitivity aContext) { return false; }

#ifdef TX_TO_STRING
void txLiteralExpr::toString(nsAString& aStr) {
  switch (mValue->getResultType()) {
    case txAExprResult::NODESET: {
      aStr.AppendLiteral(" { Nodeset literal } ");
      return;
    }
    case txAExprResult::BOOLEAN: {
      if (mValue->booleanValue()) {
        aStr.AppendLiteral("true()");
      } else {
        aStr.AppendLiteral("false()");
      }
      return;
    }
    case txAExprResult::NUMBER: {
      txDouble::toString(mValue->numberValue(), aStr);
      return;
    }
    case txAExprResult::STRING: {
      StringResult* strRes =
          static_cast<StringResult*>(static_cast<txAExprResult*>(mValue));
      char16_t ch = '\'';
      if (strRes->mValue.Contains(ch)) {
        ch = '\"';
      }
      aStr.Append(ch);
      aStr.Append(strRes->mValue);
      aStr.Append(ch);
      return;
    }
    case txAExprResult::RESULT_TREE_FRAGMENT: {
      aStr.AppendLiteral(" { RTF literal } ");
      return;
    }
  }
}
#endif