本文整理汇总了C++中LogManager::DebugLog方法的典型用法代码示例。如果您正苦于以下问题:C++ LogManager::DebugLog方法的具体用法?C++ LogManager::DebugLog怎么用?C++ LogManager::DebugLog使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LogManager
的用法示例。
在下文中一共展示了LogManager::DebugLog方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
bool MSVC10Loader::DoCreateConfigurations()
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
bool bResult = false;
// create the project targets
for (HashProjectsConfs::iterator it = m_pc.begin(); it != m_pc.end(); ++it)
{
ProjectBuildTarget* bt = m_pProject->AddBuildTarget(it->second.sName);
if (bt)
{
bt->SetCompilerID(m_pProject->GetCompilerID());
bt->AddPlatform(spAll); // target all platforms, SupportedPlatforms enum in "globals.h"
TargetType tt = ttExecutable;
if (it->second.TargetType == _T("Application")) tt = ttExecutable;
else if (it->second.TargetType == _T("Console")) tt = ttConsoleOnly;
else if (it->second.TargetType == _T("StaticLibrary")) tt = ttStaticLib;
else if (it->second.TargetType == _T("DynamicLibrary")) tt = ttDynamicLib;
else
pMsg->DebugLog(_("Import; Unsupported target type: ") + it->second.TargetType);
bt->SetTargetType(tt); // executable by default, TargetType enum in "globals.h"
it->second.bt = bt; // apply
pMsg->DebugLog(_("Created project build target: ") + it->second.sName);
bResult = true; // at least one config imported
}
}
return bResult;
}
示例2: doc
bool MSVC10Loader::Open(const wxString& filename)
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
m_ConvertSwitches = m_pProject->GetCompilerID().IsSameAs(_T("gcc"));
m_ProjectName = wxFileName(filename).GetName();
pMsg->DebugLog(F(_("Importing MSVC 10.xx project: %s"), filename.wx_str()));
TiXmlDocument doc(filename.mb_str());
if (!doc.LoadFile())
return false;
pMsg->DebugLog(_("Parsing project file..."));
const TiXmlElement* root = doc.FirstChildElement("Project");
if (!root)
{
pMsg->DebugLog(_("Not a valid MS Visual Studio project file..."));
return false;
}
// initialisation of the project
m_pProject->ClearAllProperties();
m_pProject->SetModified(true);
bool bResult = GetProjectGlobals(root) // get project name & type
// get the project list of configuration => 1 configuration = 1 build target in CodeBlocks
&& GetProjectConfigurations(root);
if (!bResult)
{
pMsg->DebugLog(_("Could not obtain project configurations."));
return false;
}
if ( !DoSelectConfigurations() )
return true; // user cancelled
if ( !DoCreateConfigurations() )
{
pMsg->DebugLog(_("Failed to create configurations in the project."));
return false;
}
// get the project list of files and add them to the targets
bResult = GetProjectConfigurationFiles(root)
// get the project/target list of includes and add them to the targets
&& GetProjectIncludes(root)
// get the project/target specific settings
&& GetTargetSpecific(root);
return bResult;
}
示例3: doc
bool MSVC7Loader::Open(const wxString& filename)
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg)
return false;
/* NOTE (mandrav#1#): not necessary to ask for switches conversion... */
m_ConvertSwitches = m_pProject->GetCompilerID().IsSameAs(_T("gcc"));
m_ProjectName = wxFileName(filename).GetName();
pMsg->DebugLog(F(_T("Importing MSVC 7.xx project: %s"), filename.wx_str()));
TiXmlDocument doc(filename.mb_str());
if (!doc.LoadFile())
return false;
pMsg->DebugLog(_T("Parsing project file..."));
TiXmlElement* root;
root = doc.FirstChildElement("VisualStudioProject");
if (!root)
{
pMsg->DebugLog(_T("Not a valid MS Visual Studio project file..."));
return false;
}
if (strcmp(root->Attribute("ProjectType"), "Visual C++") != 0)
{
pMsg->DebugLog(_T("Project is not Visual C++..."));
return false;
}
wxString ver = cbC2U(root->Attribute("Version"));
if (ver.IsSameAs(_T("7.0")) || ver.IsSameAs(_T("7.00"))) m_Version = 70;
if (ver.IsSameAs(_T("7.1")) || ver.IsSameAs(_T("7.10"))) m_Version = 71;
if (ver.IsSameAs(_T("8.0")) || ver.IsSameAs(_T("8.00"))) m_Version = 80;
if ((m_Version!=70) && (m_Version!=71))
{
// seems to work with visual 8 too ;)
pMsg->DebugLog(F(_T("Project version is '%s'. Although this loader was designed for version 7.xx, will try to import..."), ver.wx_str()));
}
m_pProject->ClearAllProperties();
m_pProject->SetModified(true);
m_pProject->SetTitle(cbC2U(root->Attribute("Name")));
// delete all targets of the project (we 'll create new ones from the imported configurations)
while (m_pProject->GetBuildTargetsCount())
m_pProject->RemoveBuildTarget(0);
return DoSelectConfiguration(root);
}
示例4: while
/** get project name, type and GUID
* \param root : the root node of the XML project file (<Project >
**/
bool MSVC10Loader::GetProjectGlobals(const TiXmlElement* root)
{
if (!root) return false;
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
bool bResult = false;
const char* title = root->Attribute("NoName");
if (title) m_pProject->SetTitle(cbC2U(title));
// parse all global parameters
const TiXmlElement* prop = root->FirstChildElement("PropertyGroup");
while (prop)
{
const char* attr = prop->Attribute("Label");
if (!attr) { prop = prop->NextSiblingElement(); continue; }
wxString label = cbC2U(attr);
if (label.MakeUpper().IsSameAs(_T("GLOBALS")))
{
const TiXmlElement* pGUID = prop->FirstChildElement("ProjectGuid");
if (pGUID) m_ProjectGUID = GetText(pGUID);
const TiXmlElement* pProjectType = prop->FirstChildElement("Keyword");
if (pProjectType) m_ProjectType = GetText(pProjectType);
const TiXmlElement* pProjectName = prop->FirstChildElement("RootNamespace");
if (pProjectName) m_ProjectName = GetText(pProjectName);
// logging
pMsg->DebugLog(wxString::Format(_("Project global properties: GUID=%s, Type=%s, Name=%s"),
m_ProjectGUID.wx_str(), m_ProjectType.wx_str(), m_ProjectName.wx_str()));
bResult = true; // got everything we need
break; // exit loop
}
prop = prop->NextSiblingElement();
}
if (!bResult)
pMsg->DebugLog(_("Failed to find global project properties, using default one."));
m_pProject->SetTitle(m_ProjectName);
return bResult;
}
示例5: Open
bool ProjectTemplateLoader::Open(const wxString& filename)
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg)
return false;
// pMsg->DebugLog(_T("Reading template file %s"), filename.c_str());
TiXmlDocument doc(filename.mb_str());
if (!doc.LoadFile())
return false;
TiXmlElement* root;
root = doc.FirstChildElement("CodeBlocks_template_file");
if (!root)
{
// old tag
root = doc.FirstChildElement("Em::Blocks_template_file");
if (!root)
{
pMsg->DebugLog(_T("Not a valid Em::Blocks template file..."));
return false;
}
}
DoTemplate(root);
return true;
}
示例6: dlg
bool MSVC10Loader::DoSelectConfigurations()
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
if ( ImportersGlobals::ImportAllTargets ) // by default, all targets are imported
return true;
// ask the user to select a configuration - multiple choice ;)
wxArrayString configurations;
for (HashProjectsConfs::iterator it = m_pc.begin(); it != m_pc.end(); ++it)
configurations.Add(it->second.sName);
MultiSelectDlg dlg(0, configurations, true, _("Select configurations to import:"), m_pProject->GetTitle());
PlaceWindow(&dlg);
if (dlg.ShowModal() == wxID_CANCEL)
{
pMsg->DebugLog(_("Cancelled.."));
return false;
}
wxArrayString asSelectedStrings = dlg.GetSelectedStrings();
if (asSelectedStrings.GetCount() < 1)
{
pMsg->DebugLog(_("No selection -> cancelled."));
return false;
}
for (HashProjectsConfs::iterator it = m_pc.begin(); it != m_pc.end(); )
{
if (asSelectedStrings.Index(it->second.sName)==wxNOT_FOUND)
m_pc.erase(it++); // remove deselected
else
++it;
}
return true;
}
示例7: SubstituteConfigMacros
bool MSVC10Loader::GetProjectIncludes(const TiXmlElement* root)
{
if (!root) return false;
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
bool bResult = false;
// parse all global parameters
const TiXmlElement* prop = root->FirstChildElement("PropertyGroup");
for (; prop; prop=prop->NextSiblingElement("PropertyGroup"))
{
const char* attr = prop->Attribute("Condition");
if (!attr) continue;
wxString conf = cbC2U(attr);
for (HashProjectsConfs::iterator it=m_pc.begin(); it!=m_pc.end(); ++it)
{
wxString sName = it->second.sName;
wxString sConf = SubstituteConfigMacros(conf);
if (sConf.IsSameAs(sName))
{
// $(VCInstallDir)include , $(VCInstallDir)atlmfc\include , $(WindowsSdkDir)include , $(FrameworkSDKDir)\include
const TiXmlElement* cinc = prop->FirstChildElement("IncludePath");
wxArrayString cdirs = GetArrayPaths(cinc, m_pc[sName]);
for (size_t j=0; j<cdirs.Count(); ++j)
{
ProjectBuildTarget* bt = m_pc[sName].bt;
if (bt) bt->AddIncludeDir(cdirs.Item(j));
}
// $(VCInstallDir)lib , $(VCInstallDir)atlmfc\lib , $(WindowsSdkDir)lib , $(FrameworkSDKDir)\lib
const TiXmlElement* linc = prop->FirstChildElement("LibraryPath");
wxArrayString ldirs = GetArrayPaths(linc, m_pc[sName]);
for (size_t j=0; j<ldirs.Count(); ++j)
{
ProjectBuildTarget* bt = m_pc[sName].bt;
if (bt) bt->AddLibDir(ldirs.Item(j));
}
bResult = true; // got something
}
}
}
if (!bResult)
pMsg->DebugLog(_("Failed to find any includes in the project...?!"));
return bResult;
}
示例8: Open
// IMPORTANT! We have to be careful of what to unicode and what not to.
// TinyXML must use NON-unicode strings!
// ----------------------------------------------------------------------------
bool BrowseTrackerLayout::Open(const wxString& filename, FileBrowse_MarksHash& m_FileBrowse_MarksArchive , FileBrowse_MarksHash& m_EdBook_MarksArchive )
// ----------------------------------------------------------------------------
{
TiXmlDocument doc;
if (!TinyXML::LoadDocument(filename, &doc))
return false;
ProjectManager* pMan = Manager::Get()->GetProjectManager();
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMan || !pMsg)
return false;
TiXmlElement* root;
TiXmlElement* elem;
wxString fname;
ProjectFile* pf;
root = doc.FirstChildElement("BrowseTracker_layout_file");
if (!root)
{
// old tag
root = doc.FirstChildElement("BrowseTracker_layout_file");
if (!root)
{
pMsg->DebugLog(_T("Not a valid BrowseTracker layout file..."));
return false;
}
}
elem = root->FirstChildElement("ActiveTarget");
if (elem)
{
if (elem->Attribute("name"))
;//m_pProject->SetActiveBuildTarget(cbC2U(elem->Attribute("name")));
}
elem = root->FirstChildElement("File");
if (!elem)
{
//pMsg->DebugLog(_T("No 'File' element in file..."));
return false;
}
while (elem)
{
//pMsg->DebugLog(elem->Value());
fname = cbC2U(elem->Attribute("name"));
if (fname.IsEmpty())
{
//pMsg->DebugLog(_T("'File' node exists, but no filename?!?"));
pf = 0L;
}
else
pf = m_pProject->GetFileByFilename(fname);
if (pf)
{
//pf->editorOpen = false;
//pf->editorPos = 0;
//pf->editorTopLine = 0;
int open = 0;
int top = 0;
int tabpos = 0;
if (elem->QueryIntAttribute("open", &open) == TIXML_SUCCESS)
;//pf->editorOpen = open != 0;
if (elem->QueryIntAttribute("top", &top) == TIXML_SUCCESS)
{
if(top)
m_TopProjectFile = pf;
}
if (elem->QueryIntAttribute("tabpos", &tabpos) == TIXML_SUCCESS)
;//pf->editorTabPos = tabpos;
TiXmlElement* cursor = elem->FirstChildElement();
if (cursor)
{
int pos = 0;
int topline = 0;
if (cursor->QueryIntAttribute("position", &pos) == TIXML_SUCCESS)
;//pf->editorPos = pos;
if (cursor->QueryIntAttribute("topLine", &topline) == TIXML_SUCCESS)
;//pf->editorTopLine = topline;
}
#if defined(LOGGING)
///LOGIT( _T("Open Layout processing for[%s]"),fname.c_str() );
#endif
TiXmlElement* browsemarks = cursor->NextSiblingElement("BrowseMarks");
///if (not browsemarks)
/// LOGIT( _T("OPEN LAYOUT failed for BrowseMarks") );
if (browsemarks)
{
wxString marksString = cbC2U(browsemarks->Attribute("positions"));
#if defined(LOGGING)
////LOGIT( _T("OPEN_LAYOUT BROWSEMarksStrng[%s][%s]"), fname.c_str(), marksString.c_str() );
//.........这里部分代码省略.........
示例9: ConvertToWxString
bool EncodingDetector::ConvertToWxString(const wxByte* buffer, size_t size)
{
LogManager* logmgr = Manager::Get()->GetLogManager();
wxString logmsg;
if (!buffer || size == 0)
{
if (m_UseLog)
{
logmsg.Printf(_T("Encoding conversion has failed (buffer is empty)!"));
logmgr->DebugLog(logmsg);
}
return false; // Nothing we can do...
}
if (m_BOMSizeInBytes > 0)
{
for (int i = 0; i < m_BOMSizeInBytes; ++i)
buffer++;
}
size_t outlen = 0;
/* NOTE (Biplab#5#): FileManager returns a buffer with 4 extra NULL chars appended.
But the buffer size is returned sans the NULL chars */
wxWCharBuffer wideBuff;
// if possible use the special conversion-routines, they are much faster than wxCSCov (at least on linux)
if ( m_Encoding == wxFONTENCODING_UTF7 )
{
wxMBConvUTF7 conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else if ( m_Encoding == wxFONTENCODING_UTF8 )
{
wxMBConvUTF8 conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else if ( m_Encoding == wxFONTENCODING_UTF16BE )
{
wxMBConvUTF16BE conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else if ( m_Encoding == wxFONTENCODING_UTF16LE )
{
wxMBConvUTF16LE conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else if ( m_Encoding == wxFONTENCODING_UTF32BE )
{
wxMBConvUTF32BE conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else if ( m_Encoding == wxFONTENCODING_UTF32LE )
{
wxMBConvUTF32LE conv;
wideBuff = conv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
}
else
{
// try wxEncodingConverter first, even it it only works for
// wxFONTENCODING_ISO8859_1..15, wxFONTENCODING_CP1250..1257 and wxFONTENCODING_KOI8
// but it's much, much faster than wxCSConv (at least on Linux)
wxEncodingConverter conv;
wchar_t* tmp = new wchar_t[size + 4 - m_BOMSizeInBytes];
if ( conv.Init(m_Encoding, wxFONTENCODING_UNICODE)
&& conv.Convert((const char*)buffer, tmp) )
{
wideBuff = tmp;
outlen = size + 4 - m_BOMSizeInBytes; // should be correct, because Convert has returned true
if (m_UseLog && outlen>0)
{
logmsg.Printf(_T("Conversion succeeded using wxEncodingConverter "
"(buffer size = %lu, converted size = %lu."), static_cast<unsigned long>(size), static_cast<unsigned long>(outlen));
logmgr->DebugLog(logmsg);
}
}
else
{
// try wxCSConv, if nothing else works
wxCSConv csconv(m_Encoding);
if (csconv.IsOk())
{
wideBuff = csconv.cMB2WC((const char*)buffer, size + 4 - m_BOMSizeInBytes, &outlen);
if (m_UseLog && outlen>0)
{
logmsg.Printf(_T("Conversion succeeded using wxCSConv "
"(buffer size = %lu, converted size = %lu."), static_cast<unsigned long>(size), static_cast<unsigned long>(outlen));
logmgr->DebugLog(logmsg);
}
}
}
delete [] tmp;
}
if (outlen>0)
{
m_ConvStr = wxString(wideBuff);
return true; // Done.
//.........这里部分代码省略.........
示例10: tmp
bool MSVC10Loader::Open(const wxString& filename)
{
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMsg) return false;
m_ConvertSwitches = m_pProject->GetCompilerID().IsSameAs(_T("gcc"));
m_ProjectName = wxFileName(filename).GetName();
if (!MSVC7WorkspaceLoader::g_WorkspacePath.IsEmpty())
{
wxFileName tmp(MSVC7WorkspaceLoader::g_WorkspacePath); tmp.MakeRelativeTo(m_pProject->GetBasePath());
m_WorkspacePath = tmp.GetPathWithSep();
}
pMsg->DebugLog(F(_("Importing MSVC 10+ project: %s"), filename.wx_str()));
TiXmlDocument doc(filename.mb_str());
if (!doc.LoadFile())
return false;
pMsg->DebugLog(_("Parsing project file..."));
const TiXmlElement* root = doc.FirstChildElement("Project");
if (!root)
{
pMsg->DebugLog(_("Not a valid MS Visual Studio project file..."));
return false;
}
// initialisation of the project
m_pProject->ClearAllProperties();
m_pProject->SetModified(true);
if (!m_ConvertSwitches)
{
// m_pProject->AddCompilerOption(_T("/EHsc")); // default, "/EHs /EHc" works as well
m_pProject->AddLinkerOption(_T("/pdb:$(TARGET_OUTPUT_DIR)$(TARGET_OUTPUT_BASENAME).pdb"));
m_pProject->AddIncludeDir(_T(".")); // some projects require it. Implicit with Visual Studio
m_pProject->AddResourceIncludeDir(_T("."));
}
bool bResult = GetProjectGlobals(root) // get project name & type
&& GetProjectConfigurations(root); // get the project list of configuration => 1 configuration = 1 build target in CodeBlocks
if (!bResult)
{
pMsg->DebugLog(_("Could not obtain project configurations."));
return false;
}
if ( !DoSelectConfigurations() )
return true; // user cancelled
if ( !DoCreateConfigurations() )
{
pMsg->DebugLog(_("Failed to create configurations in the project."));
return false;
}
bResult = GetProjectConfigurationFiles(root) // get the project list of files and add them to the targets
&& GetProjectIncludes(root) // get the project/target list of includes and add them to the targets
&& GetTargetSpecific(root); // get the project/target specific settings
return bResult;
}
示例11: Open
bool ProjectLayoutLoader::Open(const wxString& filename)
{
TiXmlDocument doc;
if (!TinyXML::LoadDocument(filename, &doc))
return false;
ProjectManager* pMan = Manager::Get()->GetProjectManager();
LogManager* pMsg = Manager::Get()->GetLogManager();
if (!pMan || !pMsg)
return false;
TiXmlElement* root;
TiXmlElement* elem;
wxString fname;
ProjectFile* pf;
root = doc.FirstChildElement("CodeBlocks_layout_file");
if (!root)
{
// old tag
root = doc.FirstChildElement("Code::Blocks_layout_file");
if (!root)
{
pMsg->DebugLog(_T("Not a valid Code::Blocks layout file..."));
return false;
}
}
int major = 0;
int minor = 0;
TiXmlElement* version = root->FirstChildElement("FileVersion");
// don't show messages if we 're running a batch build (i.e. no gui)
if (!Manager::IsBatchBuild() && version)
{
version->QueryIntAttribute("major", &major);
version->QueryIntAttribute("minor", &minor);
if (major >= PROJECT_LAYOUT_FILE_VERSION_MAJOR && minor > PROJECT_LAYOUT_FILE_VERSION_MINOR)
{
pMsg->DebugLog(F(_T("Project layout file version is > %d.%d. Trying to load..."), PROJECT_LAYOUT_FILE_VERSION_MAJOR, PROJECT_LAYOUT_FILE_VERSION_MINOR));
AnnoyingDialog dlg(_("Project layout file format is newer/unknown"),
F(_("This project layout file was saved with a newer version of Code::Blocks.\n"
"Will try to load, but you might see unexpected results.\n"
"In this case close the project, delete %s and reopen the project."),filename.wx_str()),
wxART_WARNING,
AnnoyingDialog::OK);
dlg.ShowModal();
}
else
{
// use one message for all changes
wxString msg;
wxString warn_msg;
if (major == 0 && minor == 0)
{
msg << _("0.0 (unversioned) to 1.0:\n");
msg << _(" * save editor-pane layout and order.\n");
msg << _("\n");
}
if (!msg.IsEmpty())
{
msg.Prepend(wxString::Format(_("Project layout file format is older (%d.%d) than the current format (%d.%d).\n"
"The file will automatically be upgraded on close.\n"
"But please read the following list of changes, as some of them\n"
"might not automatically convert existing (old) settings.\n"
"If you don't understand what a change means, you probably don't\n"
"use that feature so you don't have to worry about it.\n\n"
"List of changes:\n"),
major,
minor,
PROJECT_LAYOUT_FILE_VERSION_MAJOR,
PROJECT_LAYOUT_FILE_VERSION_MINOR));
AnnoyingDialog dlg(_("Project layout file format changed"),
msg,
wxART_INFORMATION,
AnnoyingDialog::OK);
dlg.ShowModal();
}
if (!warn_msg.IsEmpty())
{
warn_msg.Prepend(_("!!! WARNING !!!\n\n"));
AnnoyingDialog dlg(_("Project layout file upgrade warning"),
warn_msg,
wxART_WARNING,
AnnoyingDialog::OK);
dlg.ShowModal();
}
}
}
elem = root->FirstChildElement("ActiveTarget");
if (elem)
{
if (elem->Attribute("name"))
m_pProject->SetActiveBuildTarget(cbC2U(elem->Attribute("name")));
}
//.........这里部分代码省略.........