Prism Ruby parser
Loading...
Searching...
No Matches
Data Structures | Macros | Typedefs | Enumerations | Functions
options.h File Reference

The options that can be passed to parsing. More...

#include "prism/defines.h"
#include "prism/util/pm_char.h"
#include "prism/util/pm_string.h"
#include <stdbool.h>
#include <stddef.h>
#include <stdint.h>
Include dependency graph for options.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  pm_options_scope
 A scope of locals surrounding the code that is being parsed. More...
 
struct  pm_options
 The options that can be passed to the parser. More...
 

Macros

#define PM_OPTIONS_FROZEN_STRING_LITERAL_DISABLED   ((int8_t) -1)
 String literals should be made frozen.
 
#define PM_OPTIONS_FROZEN_STRING_LITERAL_UNSET   ((int8_t) 0)
 String literals may be frozen or mutable depending on the implementation default.
 
#define PM_OPTIONS_FROZEN_STRING_LITERAL_ENABLED   ((int8_t) 1)
 String literals should be made mutable.
 

Typedefs

typedef struct pm_options_scope pm_options_scope_t
 A scope of locals surrounding the code that is being parsed.
 
typedef void(* pm_options_shebang_callback_t) (struct pm_options *options, const uint8_t *source, size_t length, void *shebang_callback_data)
 The callback called when additional switches are found in a shebang comment that need to be processed by the runtime.
 
typedef struct pm_options pm_options_t
 The options that can be passed to the parser.
 

Enumerations

enum  pm_options_version_t { PM_OPTIONS_VERSION_LATEST = 0 , PM_OPTIONS_VERSION_CRUBY_3_3 = 1 , PM_OPTIONS_VERSION_CRUBY_3_4 = 2 }
 The version of Ruby syntax that we should be parsing with. More...
 

Functions

PRISM_EXPORTED_FUNCTION void pm_options_shebang_callback_set (pm_options_t *options, pm_options_shebang_callback_t shebang_callback, void *shebang_callback_data)
 Set the shebang callback option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_filepath_set (pm_options_t *options, const char *filepath)
 Set the filepath option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_line_set (pm_options_t *options, int32_t line)
 Set the line option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_encoding_set (pm_options_t *options, const char *encoding)
 Set the encoding option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_encoding_locked_set (pm_options_t *options, bool encoding_locked)
 Set the encoding_locked option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_frozen_string_literal_set (pm_options_t *options, bool frozen_string_literal)
 Set the frozen string literal option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_command_line_set (pm_options_t *options, uint8_t command_line)
 Sets the command line option on the given options struct.
 
PRISM_EXPORTED_FUNCTION bool pm_options_version_set (pm_options_t *options, const char *version, size_t length)
 Set the version option on the given options struct by parsing the given string.
 
PRISM_EXPORTED_FUNCTION void pm_options_main_script_set (pm_options_t *options, bool main_script)
 Set the main script option on the given options struct.
 
PRISM_EXPORTED_FUNCTION void pm_options_partial_script_set (pm_options_t *options, bool partial_script)
 Set the partial script option on the given options struct.
 
PRISM_EXPORTED_FUNCTION bool pm_options_scopes_init (pm_options_t *options, size_t scopes_count)
 Allocate and zero out the scopes array on the given options struct.
 
PRISM_EXPORTED_FUNCTION const pm_options_scope_tpm_options_scope_get (const pm_options_t *options, size_t index)
 Return a pointer to the scope at the given index within the given options.
 
PRISM_EXPORTED_FUNCTION bool pm_options_scope_init (pm_options_scope_t *scope, size_t locals_count)
 Create a new options scope struct.
 
PRISM_EXPORTED_FUNCTION const pm_string_tpm_options_scope_local_get (const pm_options_scope_t *scope, size_t index)
 Return a pointer to the local at the given index within the given scope.
 
PRISM_EXPORTED_FUNCTION void pm_options_free (pm_options_t *options)
 Free the internal memory associated with the options.
 
void pm_options_read (pm_options_t *options, const char *data)
 Deserialize an options struct from the given binary string.
 

Detailed Description

The options that can be passed to parsing.

Typedef Documentation

◆ pm_options_shebang_callback_t

typedef void(* pm_options_shebang_callback_t) (struct pm_options *options, const uint8_t *source, size_t length, void *shebang_callback_data)

The callback called when additional switches are found in a shebang comment that need to be processed by the runtime.

Parameters
optionsThe options struct that may be updated by this callback. Certain fields will be checked for changes, specifically encoding, command_line, and frozen_string_literal.
sourceThe source of the shebang comment.
lengthThe length of the source.
shebang_callback_dataAny additional data that should be passed along to the callback.

Enumeration Type Documentation

◆ pm_options_version_t

The version of Ruby syntax that we should be parsing with.

This is used to allow consumers to specify which behavior they want in case they need to parse in the same way as a specific version of CRuby would have.

Enumerator
PM_OPTIONS_VERSION_LATEST 

The current version of prism.

PM_OPTIONS_VERSION_CRUBY_3_3 

The vendored version of prism in CRuby 3.3.x.

PM_OPTIONS_VERSION_CRUBY_3_4 

The vendored version of prism in CRuby 3.4.x.

Function Documentation

◆ pm_options_shebang_callback_set()

PRISM_EXPORTED_FUNCTION void pm_options_shebang_callback_set ( pm_options_t options,
pm_options_shebang_callback_t  shebang_callback,
void *  shebang_callback_data 
)

Set the shebang callback option on the given options struct.

Parameters
optionsThe options struct to set the shebang callback on.
shebang_callbackThe shebang callback to set.
shebang_callback_dataAny additional data that should be passed along to the callback.

◆ pm_options_filepath_set()

PRISM_EXPORTED_FUNCTION void pm_options_filepath_set ( pm_options_t options,
const char *  filepath 
)

Set the filepath option on the given options struct.

Parameters
optionsThe options struct to set the filepath on.
filepathThe filepath to set.

◆ pm_options_line_set()

PRISM_EXPORTED_FUNCTION void pm_options_line_set ( pm_options_t options,
int32_t  line 
)

Set the line option on the given options struct.

Parameters
optionsThe options struct to set the line on.
lineThe line to set.

◆ pm_options_encoding_set()

PRISM_EXPORTED_FUNCTION void pm_options_encoding_set ( pm_options_t options,
const char *  encoding 
)

Set the encoding option on the given options struct.

Parameters
optionsThe options struct to set the encoding on.
encodingThe encoding to set.

◆ pm_options_encoding_locked_set()

PRISM_EXPORTED_FUNCTION void pm_options_encoding_locked_set ( pm_options_t options,
bool  encoding_locked 
)

Set the encoding_locked option on the given options struct.

Parameters
optionsThe options struct to set the encoding_locked value on.
encoding_lockedThe encoding_locked value to set.

◆ pm_options_frozen_string_literal_set()

PRISM_EXPORTED_FUNCTION void pm_options_frozen_string_literal_set ( pm_options_t options,
bool  frozen_string_literal 
)

Set the frozen string literal option on the given options struct.

Parameters
optionsThe options struct to set the frozen string literal value on.
frozen_string_literalThe frozen string literal value to set.

◆ pm_options_command_line_set()

PRISM_EXPORTED_FUNCTION void pm_options_command_line_set ( pm_options_t options,
uint8_t  command_line 
)

Sets the command line option on the given options struct.

Parameters
optionsThe options struct to set the command line option on.
command_lineThe command_line value to set.

◆ pm_options_version_set()

PRISM_EXPORTED_FUNCTION bool pm_options_version_set ( pm_options_t options,
const char *  version,
size_t  length 
)

Set the version option on the given options struct by parsing the given string.

If the string contains an invalid option, this returns false. Otherwise, it returns true.

Parameters
optionsThe options struct to set the version on.
versionThe version to set.
lengthThe length of the version string.
Returns
Whether or not the version was parsed successfully.

If the string contains an invalid option, this returns false. Otherwise, it returns true.

◆ pm_options_main_script_set()

PRISM_EXPORTED_FUNCTION void pm_options_main_script_set ( pm_options_t options,
bool  main_script 
)

Set the main script option on the given options struct.

Parameters
optionsThe options struct to set the main script value on.
main_scriptThe main script value to set.

◆ pm_options_partial_script_set()

PRISM_EXPORTED_FUNCTION void pm_options_partial_script_set ( pm_options_t options,
bool  partial_script 
)

Set the partial script option on the given options struct.

Parameters
optionsThe options struct to set the partial script value on.
partial_scriptThe partial script value to set.

◆ pm_options_scopes_init()

PRISM_EXPORTED_FUNCTION bool pm_options_scopes_init ( pm_options_t options,
size_t  scopes_count 
)

Allocate and zero out the scopes array on the given options struct.

Parameters
optionsThe options struct to initialize the scopes array on.
scopes_countThe number of scopes to allocate.
Returns
Whether or not the scopes array was initialized successfully.

◆ pm_options_scope_get()

PRISM_EXPORTED_FUNCTION const pm_options_scope_t * pm_options_scope_get ( const pm_options_t options,
size_t  index 
)

Return a pointer to the scope at the given index within the given options.

Parameters
optionsThe options struct to get the scope from.
indexThe index of the scope to get.
Returns
A pointer to the scope at the given index.

◆ pm_options_scope_init()

PRISM_EXPORTED_FUNCTION bool pm_options_scope_init ( pm_options_scope_t scope,
size_t  locals_count 
)

Create a new options scope struct.

This will hold a set of locals that are in scope surrounding the code that is being parsed.

Parameters
scopeThe scope struct to initialize.
locals_countThe number of locals to allocate.
Returns
Whether or not the scope was initialized successfully.

This will hold a set of locals that are in scope surrounding the code that is being parsed.

◆ pm_options_scope_local_get()

PRISM_EXPORTED_FUNCTION const pm_string_t * pm_options_scope_local_get ( const pm_options_scope_t scope,
size_t  index 
)

Return a pointer to the local at the given index within the given scope.

Parameters
scopeThe scope struct to get the local from.
indexThe index of the local to get.
Returns
A pointer to the local at the given index.

◆ pm_options_free()

PRISM_EXPORTED_FUNCTION void pm_options_free ( pm_options_t options)

Free the internal memory associated with the options.

Parameters
optionsThe options struct whose internal memory should be freed.

◆ pm_options_read()

void pm_options_read ( pm_options_t options,
const char *  data 
)

Deserialize an options struct from the given binary string.

This is used to pass options to the parser from an FFI call so that consumers of the library from an FFI perspective don't have to worry about the structure of our options structs. Since the source of these calls will be from Ruby implementation internals we assume it is from a trusted source.

data is assumed to be a valid pointer pointing to well-formed data. The layout of this data should be the same every time, and is described below:

# bytes field
4 the length of the filepath
... the filepath bytes
4 the line number
4 the length the encoding
... the encoding bytes
1 frozen string literal
1 -p command line option
1 -n command line option
1 -l command line option
1 -a command line option
1 the version
1 encoding locked
1 main script
1 partial script
4 the number of scopes
... the scopes

The version field is an enum, so it should be one of the following values:

value version
0 use the latest version of prism
1 use the version of prism that is vendored in CRuby 3.3.0

Each scope is laid out as follows:

# bytes field
4 the number of locals
... the locals

Each local is laid out as follows:

# bytes field
4 the length of the local
... the local bytes

Some additional things to note about this layout:

  • The filepath can have a length of 0, in which case we'll consider it an empty string.
  • The line number should be 0-indexed.
  • The encoding can have a length of 0, in which case we'll use the default encoding (UTF-8). If it's not 0, it should correspond to a name of an encoding that can be passed to Encoding.find in Ruby.
  • The frozen string literal, encoding locked, main script, and partial script fields are booleans, so their values should be either 0 or 1.
  • The number of scopes can be 0.
Parameters
optionsThe options struct to deserialize into.
dataThe binary string to deserialize from.

This is used to pass options to the parser from an FFI call so that consumers of the library from an FFI perspective don't have to worry about the structure of our options structs. Since the source of these calls will be from Ruby implementation internals we assume it is from a trusted source.