Intel® Implicit SPMD Program Compiler (Intel® ISPC)  1.13.0
Functions
util.cpp File Reference

Various small utility routines. More...

#include "util.h"
#include "module.h"
#include <ctype.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <sys/ioctl.h>
#include <unistd.h>
#include <algorithm>
#include <set>
#include <llvm/IR/DataLayout.h>
Include dependency graph for util.cpp:

Go to the source code of this file.

Functions

int TerminalWidth ()
 
static bool lHaveANSIColors ()
 
static const char * lStartBold ()
 
static const char * lStartRed ()
 
static const char * lStartBlue ()
 
static const char * lResetColor ()
 
static const char * lFindWordEnd (const char *buf)
 
static void lPrintFileLineContext (SourcePos p)
 
static int lFindIndent (int numColons, const char *buf)
 
void PrintWithWordBreaks (const char *buf, int indent, int columnWidth, FILE *out)
 
static void lPrint (const char *type, bool isError, SourcePos p, const char *fmt, va_list args)
 
void Error (SourcePos p, const char *fmt,...)
 
void Debug (SourcePos p, const char *fmt,...)
 
void Warning (SourcePos p, const char *fmt,...)
 
void PerformanceWarning (SourcePos p, const char *fmt,...)
 
static void lPrintBugText ()
 
void FatalError (const char *file, int line, const char *message)
 
void DoAssert (const char *file, int line, const char *expr)
 
void DoAssertPos (SourcePos pos, const char *file, int line, const char *expr)
 
int StringEditDistance (const std::string &str1, const std::string &str2, int maxDist)
 
std::vector< std::string > MatchStrings (const std::string &str, const std::vector< std::string > &options)
 
void GetDirectoryAndFileName (const std::string &currentDirectory, const std::string &relativeName, std::string *directory, std::string *filename)
 
static std::set< std::string > lGetStringArray (const std::string &str)
 
bool VerifyDataLayoutCompatibility (const std::string &module_dl, const std::string &lib_dl)
 
bool IsStdin (const char *filepath)
 

Detailed Description

Various small utility routines.

Definition in file util.cpp.

Function Documentation

◆ Debug()

void Debug ( SourcePos  p,
const char *  format,
  ... 
)

Prints a debugging message. These messages are only printed if g->debugPrint is true. In addition to a program source code position to associate with the message, a printf()-style format string is passed along with any values needed for items in the format string.

Definition at line 366 of file util.cpp.

References Globals::debugPrint, g, lPrint(), and Globals::quiet.

Referenced by AddBitcodeToModule(), Function::emitCode(), IfStmt::emitVaryingIf(), SelectExpr::GetValue(), lApplyLoad1(), lApplyLoad2(), lApplyLoad4(), lAssemble4Vector(), lCreateISPCSymbol(), lCreateSymbol(), lEmitLoads(), lGetConstExprConstant(), lGSToLoadStore(), LLVMVectorIsLinear(), LLVMVectorValuesAllEqual(), lSelectLoads(), BinaryExpr::Optimize(), GatherCoalescePass::runOnBasicBlock(), and TypeConvertExpr().

◆ DoAssert()

void DoAssert ( const char *  file,
int  line,
const char *  expr 
)

This function generally shouldn't be called directly, but should be used via the Assert macro, which includes the file and line number where the assertion happens. Note: avoid adding [[noreturn]] as VS2017 treats Assert macros as never returning.

Definition at line 440 of file util.cpp.

References lPrintBugText().

◆ DoAssertPos()

void DoAssertPos ( SourcePos  pos,
const char *  file,
int  line,
const char *  expr 
)

This function generally shouldn't be called directly, but should be used via the AssertPos macro, which includes the file and line number where the assertion happens. Note: avoid adding [[noreturn]] as VS2017 treats AssertPos macros as never returning.

Definition at line 446 of file util.cpp.

References Error(), and lPrintBugText().

◆ Error()

void Error ( SourcePos  p,
const char *  format,
  ... 
)

Prints an error message. It is assumd that compilation can not be successfully completed after an error has been issued, though the system tries to continue compiling as much as possible, in order to be able to issue any subsequent error messages. In addition to a program source code position to associate with the message, a printf()-style format string is passed along with any values needed for items in the format string.

Definition at line 351 of file util.cpp.

References Module::errorCount, Globals::errorLimit, g, lPrint(), m, and Globals::quiet.

Referenced by AddBitcodeToModule(), Module::AddExportedTypes(), Module::AddFunctionDeclaration(), Module::AddGlobalVariable(), SymbolTable::AddType(), SymbolTable::AddVariable(), ArchToString(), FunctionEmitContext::Break(), StructType::checkIfCanBeSOA(), checkInit(), Module::CompileAndOutput(), FunctionEmitContext::Continue(), MemberExpr::create(), FunctionEmitContext::CurrentLanesReturned(), DoAssertPos(), ArgErrors::Emit(), FunctionEmitContext::EmitCaseLabel(), DeclStmt::EmitCode(), ReturnStmt::EmitCode(), GotoStmt::EmitCode(), AssertStmt::EmitCode(), FunctionEmitContext::EmitDefaultLabel(), emitOffloadParamStruct(), Function::GenerateIR(), DeclSpecs::GetBaseType(), FunctionSymbolExpr::GetConstant(), StructMemberExpr::getElementNumber(), VectorMemberExpr::getElementNumber(), GetStructTypesNamesPositions(), Target::GetTripleString(), FunctionSymbolExpr::GetType(), StructMemberExpr::GetType(), AssignExpr::GetValue(), FunctionCallExpr::GetValue(), VectorMemberExpr::GetValue(), Declaration::GetVariableDeclarations(), Declarator::InitFromDeclSpecs(), Declarator::InitFromType(), FunctionEmitContext::initLabelBBlocks(), InitSymbol(), ISPCTargetToString(), lApplyTypeQualifiers(), lCheckExportedParameterTypes(), lCheckForConstStructMember(), lCheckForStructParameters(), lConstFoldBinaryArithOp(), lCreateBinaryOperatorCall(), lDoTypeConv(), lEmitOpAssign(), lEmitPrePostIncDec(), lGetExprListConstant(), lGetSystemISA(), FunctionEmitContext::LoadInst(), lProcessPrintArg(), lSwitchASTPreVisit(), lVaryingStructHasUniformMember(), lVectorConvert(), main(), Module::Module(), Type::MoreGeneralType(), NewExpr::NewExpr(), FunctionSymbolExpr::ResolveOverloads(), ArrayType::SizeUnsizedArrays(), FunctionEmitContext::StartForeach(), FunctionEmitContext::StoreInst(), StructType::StructType(), Target::Target(), UnaryExpr::TypeCheck(), BinaryExpr::TypeCheck(), AssignExpr::TypeCheck(), ForeachStmt::TypeCheck(), FunctionCallExpr::TypeCheck(), ForeachUniqueStmt::TypeCheck(), IndexExpr::TypeCheck(), LabeledStmt::TypeCheck(), TypeCastExpr::TypeCheck(), DeleteStmt::TypeCheck(), PtrDerefExpr::TypeCheck(), AddressOfExpr::TypeCheck(), SizeOfExpr::TypeCheck(), NewExpr::TypeCheck(), Module::writeDevStub(), Module::writeObjectFileOrAssembly(), and Module::writeOutput().

◆ FatalError()

void FatalError ( const char *  file,
int  line,
const char *  message 
)

This function generally shouldn't be called directly, but should be used via the FATAL macro, which includes the file and line number where the error was issued.

Definition at line 434 of file util.cpp.

References lPrintBugText().

◆ GetDirectoryAndFileName()

void GetDirectoryAndFileName ( const std::string &  currentDir,
const std::string &  relativeName,
std::string *  directory,
std::string *  filename 
)

Given the current working directory and a filename relative to that directory, this function returns the final directory that the resulting file is in and the base name of the file itself.

Definition at line 516 of file util.cpp.

References Assert, Globals::currentDirectory, and g.

Referenced by SourcePos::GetDIFile(), and Module::Module().

◆ IsStdin()

bool IsStdin ( const char *  )

Returns true is the filepath represents stdin, otherwise false.

Definition at line 621 of file util.cpp.

References Assert.

Referenced by Module::CompileAndOutput(), Module::CompileFile(), Module::Module(), and Module::writeDeps().

◆ lFindIndent()

static int lFindIndent ( int  numColons,
const char *  buf 
)
static

Counts the number of characters into the buf at which the numColons colon character is found. Skips over ANSI escape sequences and doesn't include their characters in the final count.

Definition at line 187 of file util.cpp.

Referenced by lPrint().

◆ lFindWordEnd()

static const char* lFindWordEnd ( const char *  buf)
static

Given a pointer into a string, find the end of the current word and return a pointer to its last character.

Definition at line 135 of file util.cpp.

Referenced by PrintWithWordBreaks().

◆ lGetStringArray()

static std::set<std::string> lGetStringArray ( const std::string &  str)
static

Definition at line 551 of file util.cpp.

References Assert.

Referenced by VerifyDataLayoutCompatibility().

◆ lHaveANSIColors()

static bool lHaveANSIColors ( )
static

Definition at line 95 of file util.cpp.

References Globals::forceColoredOutput, and g.

Referenced by lResetColor(), lStartBlue(), lStartBold(), and lStartRed().

◆ lPrint()

static void lPrint ( const char *  type,
bool  isError,
SourcePos  p,
const char *  fmt,
va_list  args 
)
static

Helper function for Error(), Warning(), etc.

Parameters
typeThe type of message being printed (e.g. "Warning")
pPosition in source file that is connected to the message being printed
fmtprintf()-style format string
argsArguments with values for format string % entries

Definition at line 304 of file util.cpp.

References SourcePos::first_column, SourcePos::first_line, lFindIndent(), lPrintFileLineContext(), lResetColor(), lStartBlue(), lStartBold(), lStartRed(), SourcePos::name, PrintWithWordBreaks(), and TerminalWidth().

Referenced by Debug(), Error(), PerformanceWarning(), and Warning().

◆ lPrintBugText()

static void lPrintBugText ( )
static

Definition at line 420 of file util.cpp.

Referenced by DoAssert(), DoAssertPos(), and FatalError().

◆ lPrintFileLineContext()

static void lPrintFileLineContext ( SourcePos  p)
static

When printing error messages, we sometimes want to include the source file line for context. This function print the line(s) of the file corresponding to the provided SourcePos and underlines the range of the SourcePos with '^' symbols.

Definition at line 146 of file util.cpp.

References SourcePos::first_column, SourcePos::first_line, SourcePos::last_column, SourcePos::last_line, and SourcePos::name.

Referenced by lPrint().

◆ lResetColor()

static const char* lResetColor ( )
static

Definition at line 125 of file util.cpp.

References lHaveANSIColors().

Referenced by lPrint().

◆ lStartBlue()

static const char* lStartBlue ( )
static

Definition at line 118 of file util.cpp.

References lHaveANSIColors().

Referenced by lPrint().

◆ lStartBold()

static const char* lStartBold ( )
static

Definition at line 104 of file util.cpp.

References lHaveANSIColors().

Referenced by lPrint().

◆ lStartRed()

static const char* lStartRed ( )
static

Definition at line 111 of file util.cpp.

References lHaveANSIColors().

Referenced by lPrint().

◆ MatchStrings()

std::vector<std::string> MatchStrings ( const std::string &  str,
const std::vector< std::string > &  options 
)

Given a string and a set of candidate strings, returns the set of candidates that are "close" to the given string, where distance is measured by the number of single-character changes needed to transform between the two. An empty vector may be returned if none of the options is close to str.

Definition at line 490 of file util.cpp.

References StringEditDistance().

Referenced by GotoStmt::EmitCode(), and MemberExpr::getCandidateNearMatches().

◆ PerformanceWarning()

void PerformanceWarning ( SourcePos  p,
const char *  format,
  ... 
)

Prints a message about a potential performance issue in the user's code. These messages are purely informative and don't affect the completion of compilation. In addition to a program source code position to associate with the message, a printf()-style format string is passed along with any values needed for items in the format string.

Definition at line 397 of file util.cpp.

References Globals::emitPerfWarnings, Module::errorCount, g, SourcePos::last_line, lPrint(), m, SourcePos::name, Globals::quiet, Globals::turnOffWarnings, and Globals::warningsAsErrors.

Referenced by DeclSpecs::GetBaseType(), BinaryExpr::GetValue(), lCoalescePerfInfo(), lEmitBinaryArith(), lReplacePseudoGS(), lTypeConvAtomic(), and ReplaceStdlibShiftPass::runOnBasicBlock().

◆ PrintWithWordBreaks()

void PrintWithWordBreaks ( const char *  buf,
int  indent,
int  columnWidth,
FILE *  out 
)

Print the given string to the given FILE, assuming the given output column width. Break words as needed to avoid words spilling past the last column.

Definition at line 210 of file util.cpp.

References lFindWordEnd().

Referenced by lPrint(), and usage().

◆ StringEditDistance()

int StringEditDistance ( const std::string &  str1,
const std::string &  str2,
int  maxDist 
)

Returns the number of single-character edits needed to transform between the two strings.

Parameters
str1First string
str2Second string
maxDistMaximum number of single-character edits allowed
Returns
Number of single-character edits to transform from str1 to str2, or maxDist+1 if it's not psosible to do so in fewer than maxDist steps

Definition at line 455 of file util.cpp.

Referenced by SymbolTable::closestTypeMatch(), SymbolTable::ClosestVariableOrFunctionMatch(), and MatchStrings().

◆ TerminalWidth()

int TerminalWidth ( )

Returns the width of the terminal where the compiler is running. Finding this out may fail in a variety of reasonable situations (piping compiler output to 'less', redirecting output to a file, running the compiler under a debuffer; in this case, just return a reasonable default.

Definition at line 76 of file util.cpp.

References Globals::disableLineWrap, and g.

Referenced by lPrint(), and usage().

◆ VerifyDataLayoutCompatibility()

bool VerifyDataLayoutCompatibility ( const std::string &  module_dl,
const std::string &  lib_dl 
)

Verification routine, which ensures that DataLayout of the module being compiled is compatible with DataLayout of the library. At the moment we allow the library DataLayout to a subset of the module DataLayout (and extra floating point and vector types to be defined for module) or empty library DataLayout.

Definition at line 568 of file util.cpp.

References lGetStringArray().

Referenced by AddBitcodeToModule().

◆ Warning()

void Warning ( SourcePos  p,
const char *  format,
  ... 
)