ctkErrorLogFDMessageHandler_p.h 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) Kitware Inc.
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.apache.org/licenses/LICENSE-2.0.txt
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. #ifndef __ctkErrorLogFDMessageHandler_p_h
  15. #define __ctkErrorLogFDMessageHandler_p_h
  16. // Qt includes
  17. #include <QObject>
  18. #include <QFileSystemWatcher>
  19. #include <QTemporaryFile>
  20. // CTK includes
  21. #include "ctkErrorLogModel.h"
  22. // STD includes
  23. #include <cstdio>
  24. class ctkErrorLogFDMessageHandler;
  25. // --------------------------------------------------------------------------
  26. class ctkFDHandler : public QObject
  27. {
  28. Q_OBJECT
  29. public:
  30. typedef ctkFDHandler Self;
  31. ctkFDHandler(ctkErrorLogFDMessageHandler* messageHandler,
  32. ctkErrorLogModel::LogLevel logLevel,
  33. int fileDescriptorNumber);
  34. void setEnabled(bool value);
  35. static FILE* fileDescriptorFromNumber(int fdNumber);
  36. public slots:
  37. void outputFileChanged(const QString & path);
  38. private:
  39. ctkErrorLogFDMessageHandler * MessageHandler;
  40. ctkErrorLogModel::LogLevel LogLevel;
  41. /// OutputFile where either stdout or stderr is redirected
  42. QTemporaryFile OutputFile;
  43. /// The fileWatcher will emit the signal 'fileChanged()' each time the outputFile changed.
  44. QFileSystemWatcher OutputFileWatcher;
  45. int FDNumber;
  46. int SavedFDNumber;
  47. fpos_t SavedFDPos;
  48. FILE* FD;
  49. bool Enabled;
  50. };
  51. #endif