本文整理匯總了C++中ASSERT_MESSAGE函數的典型用法代碼示例。如果您正苦於以下問題:C++ ASSERT_MESSAGE函數的具體用法?C++ ASSERT_MESSAGE怎麽用?C++ ASSERT_MESSAGE使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了ASSERT_MESSAGE函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: ASSERT_MESSAGE
void FaceInstance::update_move_planepts_vertex2(std::size_t index, std::size_t other)
{
ASSERT_MESSAGE(index < m_face->getWinding().size(), "select_vertex: invalid index");
const std::size_t opposite = m_face->getWinding().opposite(index, other);
if (triangle_reversed(index, other, opposite)) {
std::swap(index, other);
}
ASSERT_MESSAGE(
triangles_same_winding(
m_face->getWinding()[opposite].vertex,
m_face->getWinding()[index].vertex,
m_face->getWinding()[other].vertex,
m_face->getWinding()[0].vertex,
m_face->getWinding()[1].vertex,
m_face->getWinding()[2].vertex
),
"update_move_planepts_vertex2: error"
)
m_face->m_move_planepts[0] = m_face->getWinding()[opposite].vertex;
m_face->m_move_planepts[1] = m_face->getWinding()[index].vertex;
m_face->m_move_planepts[2] = m_face->getWinding()[other].vertex;
planepts_quantise(m_face->m_move_planepts, GRID_MIN); // winding points are very inaccurate
}
示例2: Buttons_release
bool Buttons_release(ButtonMask& buttons, guint button, guint state)
{
if(buttons != 0 && bitfield_disable(buttons, ButtonMask_for_event_button(button)) == 0)
{
ASSERT_MESSAGE(!g_accel_enabled, "Buttons_release: accelerators are enabled");
g_accel_enabled = true;
for(WindowSet::iterator i = g_accel_windows.begin(); i != g_accel_windows.end(); ++i)
{
GtkWindow* toplevel = *i;
ASSERT_MESSAGE(!window_has_accel(toplevel), "ERROR");
ASSERT_MESSAGE(GTK_WIDGET_TOPLEVEL(toplevel), "enabling accel for non-toplevel window");
gtk_window_add_accel_group(toplevel, global_accel);
#if 0
globalOutputStream() << reinterpret_cast<unsigned int>(toplevel) << ": enabled global accelerators\n";
#endif
#if 0
accel_group_test(toplevel, global_accel);
#endif
}
GlobalQueuedAccelerators_commit();
}
buttons = bitfield_disable(buttons, ButtonMask_for_event_button(button));
#if 0
globalOutputStream() << "Buttons_release: ";
print_buttons(buttons);
#endif
return false;
}
示例3: Buttons_press
bool Buttons_press(ButtonMask& buttons, guint button, guint state)
{
if(buttons == 0 && bitfield_enable(buttons, ButtonMask_for_event_button(button)) != 0)
{
ASSERT_MESSAGE(g_accel_enabled, "Buttons_press: accelerators not enabled");
g_accel_enabled = false;
for(WindowSet::iterator i = g_accel_windows.begin(); i != g_accel_windows.end(); ++i)
{
GtkWindow* toplevel = *i;
ASSERT_MESSAGE(window_has_accel(toplevel), "ERROR");
ASSERT_MESSAGE(GTK_WIDGET_TOPLEVEL(toplevel), "disabling accel for non-toplevel window");
gtk_window_remove_accel_group(toplevel, global_accel);
#if 0
globalOutputStream() << reinterpret_cast<unsigned int>(toplevel) << ": disabled global accelerators\n";
#endif
#if 0
accel_group_test(toplevel, global_accel);
#endif
}
}
buttons = bitfield_enable(buttons, ButtonMask_for_event_button(button));
#if 0
globalOutputStream() << "Buttons_press: ";
print_buttons(buttons);
#endif
return false;
}
示例4: ASSERT_MESSAGE
void CCBinaryFile::setPosition(const uint pos)
{
ASSERT_MESSAGE( m_File != NULL, "File::Position(...) : ERROR! File not open" );
ASSERT_MESSAGE( pos < m_Size, "File::Position(...) : ERROR! Invalid file position" );
fseek( m_File, pos, SEEK_SET );
m_Position = pos;
}
示例5: logMsg
void example_test_class::test_assert_message()
{
logMsg("ASSERT_MESSAGE example");
/*
Wrapper of
void assertTrue(const char * msg, bool expression
, const char* file, int line);
*/
ASSERT_MESSAGE(1 < 2, "ASSERT_MESSAGE example (true)");
ASSERT_MESSAGE(1 > 2, "ASSERT_MESSAGE example (fail) - EXPECTED failure");
}
示例6: ASSERT
bool Cx_CfgRecord::AddFieldValue(const std::wstring& wstrField,
const std::wstring& wstrValue)
{
ASSERT(IsValid() && !wstrValue.empty());
ASSERT_MESSAGE(DbFunc::IsDBName(wstrField.c_str()), "Invalid field name.");
ASSERT_MESSAGE(!HasFieldValue(wstrField), "The field has already set value.");
m_arrValue.push_back(FieldValue(wstrField, wstrValue));
return true;
}
示例7: seteuid
void ApplicationContextImpl::initialise(int argc, char* argv[]) {
// Give away unnecessary root privileges.
// Important: must be done before calling gtk_init().
char *loginname;
struct passwd *pw;
seteuid(getuid());
if (geteuid() == 0 &&
(loginname = getlogin()) != 0 &&
(pw = getpwnam(loginname)) != 0)
{
setuid(pw->pw_uid);
}
initArgs(argc, argv);
// Initialise the home directory path
std::string home = os::standardPathWithSlash(g_get_home_dir()) + ".darkradiant/";
os::makeDirectory(home);
_homePath = home;
{
char real[PATH_MAX];
_appPath = getexename(real, argv);
ASSERT_MESSAGE(!_appPath.empty(), "failed to deduce app path");
}
// Initialise the relative paths
initPaths();
}
示例8: ASSERT_MESSAGE
void Dialog::Destroy()
{
ASSERT_MESSAGE(m_window != 0, "dialog cannot be destroyed");
gtk_widget_destroy(GTK_WIDGET(m_window));
m_window = 0;
}
示例9: unrealise
~ModelResource ()
{
if (realised()) {
unrealise();
}
ASSERT_MESSAGE(!realised(), "ModelResource::~ModelResource: resource reference still realised: " << m_name);
}
示例10: Winding_Opposite
std::size_t Winding_Opposite(const Winding& winding, const std::size_t index, const std::size_t other)
{
ASSERT_MESSAGE(index < winding.numpoints && other < winding.numpoints, "Winding_Opposite: index out of range");
double dist_best = 0;
std::size_t index_best = c_brush_maxFaces;
Ray edge(ray_for_points(winding[index].vertex, winding[other].vertex));
for(std::size_t i=0; i<winding.numpoints; ++i)
{
if(i == index || i == other)
{
continue;
}
double dist_squared = ray_squared_distance_to_point(edge, winding[i].vertex);
if(dist_squared > dist_best)
{
dist_best = dist_squared;
index_best = i;
}
}
return index_best;
}
示例11: ASSERT_MESSAGE
void CCJNI::BillingRequestPurchase(const char *productID, CCLambdaCallback *callback)
{
if( billingCallback != NULL )
{
delete billingCallback;
}
billingCallback = callback;
CCText androidProductID = productID;
androidProductID.toLowercase();
// JNI Java call
JNIEnv *jEnv = gView->jniEnv;
jclass jniClass = jEnv->FindClass( "com/android2c/CCJNI" );
ASSERT_MESSAGE( jniClass != 0, "Could not find Java class." );
// Get the method ID of our method "startVideoView", which takes one parameter of type string, and returns void
static jmethodID mid = jEnv->GetStaticMethodID( jniClass, "BillingRequestPurchase", "(Ljava/lang/String;)V" );
ASSERT( mid != 0 );
// Call the function
jstring javaURL = jEnv->NewStringUTF( androidProductID.buffer );
jEnv->CallStaticVoidMethod( jniClass, mid, javaURL );
//jEnv->DeleteLocalRef( javaURL );
}
示例12: mergeSelectedBrushes
void mergeSelectedBrushes(const cmd::ArgumentList& args)
{
// Get the current selection
BrushPtrVector brushes = selection::algorithm::getSelectedBrushes();
if (brushes.empty()) {
rMessage() << _("CSG Merge: No brushes selected.") << std::endl;
wxutil::Messagebox::ShowError(_("CSG Merge: No brushes selected."));
return;
}
if (brushes.size() < 2) {
rMessage() << "CSG Merge: At least two brushes have to be selected.\n";
wxutil::Messagebox::ShowError("CSG Merge: At least two brushes have to be selected.");
return;
}
rMessage() << "CSG Merge: Merging " << brushes.size() << " brushes." << std::endl;
UndoableCommand undo("mergeSelectedBrushes");
// Take the last selected node as reference for layers and parent
scene::INodePtr merged = GlobalSelectionSystem().ultimateSelected();
scene::INodePtr parent = merged->getParent();
assert(parent != NULL);
// Create a new BrushNode
scene::INodePtr node = GlobalBrushCreator().createBrush();
// Insert the newly created brush into the (same) parent entity
parent->addChildNode(node);
// Move the new brush to the same layers as the merged one
node->assignToLayers(merged->getLayers());
// Get the contained brush
Brush* brush = Node_getBrush(node);
// Attempt to merge the selected brushes into the new one
if (!Brush_merge(*brush, brushes, true))
{
rWarning() << "CSG Merge: Failed - result would not be convex." << std::endl;
return;
}
ASSERT_MESSAGE(!brush->empty(), "brush left with no faces after merge");
// Remove the original brushes
for (BrushPtrVector::iterator i = brushes.begin(); i != brushes.end(); ++i)
{
scene::removeNodeFromParent(*i);
}
// Select the new brush
Node_setSelected(node, true);
rMessage() << "CSG Merge: Succeeded." << std::endl;
SceneChangeNotify();
}
示例13: ASSERT_MESSAGE
void GroupDlg::Create(GtkWindow* parent)
{
ASSERT_MESSAGE(m_window == 0, "dialog already created");
GtkWindow* window = create_persistent_floating_window("Entities", parent);
global_accel_connect_window(window);
window_connect_focus_in_clear_focus_widget(window);
m_window = window;
#ifdef WIN32
if( g_multimon_globals.m_bStartOnPrimMon )
{
WindowPosition pos(m_position_tracker.getPosition());
PositionWindowOnPrimaryScreen(pos);
m_position_tracker.setPosition(pos);
}
#endif
m_position_tracker.connect(window);
{
GtkWidget* notebook = gtk_notebook_new();
gtk_widget_show(notebook);
gtk_container_add (GTK_CONTAINER (window), notebook);
gtk_notebook_set_tab_pos (GTK_NOTEBOOK (notebook), GTK_POS_BOTTOM);
m_pNotebook = notebook;
g_signal_connect(G_OBJECT(notebook), "switch_page", G_CALLBACK(switch_page), window);
}
}
示例14: ASSERT_MESSAGE
void Clipper::getPlanePoints(Vector3 planepts[3], const AABB& bounds) const {
ASSERT_MESSAGE(valid(), "clipper points not initialised");
planepts[0] = _clipPoints[0]._coords;
planepts[1] = _clipPoints[1]._coords;
planepts[2] = _clipPoints[2]._coords;
Vector3 maxs(bounds.origin + bounds.extents);
Vector3 mins(bounds.origin - bounds.extents);
if (!_clipPoints[2].isSet()) {
int n = (_viewType == XY) ? 2 : (_viewType == YZ) ? 0 : 1;
int x = (n == 0) ? 1 : 0;
int y = (n == 2) ? 1 : 2;
if (n == 1) // on viewtype XZ, flip clip points
{
planepts[0][n] = maxs[n];
planepts[1][n] = maxs[n];
planepts[2][x] = _clipPoints[0]._coords[x];
planepts[2][y] = _clipPoints[0]._coords[y];
planepts[2][n] = mins[n];
}
else {
planepts[0][n] = mins[n];
planepts[1][n] = mins[n];
planepts[2][x] = _clipPoints[0]._coords[x];
planepts[2][y] = _clipPoints[0]._coords[y];
planepts[2][n] = maxs[n];
}
}
}
示例15: GetListInternal
static GSList* GetListInternal (const char *refdir, const char *ext, bool directories, std::size_t depth)
{
GSList* files = 0;
ASSERT_MESSAGE(refdir[strlen(refdir) - 1] == '/', "search path does not end in '/'");
if(directories)
{
for(archives_t::iterator i = g_archives.begin(); i != g_archives.end(); ++i)
{
DirectoryListVisitor visitor(files, refdir);
(*i).archive->forEachFile(Archive::VisitorFunc(visitor, Archive::eDirectories, depth), refdir);
}
}
else
{
for(archives_t::iterator i = g_archives.begin(); i != g_archives.end(); ++i)
{
FileListVisitor visitor(files, refdir, ext);
(*i).archive->forEachFile(Archive::VisitorFunc(visitor, Archive::eFiles, depth), refdir);
}
}
files = g_slist_reverse(files);
return files;
}