Source code

Revision control

Copy as Markdown

Other Tools

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: set ts=8 sts=2 et sw=2 tw=80:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
// OSObject.h - os object for exposing posix system calls in the JS shell
#ifndef shell_OSObject_h
#define shell_OSObject_h
#include <stdio.h>
#include "js/TypeDecls.h"
#include "js/Utility.h"
class JSLinearString;
namespace js {
namespace shell {
#ifdef XP_WIN
constexpr char PathSeparator = '\\';
#else
constexpr char PathSeparator = '/';
#endif
struct RCFile;
/* Define an os object on the given global object. */
bool DefineOS(JSContext* cx, JS::HandleObject global, bool fuzzingSafe,
RCFile** shellOut, RCFile** shellErr);
enum PathResolutionMode { RootRelative, ScriptRelative };
bool IsAbsolutePath(JSLinearString* filename);
JSString* ResolvePath(JSContext* cx, JS::HandleString filenameStr,
PathResolutionMode resolveMode);
JSObject* FileAsTypedArray(JSContext* cx, JS::HandleString pathnameStr);
/**
* Return the current working directory as a UTF-8 encoded string.
*
* @param cx current js-context
* @return the working directory name or {@code nullptr} on error
*/
JS::UniqueChars GetCWD(JSContext* cx);
/**
* Open the requested file.
*
* @param cx current js-context
* @param filename file name encoded in UTF-8
* @param mode file mode specifier, see {@code fopen} for valid values
* @return a FILE pointer or {@code nullptr} on failure
*/
FILE* OpenFile(JSContext* cx, const char* filename, const char* mode);
/**
* Read {@code length} bytes in the given buffer.
*
* @param cx current js-context
* @param filename file name encoded in UTF-8, only used for error reporting
* @param file file pointer to read from
* @param buffer destination buffer to copy read bytes into
* @param length number of bytes to read
* @return returns false and reports an error if not exactly {@code length}
* bytes could be read from the input file
*/
bool ReadFile(JSContext* cx, const char* filename, FILE* file, char* buffer,
size_t length);
/**
* Compute the file size in bytes.
*
* @param cx current js-context
* @param filename file name encoded in UTF-8, only used for error reporting
* @param file file object to inspect
* @param size output parameter to store the file size into
* @return returns false and reports an error if an I/O error occurred
*/
bool FileSize(JSContext* cx, const char* filename, FILE* file, size_t* size);
/**
* Return the system error message for the given error number. The error
* message is UTF-8 encoded.
*
* @param cx current js-context
* @param errnum error number
* @return error message or {@code nullptr} on error
*/
JS::UniqueChars SystemErrorMessage(JSContext* cx, int errnum);
} // namespace shell
} // namespace js
#endif /* shell_OSObject_h */