c/clang:presume location

This commit is contained in:
luoliwoshang
2025-02-06 16:04:54 +08:00
parent 29ec3014e7
commit 0a0bb128d6
3 changed files with 66 additions and 6 deletions

View File

@@ -2878,6 +2878,53 @@ func (l SourceLocation) Offset() (ret c.Uint) {
return
}
/**
* Retrieve the file, line and column represented by the given source
* location, as specified in a # line directive.
*
* Example: given the following source code in a file somefile.c
*
* \code
* #123 "dummy.c" 1
*
* static int func(void)
* {
* return 0;
* }
* \endcode
*
* the location information returned by this function would be
*
* File: dummy.c Line: 124 Column: 12
*
* whereas clang_getExpansionLocation would have returned
*
* File: somefile.c Line: 3 Column: 12
*
* \param location the location within a source file that will be decomposed
* into its parts.
*
* \param filename [out] if non-NULL, will be set to the filename of the
* source location. Note that filenames returned will be for "virtual" files,
* which don't necessarily exist on the machine running clang - e.g. when
* parsing preprocessed output obtained from a different environment. If
* a non-NULL value is passed in, remember to dispose of the returned value
* using \c clang_disposeString() once you've finished with it. For an invalid
* source location, an empty string is returned.
*
* \param line [out] if non-NULL, will be set to the line number of the
* source location. For an invalid source location, zero is returned.
*
* \param column [out] if non-NULL, will be set to the column number of the
* source location. For an invalid source location, zero is returned.
*/
// llgo:link (*SourceLocation).wrapPresumedLocation C.wrap_clang_getPresumedLocation
func (l *SourceLocation) wrapPresumedLocation(filename *String, line, column *c.Uint) {}
func (l SourceLocation) PresumedLocation(filename *String, line, column *c.Uint) {
l.wrapPresumedLocation(filename, line, column)
}
/**
* Retrieve a source location representing the first character within a
* source range.