Add parseSourceString method to make it easy for clients to parse a string to a module.

PiperOrigin-RevId: 211354628
This commit is contained in:
Jacques Pienaar 2018-09-03 07:38:31 -07:00 committed by jpienaar
parent 6dc2a34dcf
commit b7fc834856
2 changed files with 24 additions and 1 deletions

View File

@ -23,7 +23,9 @@
#define MLIR_PARSER_H #define MLIR_PARSER_H
namespace llvm { namespace llvm {
class SourceMgr; class SourceMgr;
class SMDiagnostic;
class StringRef;
} // end namespace llvm } // end namespace llvm
namespace mlir { namespace mlir {
@ -35,6 +37,11 @@ class MLIRContext;
/// the error handler registered in the context, and a null pointer is returned. /// the error handler registered in the context, and a null pointer is returned.
Module *parseSourceFile(llvm::SourceMgr &sourceMgr, MLIRContext *context); Module *parseSourceFile(llvm::SourceMgr &sourceMgr, MLIRContext *context);
/// This parses the module string to a MLIR module if it was valid. If not, the
/// error message is emitted through / the error handler registered in the
/// context, and a null pointer is returned.
Module *parseSourceString(llvm::StringRef moduleStr, MLIRContext *context);
} // end namespace mlir } // end namespace mlir
#endif // MLIR_PARSER_H #endif // MLIR_PARSER_H

View File

@ -35,9 +35,13 @@
#include "mlir/IR/StmtVisitor.h" #include "mlir/IR/StmtVisitor.h"
#include "mlir/IR/Types.h" #include "mlir/IR/Types.h"
#include "llvm/ADT/DenseMap.h" #include "llvm/ADT/DenseMap.h"
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/PrettyStackTrace.h" #include "llvm/Support/PrettyStackTrace.h"
#include "llvm/Support/SMLoc.h"
#include "llvm/Support/SourceMgr.h" #include "llvm/Support/SourceMgr.h"
using namespace mlir; using namespace mlir;
using llvm::MemoryBuffer;
using llvm::SMLoc; using llvm::SMLoc;
using llvm::SourceMgr; using llvm::SourceMgr;
@ -3030,3 +3034,15 @@ Module *mlir::parseSourceFile(llvm::SourceMgr &sourceMgr,
return module.release(); return module.release();
} }
/// This parses the program string to a MLIR module if it was valid. If not, it
/// emits diagnostics and returns null.
Module *mlir::parseSourceString(StringRef moduleStr, MLIRContext *context) {
auto memBuffer = MemoryBuffer::getMemBuffer(moduleStr);
if (!memBuffer)
return nullptr;
SourceMgr sourceMgr;
sourceMgr.AddNewSourceBuffer(std::move(memBuffer), SMLoc());
return parseSourceFile(sourceMgr, context);
}