a2317522ebcc0064dc1814635641f8c5231d4782
[profile/ivi/qtxmlpatterns.git] / src / xmlpatterns / functions / qerrorfn.cpp
1 /****************************************************************************
2 **
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/
5 **
6 ** This file is part of the QtXmlPatterns module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** GNU Lesser General Public License Usage
10 ** This file may be used under the terms of the GNU Lesser General Public
11 ** License version 2.1 as published by the Free Software Foundation and
12 ** appearing in the file LICENSE.LGPL included in the packaging of this
13 ** file. Please review the following information to ensure the GNU Lesser
14 ** General Public License version 2.1 requirements will be met:
15 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
16 **
17 ** In addition, as a special exception, Nokia gives you certain additional
18 ** rights. These rights are described in the Nokia Qt LGPL Exception
19 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
20 **
21 ** GNU General Public License Usage
22 ** Alternatively, this file may be used under the terms of the GNU General
23 ** Public License version 3.0 as published by the Free Software Foundation
24 ** and appearing in the file LICENSE.GPL included in the packaging of this
25 ** file. Please review the following information to ensure the GNU General
26 ** Public License version 3.0 requirements will be met:
27 ** http://www.gnu.org/copyleft/gpl.html.
28 **
29 ** Other Usage
30 ** Alternatively, this file may be used in accordance with the terms and
31 ** conditions contained in a signed written agreement between you and Nokia.
32 **
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #include "qcommonsequencetypes_p.h"
43 #include "qpatternistlocale_p.h"
44 #include "qqnamevalue_p.h"
45 #include "qatomicstring_p.h"
46
47 #include "qerrorfn_p.h"
48
49 QT_BEGIN_NAMESPACE
50
51 using namespace QPatternist;
52
53 Item ErrorFN::evaluateSingleton(const DynamicContext::Ptr &context) const
54 {
55     QString msg;
56
57     switch(m_operands.count())
58     {
59         case 0: /* No args. */
60         {
61             context->error(QtXmlPatterns::tr("%1 was called.").arg(formatFunction(context->namePool(), signature())),
62                             ReportContext::FOER0000, this);
63             return Item();
64         }
65         case 3:
66         /* Fallthrough, we don't use the 'error object' param. */
67         case 2:
68             msg = m_operands.at(1)->evaluateSingleton(context).stringValue();
69         /* Fall through. */
70         case 1:
71         {
72             const QNameValue::Ptr qName(m_operands.first()->evaluateSingleton(context).as<QNameValue>());
73
74             if(qName)
75                 context->error(msg, qName->qName(), this);
76             else
77                 context->error(msg, ReportContext::FOER0000, this);
78
79             return Item();
80         }
81         default:
82         {
83             Q_ASSERT_X(false, Q_FUNC_INFO,
84                        "Invalid number of arguments passed to fn:error.");
85             return Item();
86         }
87     }
88 }
89
90 FunctionSignature::Ptr ErrorFN::signature() const
91 {
92     const FunctionSignature::Ptr e(FunctionCall::signature());
93
94     if(m_operands.count() != 1)
95         return e;
96
97     FunctionSignature::Ptr nev(FunctionSignature::Ptr(new FunctionSignature(e->name(),
98                                                       e->minimumArguments(),
99                                                       e->maximumArguments(),
100                                                       e->returnType(),
101                                                       e->properties())));
102     const FunctionArgument::List args(e->arguments());
103     FunctionArgument::List nargs;
104     const QXmlName argName(StandardNamespaces::empty, StandardLocalNames::error);
105     nargs.append(FunctionArgument::Ptr(new FunctionArgument(argName, CommonSequenceTypes::ExactlyOneQName)));
106     nargs.append(args[1]);
107     nargs.append(args[2]);
108     nev->setArguments(nargs);
109
110     return nev;
111 }
112
113 QT_END_NAMESPACE