mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
pretty mechanical changes to match coding guidelines (blessed by sabre on IRC)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82603 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c72efbeb42
commit
4136e7b90e
@ -37,8 +37,8 @@ using namespace llvm;
|
|||||||
|
|
||||||
bool LTOModule::isBitcodeFile(const void* mem, size_t length)
|
bool LTOModule::isBitcodeFile(const void* mem, size_t length)
|
||||||
{
|
{
|
||||||
return ( llvm::sys::IdentifyFileType((char*)mem, length)
|
return llvm::sys::IdentifyFileType((char*)mem, length)
|
||||||
== llvm::sys::Bitcode_FileType );
|
== llvm::sys::Bitcode_FileType;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LTOModule::isBitcodeFile(const char* path)
|
bool LTOModule::isBitcodeFile(const char* path)
|
||||||
@ -50,7 +50,7 @@ bool LTOModule::isBitcodeFileForTarget(const void* mem, size_t length,
|
|||||||
const char* triplePrefix)
|
const char* triplePrefix)
|
||||||
{
|
{
|
||||||
MemoryBuffer* buffer = makeBuffer(mem, length);
|
MemoryBuffer* buffer = makeBuffer(mem, length);
|
||||||
if ( buffer == NULL )
|
if (!buffer)
|
||||||
return false;
|
return false;
|
||||||
return isTargetMatch(buffer, triplePrefix);
|
return isTargetMatch(buffer, triplePrefix);
|
||||||
}
|
}
|
||||||
@ -71,12 +71,12 @@ bool LTOModule::isTargetMatch(MemoryBuffer* buffer, const char* triplePrefix)
|
|||||||
OwningPtr<ModuleProvider> mp(getBitcodeModuleProvider(buffer,
|
OwningPtr<ModuleProvider> mp(getBitcodeModuleProvider(buffer,
|
||||||
getGlobalContext()));
|
getGlobalContext()));
|
||||||
// on success, mp owns buffer and both are deleted at end of this method
|
// on success, mp owns buffer and both are deleted at end of this method
|
||||||
if ( !mp ) {
|
if (!mp) {
|
||||||
delete buffer;
|
delete buffer;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::string actualTarget = mp->getModule()->getTargetTriple();
|
std::string actualTarget = mp->getModule()->getTargetTriple();
|
||||||
return ( strncmp(actualTarget.c_str(), triplePrefix,
|
return (strncmp(actualTarget.c_str(), triplePrefix,
|
||||||
strlen(triplePrefix)) == 0);
|
strlen(triplePrefix)) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,7 +90,7 @@ LTOModule* LTOModule::makeLTOModule(const char* path,
|
|||||||
std::string& errMsg)
|
std::string& errMsg)
|
||||||
{
|
{
|
||||||
OwningPtr<MemoryBuffer> buffer(MemoryBuffer::getFile(path, &errMsg));
|
OwningPtr<MemoryBuffer> buffer(MemoryBuffer::getFile(path, &errMsg));
|
||||||
if ( !buffer )
|
if (!buffer)
|
||||||
return NULL;
|
return NULL;
|
||||||
return makeLTOModule(buffer.get(), errMsg);
|
return makeLTOModule(buffer.get(), errMsg);
|
||||||
}
|
}
|
||||||
@ -103,8 +103,8 @@ MemoryBuffer* LTOModule::makeBuffer(const void* mem, size_t length)
|
|||||||
{
|
{
|
||||||
const char* startPtr = (char*)mem;
|
const char* startPtr = (char*)mem;
|
||||||
const char* endPtr = startPtr+length;
|
const char* endPtr = startPtr+length;
|
||||||
if ( (((uintptr_t)endPtr & (sys::Process::GetPageSize()-1)) == 0)
|
if ((((uintptr_t)endPtr & (sys::Process::GetPageSize()-1)) == 0)
|
||||||
|| (*endPtr != 0) )
|
|| (*endPtr != 0))
|
||||||
return MemoryBuffer::getMemBufferCopy(startPtr, endPtr);
|
return MemoryBuffer::getMemBufferCopy(startPtr, endPtr);
|
||||||
else
|
else
|
||||||
return MemoryBuffer::getMemBuffer(startPtr, endPtr);
|
return MemoryBuffer::getMemBuffer(startPtr, endPtr);
|
||||||
@ -115,7 +115,7 @@ LTOModule* LTOModule::makeLTOModule(const void* mem, size_t length,
|
|||||||
std::string& errMsg)
|
std::string& errMsg)
|
||||||
{
|
{
|
||||||
OwningPtr<MemoryBuffer> buffer(makeBuffer(mem, length));
|
OwningPtr<MemoryBuffer> buffer(makeBuffer(mem, length));
|
||||||
if ( !buffer )
|
if (!buffer)
|
||||||
return NULL;
|
return NULL;
|
||||||
return makeLTOModule(buffer.get(), errMsg);
|
return makeLTOModule(buffer.get(), errMsg);
|
||||||
}
|
}
|
||||||
@ -148,7 +148,7 @@ LTOModule* LTOModule::makeLTOModule(MemoryBuffer* buffer,
|
|||||||
|
|
||||||
// parse bitcode buffer
|
// parse bitcode buffer
|
||||||
OwningPtr<Module> m(ParseBitcodeFile(buffer, getGlobalContext(), &errMsg));
|
OwningPtr<Module> m(ParseBitcodeFile(buffer, getGlobalContext(), &errMsg));
|
||||||
if ( !m )
|
if (!m)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
std::string Triple = m->getTargetTriple();
|
std::string Triple = m->getTargetTriple();
|
||||||
@ -157,7 +157,7 @@ LTOModule* LTOModule::makeLTOModule(MemoryBuffer* buffer,
|
|||||||
|
|
||||||
// find machine architecture for this module
|
// find machine architecture for this module
|
||||||
const Target* march = TargetRegistry::lookupTarget(Triple, errMsg);
|
const Target* march = TargetRegistry::lookupTarget(Triple, errMsg);
|
||||||
if ( march == NULL )
|
if (!march)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
// construct LTModule, hand over ownership of module and target
|
// construct LTModule, hand over ownership of module and target
|
||||||
@ -196,7 +196,7 @@ bool LTOModule::objcClassNameFromExpression(Constant* c, std::string& name)
|
|||||||
if (GlobalVariable* gvn = dyn_cast<GlobalVariable>(op)) {
|
if (GlobalVariable* gvn = dyn_cast<GlobalVariable>(op)) {
|
||||||
Constant* cn = gvn->getInitializer();
|
Constant* cn = gvn->getInitializer();
|
||||||
if (ConstantArray* ca = dyn_cast<ConstantArray>(cn)) {
|
if (ConstantArray* ca = dyn_cast<ConstantArray>(cn)) {
|
||||||
if ( ca->isCString() ) {
|
if (ca->isCString()) {
|
||||||
name = ".objc_class_name_" + ca->getAsString();
|
name = ".objc_class_name_" + ca->getAsString();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -212,9 +212,9 @@ void LTOModule::addObjCClass(GlobalVariable* clgv)
|
|||||||
if (ConstantStruct* c = dyn_cast<ConstantStruct>(clgv->getInitializer())) {
|
if (ConstantStruct* c = dyn_cast<ConstantStruct>(clgv->getInitializer())) {
|
||||||
// second slot in __OBJC,__class is pointer to superclass name
|
// second slot in __OBJC,__class is pointer to superclass name
|
||||||
std::string superclassName;
|
std::string superclassName;
|
||||||
if ( objcClassNameFromExpression(c->getOperand(1), superclassName) ) {
|
if (objcClassNameFromExpression(c->getOperand(1), superclassName)) {
|
||||||
NameAndAttributes info;
|
NameAndAttributes info;
|
||||||
if ( _undefines.find(superclassName.c_str()) == _undefines.end() ) {
|
if (_undefines.find(superclassName.c_str()) == _undefines.end()) {
|
||||||
const char* symbolName = ::strdup(superclassName.c_str());
|
const char* symbolName = ::strdup(superclassName.c_str());
|
||||||
info.name = ::strdup(symbolName);
|
info.name = ::strdup(symbolName);
|
||||||
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
||||||
@ -224,7 +224,7 @@ void LTOModule::addObjCClass(GlobalVariable* clgv)
|
|||||||
}
|
}
|
||||||
// third slot in __OBJC,__class is pointer to class name
|
// third slot in __OBJC,__class is pointer to class name
|
||||||
std::string className;
|
std::string className;
|
||||||
if ( objcClassNameFromExpression(c->getOperand(2), className) ) {
|
if (objcClassNameFromExpression(c->getOperand(2), className)) {
|
||||||
const char* symbolName = ::strdup(className.c_str());
|
const char* symbolName = ::strdup(className.c_str());
|
||||||
NameAndAttributes info;
|
NameAndAttributes info;
|
||||||
info.name = symbolName;
|
info.name = symbolName;
|
||||||
@ -245,9 +245,9 @@ void LTOModule::addObjCCategory(GlobalVariable* clgv)
|
|||||||
if (ConstantStruct* c = dyn_cast<ConstantStruct>(clgv->getInitializer())) {
|
if (ConstantStruct* c = dyn_cast<ConstantStruct>(clgv->getInitializer())) {
|
||||||
// second slot in __OBJC,__category is pointer to target class name
|
// second slot in __OBJC,__category is pointer to target class name
|
||||||
std::string targetclassName;
|
std::string targetclassName;
|
||||||
if ( objcClassNameFromExpression(c->getOperand(1), targetclassName) ) {
|
if (objcClassNameFromExpression(c->getOperand(1), targetclassName)) {
|
||||||
NameAndAttributes info;
|
NameAndAttributes info;
|
||||||
if ( _undefines.find(targetclassName.c_str()) == _undefines.end() ){
|
if (_undefines.find(targetclassName.c_str()) == _undefines.end()) {
|
||||||
const char* symbolName = ::strdup(targetclassName.c_str());
|
const char* symbolName = ::strdup(targetclassName.c_str());
|
||||||
info.name = ::strdup(symbolName);
|
info.name = ::strdup(symbolName);
|
||||||
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
||||||
@ -263,9 +263,9 @@ void LTOModule::addObjCCategory(GlobalVariable* clgv)
|
|||||||
void LTOModule::addObjCClassRef(GlobalVariable* clgv)
|
void LTOModule::addObjCClassRef(GlobalVariable* clgv)
|
||||||
{
|
{
|
||||||
std::string targetclassName;
|
std::string targetclassName;
|
||||||
if ( objcClassNameFromExpression(clgv->getInitializer(), targetclassName) ){
|
if (objcClassNameFromExpression(clgv->getInitializer(), targetclassName)) {
|
||||||
NameAndAttributes info;
|
NameAndAttributes info;
|
||||||
if ( _undefines.find(targetclassName.c_str()) == _undefines.end() ) {
|
if (_undefines.find(targetclassName.c_str()) == _undefines.end()) {
|
||||||
const char* symbolName = ::strdup(targetclassName.c_str());
|
const char* symbolName = ::strdup(targetclassName.c_str());
|
||||||
info.name = ::strdup(symbolName);
|
info.name = ::strdup(symbolName);
|
||||||
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
info.attributes = LTO_SYMBOL_DEFINITION_UNDEFINED;
|
||||||
@ -300,23 +300,23 @@ void LTOModule::addDefinedDataSymbol(GlobalValue* v, Mangler& mangler)
|
|||||||
// a class was missing.
|
// a class was missing.
|
||||||
// The following synthesizes the implicit .objc_* symbols for the linker
|
// The following synthesizes the implicit .objc_* symbols for the linker
|
||||||
// from the ObjC data structures generated by the front end.
|
// from the ObjC data structures generated by the front end.
|
||||||
if ( v->hasSection() /* && isTargetDarwin */ ) {
|
if (v->hasSection() /* && isTargetDarwin */) {
|
||||||
// special case if this data blob is an ObjC class definition
|
// special case if this data blob is an ObjC class definition
|
||||||
if ( v->getSection().compare(0, 15, "__OBJC,__class,") == 0 ) {
|
if (v->getSection().compare(0, 15, "__OBJC,__class,") == 0) {
|
||||||
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
||||||
addObjCClass(gv);
|
addObjCClass(gv);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// special case if this data blob is an ObjC category definition
|
// special case if this data blob is an ObjC category definition
|
||||||
else if ( v->getSection().compare(0, 18, "__OBJC,__category,") == 0 ) {
|
else if (v->getSection().compare(0, 18, "__OBJC,__category,") == 0) {
|
||||||
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
||||||
addObjCCategory(gv);
|
addObjCCategory(gv);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// special case if this data blob is the list of referenced classes
|
// special case if this data blob is the list of referenced classes
|
||||||
else if ( v->getSection().compare(0, 18, "__OBJC,__cls_refs,") == 0 ) {
|
else if (v->getSection().compare(0, 18, "__OBJC,__cls_refs,") == 0) {
|
||||||
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
if (GlobalVariable* gv = dyn_cast<GlobalVariable>(v)) {
|
||||||
addObjCClassRef(gv);
|
addObjCClassRef(gv);
|
||||||
}
|
}
|
||||||
@ -346,21 +346,21 @@ void LTOModule::addDefinedSymbol(GlobalValue* def, Mangler &mangler,
|
|||||||
uint32_t attr = align ? CountTrailingZeros_32(def->getAlignment()) : 0;
|
uint32_t attr = align ? CountTrailingZeros_32(def->getAlignment()) : 0;
|
||||||
|
|
||||||
// set permissions part
|
// set permissions part
|
||||||
if ( isFunction )
|
if (isFunction)
|
||||||
attr |= LTO_SYMBOL_PERMISSIONS_CODE;
|
attr |= LTO_SYMBOL_PERMISSIONS_CODE;
|
||||||
else {
|
else {
|
||||||
GlobalVariable* gv = dyn_cast<GlobalVariable>(def);
|
GlobalVariable* gv = dyn_cast<GlobalVariable>(def);
|
||||||
if ( (gv != NULL) && gv->isConstant() )
|
if (gv && gv->isConstant())
|
||||||
attr |= LTO_SYMBOL_PERMISSIONS_RODATA;
|
attr |= LTO_SYMBOL_PERMISSIONS_RODATA;
|
||||||
else
|
else
|
||||||
attr |= LTO_SYMBOL_PERMISSIONS_DATA;
|
attr |= LTO_SYMBOL_PERMISSIONS_DATA;
|
||||||
}
|
}
|
||||||
|
|
||||||
// set definition part
|
// set definition part
|
||||||
if ( def->hasWeakLinkage() || def->hasLinkOnceLinkage() ) {
|
if (def->hasWeakLinkage() || def->hasLinkOnceLinkage()) {
|
||||||
attr |= LTO_SYMBOL_DEFINITION_WEAK;
|
attr |= LTO_SYMBOL_DEFINITION_WEAK;
|
||||||
}
|
}
|
||||||
else if ( def->hasCommonLinkage()) {
|
else if (def->hasCommonLinkage()) {
|
||||||
attr |= LTO_SYMBOL_DEFINITION_TENTATIVE;
|
attr |= LTO_SYMBOL_DEFINITION_TENTATIVE;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -368,12 +368,12 @@ void LTOModule::addDefinedSymbol(GlobalValue* def, Mangler &mangler,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// set scope part
|
// set scope part
|
||||||
if ( def->hasHiddenVisibility() )
|
if (def->hasHiddenVisibility())
|
||||||
attr |= LTO_SYMBOL_SCOPE_HIDDEN;
|
attr |= LTO_SYMBOL_SCOPE_HIDDEN;
|
||||||
else if ( def->hasProtectedVisibility() )
|
else if (def->hasProtectedVisibility())
|
||||||
attr |= LTO_SYMBOL_SCOPE_PROTECTED;
|
attr |= LTO_SYMBOL_SCOPE_PROTECTED;
|
||||||
else if ( def->hasExternalLinkage() || def->hasWeakLinkage()
|
else if (def->hasExternalLinkage() || def->hasWeakLinkage()
|
||||||
|| def->hasLinkOnceLinkage() || def->hasCommonLinkage() )
|
|| def->hasLinkOnceLinkage() || def->hasCommonLinkage())
|
||||||
attr |= LTO_SYMBOL_SCOPE_DEFAULT;
|
attr |= LTO_SYMBOL_SCOPE_DEFAULT;
|
||||||
else
|
else
|
||||||
attr |= LTO_SYMBOL_SCOPE_INTERNAL;
|
attr |= LTO_SYMBOL_SCOPE_INTERNAL;
|
||||||
@ -388,7 +388,7 @@ void LTOModule::addDefinedSymbol(GlobalValue* def, Mangler &mangler,
|
|||||||
|
|
||||||
void LTOModule::addAsmGlobalSymbol(const char *name) {
|
void LTOModule::addAsmGlobalSymbol(const char *name) {
|
||||||
// only add new define if not already defined
|
// only add new define if not already defined
|
||||||
if ( _defines.count(name) == 0 )
|
if (_defines.count(name) == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// string is owned by _defines
|
// string is owned by _defines
|
||||||
@ -434,7 +434,7 @@ void LTOModule::addPotentialUndefinedSymbol(GlobalValue* decl, Mangler &mangler)
|
|||||||
void LTOModule::findExternalRefs(Value* value, Mangler &mangler) {
|
void LTOModule::findExternalRefs(Value* value, Mangler &mangler) {
|
||||||
|
|
||||||
if (GlobalValue* gv = dyn_cast<GlobalValue>(value)) {
|
if (GlobalValue* gv = dyn_cast<GlobalValue>(value)) {
|
||||||
if ( !gv->hasExternalLinkage() )
|
if (!gv->hasExternalLinkage())
|
||||||
addPotentialUndefinedSymbol(gv, mangler);
|
addPotentialUndefinedSymbol(gv, mangler);
|
||||||
// If this is a variable definition, do not recursively process
|
// If this is a variable definition, do not recursively process
|
||||||
// initializer. It might contain a reference to this variable
|
// initializer. It might contain a reference to this variable
|
||||||
@ -446,7 +446,7 @@ void LTOModule::findExternalRefs(Value* value, Mangler &mangler) {
|
|||||||
// GlobalValue, even with InternalLinkage type, may have operands with
|
// GlobalValue, even with InternalLinkage type, may have operands with
|
||||||
// ExternalLinkage type. Do not ignore these operands.
|
// ExternalLinkage type. Do not ignore these operands.
|
||||||
if (Constant* c = dyn_cast<Constant>(value)) {
|
if (Constant* c = dyn_cast<Constant>(value)) {
|
||||||
// Handle ConstantExpr, ConstantStruct, ConstantArry etc..
|
// Handle ConstantExpr, ConstantStruct, ConstantArry etc.
|
||||||
for (unsigned i = 0, e = c->getNumOperands(); i != e; ++i)
|
for (unsigned i = 0, e = c->getNumOperands(); i != e; ++i)
|
||||||
findExternalRefs(c->getOperand(i), mangler);
|
findExternalRefs(c->getOperand(i), mangler);
|
||||||
}
|
}
|
||||||
@ -454,7 +454,7 @@ void LTOModule::findExternalRefs(Value* value, Mangler &mangler) {
|
|||||||
|
|
||||||
void LTOModule::lazyParseSymbols()
|
void LTOModule::lazyParseSymbols()
|
||||||
{
|
{
|
||||||
if ( !_symbolsParsed ) {
|
if (!_symbolsParsed) {
|
||||||
_symbolsParsed = true;
|
_symbolsParsed = true;
|
||||||
|
|
||||||
// Use mangler to add GlobalPrefix to names to match linker names.
|
// Use mangler to add GlobalPrefix to names to match linker names.
|
||||||
@ -470,7 +470,7 @@ void LTOModule::lazyParseSymbols()
|
|||||||
|
|
||||||
// add functions
|
// add functions
|
||||||
for (Module::iterator f = _module->begin(); f != _module->end(); ++f) {
|
for (Module::iterator f = _module->begin(); f != _module->end(); ++f) {
|
||||||
if ( f->isDeclaration() )
|
if (f->isDeclaration())
|
||||||
addPotentialUndefinedSymbol(f, mangler);
|
addPotentialUndefinedSymbol(f, mangler);
|
||||||
else
|
else
|
||||||
addDefinedFunctionSymbol(f, mangler);
|
addDefinedFunctionSymbol(f, mangler);
|
||||||
@ -479,7 +479,7 @@ void LTOModule::lazyParseSymbols()
|
|||||||
// add data
|
// add data
|
||||||
for (Module::global_iterator v = _module->global_begin(),
|
for (Module::global_iterator v = _module->global_begin(),
|
||||||
e = _module->global_end(); v != e; ++v) {
|
e = _module->global_end(); v != e; ++v) {
|
||||||
if ( v->isDeclaration() )
|
if (v->isDeclaration())
|
||||||
addPotentialUndefinedSymbol(v, mangler);
|
addPotentialUndefinedSymbol(v, mangler);
|
||||||
else
|
else
|
||||||
addDefinedDataSymbol(v, mangler);
|
addDefinedDataSymbol(v, mangler);
|
||||||
@ -516,7 +516,7 @@ void LTOModule::lazyParseSymbols()
|
|||||||
it != _undefines.end(); ++it) {
|
it != _undefines.end(); ++it) {
|
||||||
// if this symbol also has a definition, then don't make an undefine
|
// if this symbol also has a definition, then don't make an undefine
|
||||||
// because it is a tentative definition
|
// because it is a tentative definition
|
||||||
if ( _defines.count(it->getKey()) == 0 ) {
|
if (_defines.count(it->getKey()) == 0) {
|
||||||
NameAndAttributes info = it->getValue();
|
NameAndAttributes info = it->getValue();
|
||||||
_symbols.push_back(info);
|
_symbols.push_back(info);
|
||||||
}
|
}
|
||||||
@ -535,7 +535,7 @@ uint32_t LTOModule::getSymbolCount()
|
|||||||
lto_symbol_attributes LTOModule::getSymbolAttributes(uint32_t index)
|
lto_symbol_attributes LTOModule::getSymbolAttributes(uint32_t index)
|
||||||
{
|
{
|
||||||
lazyParseSymbols();
|
lazyParseSymbols();
|
||||||
if ( index < _symbols.size() )
|
if (index < _symbols.size())
|
||||||
return _symbols[index].attributes;
|
return _symbols[index].attributes;
|
||||||
else
|
else
|
||||||
return lto_symbol_attributes(0);
|
return lto_symbol_attributes(0);
|
||||||
@ -544,7 +544,7 @@ lto_symbol_attributes LTOModule::getSymbolAttributes(uint32_t index)
|
|||||||
const char* LTOModule::getSymbolName(uint32_t index)
|
const char* LTOModule::getSymbolName(uint32_t index)
|
||||||
{
|
{
|
||||||
lazyParseSymbols();
|
lazyParseSymbols();
|
||||||
if ( index < _symbols.size() )
|
if (index < _symbols.size())
|
||||||
return _symbols[index].name;
|
return _symbols[index].name;
|
||||||
else
|
else
|
||||||
return NULL;
|
return NULL;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user