// This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details #pragma once #include "Luau/Ast.h" #include "Luau/Parser.h" #include "Luau/AutocompleteTypes.h" #include "Luau/DenseHash.h" #include "Luau/Module.h" #include "Luau/Frontend.h" #include #include namespace Luau { struct FrontendOptions; enum class FragmentAutocompleteWaypoint { ParseFragmentEnd, CloneModuleStart, CloneModuleEnd, DfgBuildEnd, CloneAndSquashScopeStart, CloneAndSquashScopeEnd, ConstraintSolverStart, ConstraintSolverEnd, TypecheckFragmentEnd, AutocompleteEnd, COUNT, }; class IFragmentAutocompleteReporter { public: virtual void reportWaypoint(FragmentAutocompleteWaypoint) = 0; virtual void reportFragmentString(std::string_view) = 0; }; enum class FragmentTypeCheckStatus { SkipAutocomplete, Success, }; struct FragmentAutocompleteAncestryResult { DenseHashMap localMap{AstName()}; std::vector localStack; std::vector ancestry; AstStat* nearestStatement = nullptr; AstStatBlock* parentBlock = nullptr; Location fragmentSelectionRegion; }; struct FragmentParseResult { std::string fragmentToParse; AstStatBlock* root = nullptr; std::vector ancestry; AstStat* nearestStatement = nullptr; std::vector commentLocations; std::unique_ptr alloc = std::make_unique(); Position scopePos{0, 0}; }; struct FragmentTypeCheckResult { ModulePtr incrementalModule = nullptr; ScopePtr freshScope; std::vector ancestry; }; struct FragmentAutocompleteResult { ModulePtr incrementalModule; Scope* freshScope; TypeArena arenaForAutocomplete; AutocompleteResult acResults; }; struct FragmentRegion { Location fragmentLocation; AstStat* nearestStatement = nullptr; // used for tests AstStatBlock* parentBlock = nullptr; // used for scope detection }; FragmentRegion getFragmentRegion(AstStatBlock* root, const Position& cursorPosition); FragmentAutocompleteAncestryResult findAncestryForFragmentParse(AstStatBlock* stale, const Position& cursorPos, AstStatBlock* lastGoodParse); FragmentAutocompleteAncestryResult findAncestryForFragmentParse_DEPRECATED(AstStatBlock* root, const Position& cursorPos); std::optional parseFragment_DEPRECATED( AstStatBlock* root, AstNameTable* names, std::string_view src, const Position& cursorPos, std::optional fragmentEndPosition ); std::optional parseFragment( AstStatBlock* stale, AstStatBlock* mostRecentParse, AstNameTable* names, std::string_view src, const Position& cursorPos, std::optional fragmentEndPosition ); std::pair typecheckFragment( Frontend& frontend, const ModuleName& moduleName, const Position& cursorPos, std::optional opts, std::string_view src, std::optional fragmentEndPosition, AstStatBlock* recentParse = nullptr, IFragmentAutocompleteReporter* reporter = nullptr ); FragmentAutocompleteResult fragmentAutocomplete( Frontend& frontend, std::string_view src, const ModuleName& moduleName, Position cursorPosition, std::optional opts, StringCompletionCallback callback, std::optional fragmentEndPosition = std::nullopt, AstStatBlock* recentParse = nullptr, IFragmentAutocompleteReporter* reporter = nullptr ); enum class FragmentAutocompleteStatus { Success, FragmentTypeCheckFail, InternalIce }; struct FragmentAutocompleteStatusResult { FragmentAutocompleteStatus status; std::optional result; }; struct FragmentContext { std::string_view newSrc; const ParseResult& freshParse; std::optional opts; std::optional DEPRECATED_fragmentEndPosition; IFragmentAutocompleteReporter* reporter = nullptr; }; /** * @brief Attempts to compute autocomplete suggestions from the fragment context. * * This function computes autocomplete suggestions using outdated frontend typechecking data * by patching the fragment context of the new script source content. * * @param frontend The Luau Frontend data structure, which may contain outdated typechecking data. * * @param moduleName The name of the target module, specifying which script the caller wants to request autocomplete for. * * @param cursorPosition The position in the script where the caller wants to trigger autocomplete. * * @param context The fragment context that this API will use to patch the outdated typechecking data. * * @param stringCompletionCB A callback function that provides autocomplete suggestions for string contexts. * * @return * The status indicating whether `fragmentAutocomplete` ran successfully or failed, along with the reason for failure. * Also includes autocomplete suggestions if the status is successful. * * @usage * FragmentAutocompleteStatusResult acStatusResult; * if (shouldFragmentAC) * acStatusResult = Luau::tryFragmentAutocomplete(...); * * if (acStatusResult.status != Successful) * { * frontend.check(moduleName, options); * acStatusResult.acResult = Luau::autocomplete(...); * } * return convertResultWithContext(acStatusResult.acResult); */ FragmentAutocompleteStatusResult tryFragmentAutocomplete( Frontend& frontend, const ModuleName& moduleName, Position cursorPosition, FragmentContext context, StringCompletionCallback stringCompletionCB ); } // namespace Luau