antlr3filestream.hpp 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. #ifndef _ANTLR3_FILESTREAM_HPP
  2. #define _ANTLR3_FILESTREAM_HPP
  3. // [The "BSD licence"]
  4. // Copyright (c) 2005-2009 Gokulakannan Somasundaram, ElectronDB
  5. //
  6. // All rights reserved.
  7. //
  8. // Redistribution and use in source and binary forms, with or without
  9. // modification, are permitted provided that the following conditions
  10. // are met:
  11. // 1. Redistributions of source code must retain the above copyright
  12. // notice, this list of conditions and the following disclaimer.
  13. // 2. Redistributions in binary form must reproduce the above copyright
  14. // notice, this list of conditions and the following disclaimer in the
  15. // documentation and/or other materials provided with the distribution.
  16. // 3. The name of the author may not be used to endorse or promote products
  17. // derived from this software without specific prior written permission.
  18. //
  19. // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  20. // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  21. // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  22. // IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  23. // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  24. // NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  25. // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  26. // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  28. // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. namespace antlr3 {
  30. template<class ImplTraits>
  31. class FileUtils
  32. {
  33. public:
  34. /** \brief Open an operating system file and return the descriptor
  35. * We just use the common open() and related functions here.
  36. * Later we might find better ways on systems
  37. * such as Windows and OpenVMS for instance. But the idea is to read the
  38. * while file at once anyway, so it may be irrelevant.
  39. */
  40. static ANTLR_FDSC AntlrFopen(const ANTLR_UINT8* filename, const char * mode);
  41. /** \brief Close an operating system file and free any handles
  42. * etc.
  43. */
  44. static void AntlrFclose (ANTLR_FDSC fd);
  45. static ANTLR_UINT32 AntlrFsize(const ANTLR_UINT8* filename);
  46. template<typename InputStreamType>
  47. static ANTLR_UINT32 AntlrRead8Bit(InputStreamType* input, const ANTLR_UINT8* fileName);
  48. static ANTLR_UINT32 AntlrFread(ANTLR_FDSC fdsc, ANTLR_UINT32 count, void* data);
  49. };
  50. class ParseFileAbsentException : public std::exception
  51. {
  52. virtual const char* what() const noexcept
  53. {
  54. return " Parse File not Present";
  55. }
  56. };
  57. }
  58. #include "antlr3filestream.inl"
  59. #endif