Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.9 KiB

  1. //========= Copyright Valve Corporation, All rights reserved. ============//
  2. //
  3. // Purpose:
  4. //
  5. // $Workfile: $
  6. // $Date: $
  7. // $NoKeywords: $
  8. //=============================================================================//
  9. #ifndef SCRIPLIB_H
  10. #define SCRIPLIB_H
  11. #ifdef _WIN32
  12. #pragma once
  13. #endif
  14. enum ScriptPathMode_t
  15. {
  16. SCRIPT_USE_ABSOLUTE_PATH,
  17. SCRIPT_USE_RELATIVE_PATH
  18. };
  19. // scriplib.h
  20. #define MAXTOKEN 1024
  21. extern char token[MAXTOKEN];
  22. extern char *scriptbuffer,*script_p,*scriptend_p;
  23. extern int grabbed;
  24. extern int scriptline;
  25. extern qboolean endofscript;
  26. // If pathMode is SCRIPT_USE_ABSOLUTE_PATH, then it uses ExpandPath() on the filename before
  27. // trying to open it. Otherwise, it passes the filename straight into the filesystem
  28. // (so you can leave it as a relative path).
  29. void LoadScriptFile (char *filename, ScriptPathMode_t pathMode=SCRIPT_USE_ABSOLUTE_PATH);
  30. void ParseFromMemory (char *buffer, int size);
  31. qboolean GetToken (qboolean crossline);
  32. qboolean GetExprToken (qboolean crossline);
  33. void UnGetToken (void);
  34. qboolean TokenAvailable (void);
  35. qboolean GetTokenizerStatus( char **pFilename, int *pLine );
  36. bool SetCheckSingleCharTokens( bool bCheck );
  37. // SCRIPT_LOADED_CALLBACK:
  38. // Is called after the contents of a file is loaded.
  39. // pFilenameLoaded is the path of a file that got loaded.
  40. // pIncludedFromFileName is the name of the parent file or NULL if loaded because of "LoadScriptFile" toplevel call.
  41. // nIncludeLineNumber is the number of the line in the parent file with $include statement or 0 in case of "LoadScriptFile"
  42. typedef void ( * SCRIPT_LOADED_CALLBACK )( char const *pFilenameLoaded, char const *pIncludedFromFileName, int nIncludeLineNumber );
  43. // SetScriptLoadedCallback:
  44. // Sets the new callback for script loading.
  45. // Returns the previous callback function.
  46. SCRIPT_LOADED_CALLBACK SetScriptLoadedCallback( SCRIPT_LOADED_CALLBACK pfnNewScriptLoadedCallback );
  47. #include "tier1/utlstring.h"
  48. #include "tier1/utlvector.h"
  49. CUtlString SetSingleCharTokenList( const char *pszSingleCharTokenList );
  50. class CUtlBuffer;
  51. enum DiskWriteMode_t
  52. {
  53. WRITE_TO_DISK_NEVER,
  54. WRITE_TO_DISK_ALWAYS,
  55. WRITE_TO_DISK_UPDATE, // file must exist
  56. };
  57. struct fileList_t
  58. {
  59. CUtlString fileName;
  60. time_t timeWrite;
  61. };
  62. class IScriptLib
  63. {
  64. public:
  65. virtual bool ReadFileToBuffer( const char *pSourceName, CUtlBuffer &buffer, bool bText = false, bool bNoOpenFailureWarning = false ) = 0;
  66. virtual bool WriteBufferToFile( const char *pTargetName, CUtlBuffer &buffer, DiskWriteMode_t writeMode ) = 0;
  67. virtual int FindFiles( char* pFileMask, bool bRecurse, CUtlVector<fileList_t> &fileList ) = 0;
  68. virtual char *MakeTemporaryFilename( char const *pchModPath, char *pPath, int pathSize ) = 0;
  69. virtual void DeleteTemporaryFiles( const char *pFileMask ) = 0;
  70. virtual int CompareFileTime( const char *pFilenameA, const char *pFilenameB ) = 0;
  71. virtual bool DoesFileExist( const char *pFilename ) = 0;
  72. };
  73. extern IScriptLib *scriptlib;
  74. #endif // SCRIPLIB_H