OCCT3D (Open CASCADE Technology) Open Source 8.0 bylo vydáno. OCCT3D (Wikipedie, GitHub) je objektově orientovaná knihovna pro 3D CAD, CAM nebo CAE. Používá se například v softwarech FreeCAD a KiCad.
Ve FreeBSD byla nalezena a již opravena 21letá zranitelnost CVE-2026-42511 v dhclient. Jedná se o vzdálené spuštění kódu (RCE). Útočník mající pod správou DHCP server může získat plnou kontrolu nad systémem FreeBSD pouze jeho připojením k místní síti.
Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.
Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).
Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.
Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].
Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.
Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.
Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Čau, snažím se rozjet v code:block tento kód:
#define GLEW_STATIC
#include <GL/glew.h>
#include <GL/glut.h>
#include <stdlib.h>
#include <stdio.h>
// nekdy je potreba pouzivat funkce s priponou ARB...
#ifdef USE_ARB
#define glBindBuffer glBindBufferARB
#define glGenBuffers glGenBuffersARB
#define glBufferData glBufferDataARB
#define glBufferSubData glBufferSubDataARB
#define glDeleteBuffers glDeleteBuffersARB
#endif
/*
Priklad na Vertex Buffer Objects
================================
Oproti predchozimu (Vertex Arrays) je toto prvni metoda, ktera
nahrava objekty primo do pameti graficke karty, diky cemuz pak
neni nutne pri kazdem kresleni prenaset nejaka vetsi data mezi
programem a grafickou kartou.
Princip:
1) V inicializaci vytvorim VBO a do neho nahraju vsechna data,
ta pak mohu smazat z uzivatelske pameti
2) Lze tam kombinovat souradnice i barvy i dalsi veci
3) Pri kresleni je potreba zabindovat patricny buffer - ten se
identifikuje pouze integerem
4) Dale je treba nastavit ukazatele, pokazde znova
5) Pole lze delat prokladane nebo to davat kamkoliv, predavaji
se tam ukazatele
6) Kreslime to stejnym prikazem jako VertexArrays, to je totiz
asi uplne jedno, ty funkce budou pretizene a akorat berou data
z jineho zdroje
*/
// identifikator bufferu, mimo funkce staci jen toto
GLuint vbo_id;
void init(void)
{
glClearColor (0.0, 0.0, 0.0, 0.0);
glClearDepth(1.0);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
gluOrtho2D(0, 800, 0, 600);
// v initu je nyni potreba vytvorit VBO a nahrat do nej data,
// cimzto se data nahraji do graficke karty a z uzivatelske
// pameti mohou byt vymazana
// (kolik_bufferu_chci, ukazatel_kam_zapsat_vznikle_id)
glGenBuffers(1, &vbo_id);
printf("get error = %i\n", glGetError());
// tato data jsou pouze lokalni na zasobniku, pak je mozne je
// smazat...
static GLfloat triangles[] =
{
0.0, 0.0, 1.0, 0.0, 0.0,
200.0, 200.0, 1.0, 1.0, 0.0,
0.0, 200.0, 0.0, 1.0, 1.0,
300.0, 300.0, 1.0, 0.0, 0.0,
600.0, 500.0, 0.0, 0.0, 1.0,
300.0, 450.0, 1.0, 0.0, 1.0
};
// jdem nahrat data do bufferu
glBindBuffer(GL_ARRAY_BUFFER, vbo_id);
glBufferData(GL_ARRAY_BUFFER, sizeof(triangles), triangles, GL_STATIC_DRAW);
// dalsi funkce je pro pripadne dalsi data
// glBufferSubData(GL_ARRAY_BUFFER, 0, sizeof(triangles), triangles);
// BYLO BY FAJN v nejakem destruktoru volat funkci glDeleteBuffers,
// ale to tady v tomto priklade neni... glutMainLoop uz neskonci, ale
// pri ukoncovani programu by se mely volat napr. destruktory sceny, takze
// pokud mame nejakou statickou scenu, tak muzeme uklid dat tam... dalsi
// varianta je UDAJNE registrace callbacku atexit(func_to_be_called) u
// ostatnich callbacku
}
void onDisplay(void)
{
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
// tady se to musi zapnout
glEnableClientState(GL_VERTEX_ARRAY);
glEnableClientState(GL_COLOR_ARRAY);
// zabindujeme buffer, nutno delat pred kazdym kreslenim
glBindBuffer(GL_ARRAY_BUFFER, vbo_id);
// nastavime pointery... TENTOKRAT MAME NA KONCI INT pouze pretypovany na void *
// --> takze to nikam neukazuje, je to jen index
glVertexPointer(2, GL_FLOAT, 5 * sizeof(GLfloat), (GLvoid *) 0);
glColorPointer(3, GL_FLOAT, 5 * sizeof(GLfloat), (void *) (2 * sizeof(GL_FLOAT)));
// vykreslime VBO
glDrawArrays(GL_TRIANGLES, 0, 6);
// vypnem to
glDisableClientState(GL_VERTEX_ARRAY);
glDisableClientState(GL_COLOR_ARRAY);
// zapiseme zmeny
glFlush();
}
void onReshape (int w, int h)
{
glViewport (0, 0, (GLsizei) w, (GLsizei) h);
}
void onKeyboard(unsigned char key, int x, int y)
{
switch (key) {
case 27:
exit(0);
break;
}
glutPostRedisplay();
}
int main(int argc, char** argv)
{
glutInit(&argc, argv);
glutInitDisplayMode (GLUT_SINGLE | GLUT_RGBA | GLUT_DEPTH);
glutInitWindowSize (800, 600);
glutInitWindowPosition (100, 100);
glutCreateWindow ("Polopaticky mustr na Vertex Buffer Objects");
GLenum err = glewInit();
init ();
glutDisplayFunc(onDisplay);
glutReshapeFunc(onReshape);
glutKeyboardFunc(onKeyboard);
glutMainLoop();
return 0;
}
Mám v systému tyto balíčky:
freeglut3 freeglut3-dev libglew1.5 libglew1.5-dev libglu1-mesa libglu1-mesa-dev libgl1-mesa-glx libgl1-mesa-dev
A stále mi to háže chyby kterým nerozumím. Viz příloha.
Tuší někdo kde mám chybu?
Díky Dan
Pro úspěšné vytvoření binárky jí musíš slinkovat s knihovnami libglut.so a libGLEW.so:
$ gcc -lglut -lGLEW -o test test.c
/usr bylo správně (pokud ovšem v usr jsou podadresáře include a lib a tam jsou ty .h a .a,.so).
Tiskni
Sdílej: