Skip to content

core.language.language

Used to obtain information about the compiled language, generally used for the operation of code files.

language.extensions

  • Get a list of code suffixes for all languages

Function Prototype

API

lua
language.extensions()

Parameter Description

No parameters required for this function.

Return Value

TypeDescription
tableReturns a table with file extensions as keys and language source types as values

Usage

Get a list of code suffixes for all languages.

The results are as follows:

lua
{
    [".c"] = cc,
    [".cc"] = cxx,
    [".cpp"] = cxx,
    [".m"] = mm,
    [".mm"] = mxx,
    [".swift"] = sc,
    [".go"] = gc
}

language.targetkinds

  • Get a list of target types in all languages

Function Prototype

API

lua
language.targetkinds()

Parameter Description

No parameters required for this function.

Return Value

TypeDescription
tableReturns a table with target types as keys and lists of supported linkers as values

Usage

Get a list of target types in all languages.

The results are as follows:

lua
{
    binary = {"ld", "gcld", "dcld"},
    static = {"ar", "gcar", "dcar"},
    shared = {"sh", "dcsh"}
}

language.sourcekinds

  • Get a list of source file types in all languages

Function Prototype

API

lua
language.sourcekinds()

Parameter Description

No parameters required for this function.

Return Value

TypeDescription
tableReturns a table with source file types as keys and file extensions or extension lists as values

Usage

Get a list of source file types in all languages.

The results are as follows:

lua
{
    cc = ".c",
    cxx = {".cc", ".cpp", ".cxx"},
    mm = ".m",
    mxx = ".mm",
    sc = ".swift",
    gc = ".go",
    rc = ".rs",
    dc = ".d",
    as = {".s", ".S", ".asm"}
}

language.sourceflags

  • Load a list of source file compilation option names for all languages

Function Prototype

API

lua
language.sourceflags()

Parameter Description

No parameters required for this function.

Return Value

TypeDescription
tableReturns a table with source file types as keys and compilation option name lists as values

Usage

Load a list of source file compilation option names for all languages.

The results are as follows:

lua
{
    cc = {"cflags", "cxflags"},
    cxx = {"cxxflags", "cxflags"},
    ...
}

language.load

  • Load the specified language

Function Prototype

API

lua
language.load(name: <string>)

Parameter Description

ParameterDescription
nameRequired. Language name, e.g., "c++", "c"

Return Value

TypeDescription
languageReturns a language object, or nil if it doesn't exist

Usage

Load a specific language object from the language name, for example:

lua
local lang = language.load("c++")
if lang then
    print(lang:name())
end

language.load_sk

  • Load the specified language from the source file type

Function Prototype

API

lua
language.load_sk(sourcekind: <string>)

Parameter Description

ParameterDescription
sourcekindRequired. Source file type, e.g., "cc", "cxx", "mm"

Return Value

TypeDescription
languageReturns a language object, or nil if it doesn't exist

Usage

Load specific language objects from the source file type: cc, cxx, mm, mxx, sc, gc, as .., for example:

lua
local lang = language.load_sk("cxx")
if lang then
    print(lang:name())
end

language.load_ex

  • Load the specified language from the source file suffix name

Function Prototype

API

lua
language.load_ex(extension: <string>)

Parameter Description

ParameterDescription
extensionRequired. Source file extension, e.g., ".cpp", ".c"

Return Value

TypeDescription
languageReturns a language object, or nil if it doesn't exist

Usage

Load specific language objects from the source file extension: .cc, .c, .cpp, .mm, .swift, .go .., for example:

lua
local lang = language.load_ex(".cpp")
if lang then
    print(lang:name())
end

language.sourcekind_of

  • Get the source file type of the specified source file

Function Prototype

API

lua
language.sourcekind_of(filepath: <string>)

Parameter Description

ParameterDescription
filepathRequired. Source file path

Return Value

TypeDescription
stringReturns the source file type, e.g., "cxx", "cc"

Usage

That is, from a given source file path, get the type of source file it belongs to, for example:

lua
print(language.sourcekind_of("/xxxx/test.cpp"))

The result is: cxx, which is the c++ type. For the corresponding list, see: language.sourcekinds