Fix part 1 of pr4682. PICADD is a 16-bit instruction even in thumb2 mode.
[llvm/avr.git] / utils / TableGen / TableGenBackend.h
blob9c2b948b0dfc426b61cf488ee65e3d2332f67e6f
1 //===- TableGenBackend.h - Base class for TableGen Backends -----*- C++ -*-===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // The TableGenBackend class is provided as a common interface for all TableGen
11 // backends. It provides useful services and an standardized interface.
13 //===----------------------------------------------------------------------===//
15 #ifndef TABLEGENBACKEND_H
16 #define TABLEGENBACKEND_H
18 #include "llvm/Support/raw_ostream.h"
19 #include <string>
21 namespace llvm {
23 class Record;
24 class RecordKeeper;
26 struct TableGenBackend {
27 virtual ~TableGenBackend() {}
29 // run - All TableGen backends should implement the run method, which should
30 // be the main entry point.
31 virtual void run(raw_ostream &OS) = 0;
34 public: // Useful helper routines...
35 /// EmitSourceFileHeader - Output a LLVM style file header to the specified
36 /// ostream.
37 void EmitSourceFileHeader(const std::string &Desc, raw_ostream &OS) const;
41 } // End llvm namespace
43 #endif