(file) Return to FQLParser.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / FQL

File: [Pegasus] / pegasus / src / Pegasus / FQL / FQLParser.cpp (download)
Revision: 1.1, Mon Nov 10 21:41:04 2014 UTC (9 years, 7 months ago) by karl
Branch: MAIN
CVS Tags: RELEASE_2_14_1, RELEASE_2_14_0-RC2, RELEASE_2_14_0-RC1, RELEASE_2_14_0, RELEASE_2_14-root, RELEASE_2_14-branch, HEAD
BUG#: 9928

TITLE: Initial FQL implementation per DMTF specification DSP0212

DESCRIPTION: Commit of initial FQL (Filter Query Language)
implementation including 1) FQL parser and evaluator, 2 FQL integration
into CIMOperationRequestDispatcher.cpp, 3)FQL unit and end-end tests
in FQL/tests/Parser and FQL/tests/clitest and FQL tests added to
cimcli tests in src/Clients/cimcli/tests/Makefile

//%LICENSE////////////////////////////////////////////////////////////////
//
// Licensed to The Open Group (TOG) under one or more contributor license
// agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
// this work for additional information regarding copyright ownership.
// Each contributor licenses this file to you under the OpenPegasus Open
// Source License; you may not use this file except in compliance with the
// License.
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
//////////////////////////////////////////////////////////////////////////
//
//%/////////////////////////////////////////////////////////////////////////////

#include <Pegasus/Common/Config.h>
#include <Pegasus/Common/InternalException.h>
#include <Pegasus/Common/Tracer.h>
#include <Pegasus/Common/PegasusVersion.h>
#include <Pegasus/Common/Mutex.h>
#include <iostream>
#include "FQLParser.h"
#include "FQLParserState.h"

PEGASUS_USING_STD;

extern int FQL_parse();

extern void FQL_restart (FILE *input_file);

PEGASUS_NAMESPACE_BEGIN

FQLParserState* globalParserState = 0;
Array<FQLOperand*> _argList;
static Mutex FQL_mutex;
#ifdef FQL_YYDEBUG
    int FQL_debug = 1;
#endif

void FQLParser::parse(
    const char* text,
    FQLQueryStatement& statement)
{
    PEG_METHOD_ENTER(TRC_FQL,"FQLParser::parse");

    AutoMutex mtx(FQL_mutex);

    if (!text)
    {
        PEG_METHOD_EXIT();
        throw NullPointer();
    }

    statement.clear();

    globalParserState = new FQLParserState;
    globalParserState->error = false;
    globalParserState->text = text;
    globalParserState->textSize = (Uint32)(strlen(text) + 1);
    globalParserState->offset = 0;
    globalParserState->statement = &statement;

    FQL_parse();

    if (globalParserState->error)
    {
        String errorMessage = globalParserState->errorMessage;
        cleanup();
        //Uint32 position = globalParserState->currentTokenPos;
        //Uint32 token = globalParserState->tokenCount;
        String rule = globalParserState->currentRule;
        delete globalParserState;
        PEG_METHOD_EXIT();
        // KS_TODO Expand this one to show token, position, rule
        // Easiest for now is to append string with more data to
        // errorMessage. Enable comments above so they are used.
        throw ParseError(errorMessage);
    }

    cleanup();
    delete globalParserState;
    PEG_METHOD_EXIT();
}

void FQLParser::parse(
    const Buffer& text,
    FQLQueryStatement& statement)
{
    PEG_METHOD_ENTER(TRC_FQL,"FQLParser::parse");

    parse(text.getData(), statement);

    PEG_METHOD_EXIT();
}

void FQLParser::parse(
    const String& text,
    FQLQueryStatement& statement)
{
    PEG_METHOD_ENTER(TRC_FQL,"FQLParser::parse");

    parse(text.getCString(), statement);

    PEG_METHOD_EXIT();
}

void FQLParser::cleanup()
{
    PEG_METHOD_ENTER(TRC_FQL,"FQLParser::cleanup");

    Array<char*>& arr = globalParserState->outstandingStrings;

    for (Uint32 i = 0, n = arr.size(); i < n; i++)
        delete [] arr[i];

    arr.clear();

    PEG_METHOD_EXIT();
}

PEGASUS_NAMESPACE_END

PEGASUS_USING_PEGASUS;

int FQL_error(const char* errorMessage)
{
    PEG_METHOD_ENTER(TRC_FQL,"FQL_error");

    globalParserState->error = true;
    globalParserState->errorMessage = errorMessage;

    //
    //  flex does not automatically flush the input buffer in case of error
    //
    FQL_restart (0);

    PEG_METHOD_EXIT();
    return -1;
}

int FQLInput(char* buffer, int& numRead, int numRequested)
{
    PEG_METHOD_ENTER(TRC_FQL,"FQLInput");
    //
    // Be sure to account for the null terminator (the size of the text will
    // be one or more; this is fixed checked beforehand by FQLParser::parse()).
    //

    int remaining =
        globalParserState->textSize - globalParserState->offset - 1;

    if (remaining == 0)
    {
        numRead = 0;
        PEG_METHOD_EXIT();
        return 0;
    }

    if (remaining < numRequested)
        numRequested = remaining;

    memcpy(buffer,
    globalParserState->text + globalParserState->offset,
    numRequested);

    globalParserState->offset += numRequested;
    numRead = numRequested;

    PEG_METHOD_EXIT();
    return numRead;
}

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2