//===-- Language.cpp --------------------------------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "lldb/lldb-private.h"
#include "lldb/Core/Language.h"
#include "lldb/Core/Stream.h"
#include <string.h>
using namespace lldb;
using namespace lldb_private;
#define ENUM_TO_DCSTREAM(x) case x: s->PutCString(#x); return
struct LanguageStrings
{
const char * names[3];
};
static LanguageStrings
g_languages[] =
{
{ { "unknown" , NULL , NULL } },
{ { "c89" , NULL , "ISO C:1989" } },
{ { NULL , NULL , "K&R C" } },
{ { "ada83" , "Ada83" , "ISO Ada:1983" } },
{ { "c++" , "cxx" , "ISO C++:1998" } },
{ { "cobol74" , "Cobol74" , "ISO Cobol:1974" } },
{ { "cobol" , "Cobol85" , "ISO Cobol:1985." } },
{ { "f77" , "Fortran77" , "ISO Fortran 77." } },
{ { "f90" , "Fortran90" , "ISO Fortran 90" } },
{ { "pascal" , "Pascal83" , "ISO Pascal:1983" } },
{ { "modula2" , "Modula2" , "ISO Modula-2:1996" } },
{ { "java" , NULL , "Java" } },
{ { "c" , "C99" , "ISO C:1999" } },
{ { "ada" , "Ada95" , "ISO Ada:1995" } },
{ { "f95" , "Fortran95" , "ISO Fortran 95" } },
{ { "PLI" , NULL , "ANSI PL/I:1976" } },
{ { "objc" , NULL , "Objective-C" } },
{ { "objc++" , NULL , "Objective-C++" } },
{ { "upc" , NULL , "Unified Parallel C" } },
{ { "d" , NULL , "D" } },
{ { "python" , NULL , "Python" } }
};
static const size_t
g_num_languages = sizeof(g_languages)/sizeof(LanguageStrings);
Language::Language(LanguageType language) :
m_language (language)
{
}
Language::~Language()
{
}
LanguageType
Language::GetLanguage() const
{
return m_language;
}
void
Language::Clear ()
{
m_language = eLanguageTypeUnknown;
}
void
Language::SetLanguage(LanguageType language)
{
m_language = language;
}
bool
Language::SetLanguageFromCString(const char *language_cstr)
{
size_t i, desc_idx;
const char *name;
// First check the most common name for the languages
for (desc_idx=lldb::eDescriptionLevelBrief; desc_idx<kNumDescriptionLevels; ++desc_idx)
{
for (i=0; i<g_num_languages; ++i)
{
name = g_languages[i].names[desc_idx];
if (name == NULL)
continue;
if (::strcasecmp (language_cstr, name) == 0)
{
m_language = (LanguageType)i;
return true;
}
}
}
m_language = eLanguageTypeUnknown;
return false;
}
const char *
Language::AsCString (lldb::DescriptionLevel level) const
{
if (m_language < g_num_languages && level < kNumDescriptionLevels)
{
const char *name = g_languages[m_language].names[level];
if (name)
return name;
else if (level + 1 < kNumDescriptionLevels)
return AsCString ((lldb::DescriptionLevel)(level + 1));
else
return NULL;
}
return NULL;
}
void
Language::Dump(Stream *s) const
{
GetDescription(s, lldb::eDescriptionLevelVerbose);
}
void
Language::GetDescription (Stream *s, lldb::DescriptionLevel level) const
{
const char *lang_cstr = AsCString(level);
if (lang_cstr)
s->PutCString(lang_cstr);
else
s->Printf("Language(language = 0x%4.4x)", m_language);
}
Stream&
lldb_private::operator << (Stream& s, const Language& language)
{
language.Dump(&s);
return s;
}