start getting the slack api setup
parent
383478cf15
commit
3e25ed94fc
|
@ -36,6 +36,7 @@
|
||||||
buildInputs = with pkgs; (if pkgs.system == "aarch64-darwin" || pkgs.system == "x86_64-darwin" then [
|
buildInputs = with pkgs; (if pkgs.system == "aarch64-darwin" || pkgs.system == "x86_64-darwin" then [
|
||||||
pkg-config
|
pkg-config
|
||||||
binutils
|
binutils
|
||||||
|
curlMinimal
|
||||||
clang
|
clang
|
||||||
bear
|
bear
|
||||||
naga-cli
|
naga-cli
|
||||||
|
|
10
justfile
10
justfile
|
@ -3,13 +3,13 @@ alias r := run
|
||||||
|
|
||||||
build: transpile_shaders_metal
|
build: transpile_shaders_metal
|
||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
cc -Ivendor/ -O0 -g -Wall -Wextra -framework Cocoa -framework QuartzCore -framework CoreImage -framework Metal -framework MetalKit -ObjC src/*.c -o bin/an_editor
|
cc -Ivendor/ -O0 -g -Wall -Wextra $(curl-config --libs) -framework Cocoa -framework QuartzCore -framework CoreImage -framework Metal -framework MetalKit -ObjC src/*.c -o bin/chat_client
|
||||||
# cc -Ivendor/ -g -Wall -Wextra src/*.c -o bin/an_editor -lEGL -lGLESv2 -lGL -lm -lX11 -lXi -lXcursor
|
# cc -Ivendor/ -g -Wall -Wextra src/*.c -o bin/chat_client -lEGL -lGLESv2 -lGL -lm -lX11 -lXi -lXcursor
|
||||||
# cc bin/*.o -o bin/an_editor -lEGL -lGLESv2 -lGL -lm -lX11 -lXi -lXcursor
|
# cc bin/*.o -o bin/chat_client -lEGL -lGLESv2 -lGL -lm -lX11 -lXi -lXcursor
|
||||||
|
|
||||||
run: build
|
run: build
|
||||||
# nixGLIntel ./bin/an_editor
|
# nixGLIntel ./bin/chat_client
|
||||||
./bin/an_editor
|
./bin/chat_client
|
||||||
|
|
||||||
transpile_shaders_metal:
|
transpile_shaders_metal:
|
||||||
mkdir -p bin/transpiled_shaders
|
mkdir -p bin/transpiled_shaders
|
||||||
|
|
|
@ -4,5 +4,6 @@
|
||||||
-DED_GFX_IMPLEMENTATION
|
-DED_GFX_IMPLEMENTATION
|
||||||
-DED_BUFFER_IMPLEMENTATION
|
-DED_BUFFER_IMPLEMENTATION
|
||||||
-DED_FILE_IO_IMPLEMENTATION
|
-DED_FILE_IO_IMPLEMENTATION
|
||||||
|
-DCHAT_SLACK_IMPLEMENTATION
|
||||||
-I../vendor/
|
-I../vendor/
|
||||||
-ObjC
|
-ObjC
|
||||||
|
|
71
src/main.c
71
src/main.c
|
@ -1,3 +1,4 @@
|
||||||
|
#include <curl/curl.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
@ -13,10 +14,12 @@
|
||||||
#define ED_UI_IMPLEMENTATION
|
#define ED_UI_IMPLEMENTATION
|
||||||
#define ED_BUFFER_IMPLEMENTATION
|
#define ED_BUFFER_IMPLEMENTATION
|
||||||
#define ED_FILE_IO_IMPLEMENTATION
|
#define ED_FILE_IO_IMPLEMENTATION
|
||||||
|
#define CHAT_SLACK_IMPLEMENTATION
|
||||||
#include "ed_array.h"
|
#include "ed_array.h"
|
||||||
#include "file_io.h"
|
#include "file_io.h"
|
||||||
#include "gfx.h"
|
#include "gfx.h"
|
||||||
#include "ht.h"
|
#include "ht.h"
|
||||||
|
#include "slack_api.h"
|
||||||
#include "string.h"
|
#include "string.h"
|
||||||
#include "ui.h"
|
#include "ui.h"
|
||||||
|
|
||||||
|
@ -33,6 +36,8 @@ void *context_alloc(size_t size) {
|
||||||
static struct {
|
static struct {
|
||||||
bool should_exit;
|
bool should_exit;
|
||||||
|
|
||||||
|
bool show_thing;
|
||||||
|
|
||||||
ui_context ui_cx;
|
ui_context ui_cx;
|
||||||
gfx_context_t *gfx_cx;
|
gfx_context_t *gfx_cx;
|
||||||
} state;
|
} state;
|
||||||
|
@ -133,8 +138,12 @@ void ed_frame(int mouse_x, int mouse_y, bool mouse_left_down,
|
||||||
snprintf(buffer, 256, "Mouse X: %d, Mouse Y: %d, Mouse %s", mouse_x,
|
snprintf(buffer, 256, "Mouse X: %d, Mouse Y: %d, Mouse %s", mouse_x,
|
||||||
mouse_y, mouse_left_down ? "Down" : "Up");
|
mouse_y, mouse_left_down ? "Down" : "Up");
|
||||||
|
|
||||||
render_ui_rect((float[2]){mouse_x, mouse_y}, (float[2]){32, 32},
|
ui_update_input(&state.ui_cx, (ui_context_input){
|
||||||
(float[4]){1, 1, 1, 1});
|
.mouse_x = mouse_x,
|
||||||
|
.mouse_y = mouse_y,
|
||||||
|
.mouse_left_down = mouse_left_down,
|
||||||
|
.mouse_right_down = mouse_right_down,
|
||||||
|
});
|
||||||
|
|
||||||
ui_element(&state.ui_cx, _String("channel sidebar"), UI_AXIS_VERTICAL,
|
ui_element(&state.ui_cx, _String("channel sidebar"), UI_AXIS_VERTICAL,
|
||||||
ui_make_size(ui_children_sum, ui_fill), UI_FLAG_DRAW_BACKGROUND);
|
ui_make_size(ui_children_sum, ui_fill), UI_FLAG_DRAW_BACKGROUND);
|
||||||
|
@ -144,12 +153,43 @@ void ed_frame(int mouse_x, int mouse_y, bool mouse_left_down,
|
||||||
ui_make_size(ui_fit_text, ui_fit_text),
|
ui_make_size(ui_fit_text, ui_fit_text),
|
||||||
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT);
|
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT);
|
||||||
|
|
||||||
ui_element(&state.ui_cx, _String("#dev-general"), UI_AXIS_HORIZONTAL,
|
if (ui_button(&state.ui_cx, _String("#dev-general")).clicked) {
|
||||||
ui_make_size(ui_fit_text, ui_fit_text),
|
printf("you clicked the dev-general button\n");
|
||||||
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT);
|
state.show_thing = !state.show_thing;
|
||||||
ui_element(&state.ui_cx, _String("#dev-help"), UI_AXIS_HORIZONTAL,
|
}
|
||||||
ui_make_size(ui_fit_text, ui_fit_text),
|
if (ui_button(&state.ui_cx, _String("#dev-help")).clicked) {
|
||||||
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT);
|
printf("you clicked the dev-help button\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state.show_thing) {
|
||||||
|
ui_interaction interaction = _ui_test_interaction(
|
||||||
|
&state.ui_cx,
|
||||||
|
ui_element(&state.ui_cx, _String("thread list"),
|
||||||
|
UI_AXIS_VERTICAL,
|
||||||
|
ui_make_size(ui_children_sum, ui_children_sum),
|
||||||
|
UI_FLAG_DRAW_BACKGROUND));
|
||||||
|
|
||||||
|
ui_push_parent(&state.ui_cx);
|
||||||
|
ui_element(&state.ui_cx, _String("List of Threads"),
|
||||||
|
UI_AXIS_VERTICAL, ui_make_size(ui_fit_text, ui_fit_text),
|
||||||
|
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT |
|
||||||
|
UI_FLAG_HOVERABLE);
|
||||||
|
if (interaction.hovering) {
|
||||||
|
if (ui_button(&state.ui_cx, _String("Thread 1")).clicked) {
|
||||||
|
printf("thread 1\n");
|
||||||
|
}
|
||||||
|
if (ui_button(&state.ui_cx, _String("Thread 2")).clicked) {
|
||||||
|
printf("thread 2\n");
|
||||||
|
}
|
||||||
|
if (ui_button(&state.ui_cx, _String("Thread 3")).clicked) {
|
||||||
|
printf("thread 3\n");
|
||||||
|
}
|
||||||
|
if (ui_button(&state.ui_cx, _String("Thread 4")).clicked) {
|
||||||
|
printf("thread 4\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ui_pop_parent(&state.ui_cx);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
ui_pop_parent(&state.ui_cx);
|
ui_pop_parent(&state.ui_cx);
|
||||||
|
|
||||||
|
@ -158,16 +198,17 @@ void ed_frame(int mouse_x, int mouse_y, bool mouse_left_down,
|
||||||
|
|
||||||
ui_update_cache(&state.ui_cx, 0);
|
ui_update_cache(&state.ui_cx, 0);
|
||||||
ui_prune(&state.ui_cx);
|
ui_prune(&state.ui_cx);
|
||||||
|
|
||||||
ui_update_input(&state.ui_cx, (ui_context_input){
|
|
||||||
.mouse_x = mouse_x,
|
|
||||||
.mouse_y = mouse_y,
|
|
||||||
.mouse_left_down = false,
|
|
||||||
.mouse_right_down = false,
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
|
|
||||||
|
slack_client client = slack_init_client();
|
||||||
|
_slack_debug_print_auth_test(&client);
|
||||||
|
|
||||||
|
curl_global_cleanup();
|
||||||
|
return 0;
|
||||||
|
|
||||||
ed_init(ed_frame);
|
ed_init(ed_frame);
|
||||||
|
|
||||||
while (keep_running) {
|
while (keep_running) {
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
// Slack API Interface
|
||||||
|
|
||||||
|
#ifndef CHAT_SLACK_INCLUDED
|
||||||
|
#define CHAT_SLACK_INCLUDED
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#include "ed_array.h"
|
||||||
|
#include "string.h"
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
CURL *curl;
|
||||||
|
} slack_client;
|
||||||
|
|
||||||
|
void _slack_debug_print_auth_test(slack_client *client);
|
||||||
|
|
||||||
|
slack_client slack_init_client();
|
||||||
|
|
||||||
|
#ifdef CHAT_SLACK_IMPLEMENTATION
|
||||||
|
|
||||||
|
static size_t write_memory_callback(void *contents, size_t size, size_t nmemb,
|
||||||
|
void *userp) {
|
||||||
|
size_t real_size = size * nmemb;
|
||||||
|
pushArrayMulti(uint8_t, userp, contents, real_size);
|
||||||
|
return real_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
void _slack_debug_print_auth_test(slack_client *client, string token,
|
||||||
|
string cookie) {
|
||||||
|
if (client->curl) {
|
||||||
|
struct curl_slist *headers = NULL;
|
||||||
|
headers = curl_slist_append(headers, "Content-Type: application/json");
|
||||||
|
// headers = curl_slist_append(headers, cookie);
|
||||||
|
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_URL,
|
||||||
|
"https://slack.com/api/auth.test");
|
||||||
|
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_HTTPAUTH, (long)CURLAUTH_BEARER);
|
||||||
|
// curl_easy_setopt(client->curl, CURLOPT_XOAUTH2_BEARER, token);
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_USERAGENT,
|
||||||
|
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; "
|
||||||
|
"rv:76.0) Gecko/20100101 Firefox/76.0");
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_HTTPHEADER, headers);
|
||||||
|
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_POST, 1L);
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_POSTFIELDS, "{}");
|
||||||
|
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_FOLLOWLOCATION, 1L);
|
||||||
|
|
||||||
|
array(uint8_t) chunk = newArray(uint8_t, 10000);
|
||||||
|
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_WRITEFUNCTION,
|
||||||
|
write_memory_callback);
|
||||||
|
curl_easy_setopt(client->curl, CURLOPT_WRITEDATA, (void *)&chunk);
|
||||||
|
|
||||||
|
/* Perform the request, res gets the return code */
|
||||||
|
CURLcode res = curl_easy_perform(client->curl);
|
||||||
|
/* Check for errors */
|
||||||
|
if (res != CURLE_OK) {
|
||||||
|
fprintf(stderr, "curl_easy_perform() failed: %s\n",
|
||||||
|
curl_easy_strerror(res));
|
||||||
|
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Got data\n%.*s\n", (int)chunk.size, chunk.data);
|
||||||
|
}
|
||||||
|
|
||||||
|
free(chunk.data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
slack_client slack_init_client(string token, string cookie) {
|
||||||
|
CURL *curl = curl_easy_init();
|
||||||
|
|
||||||
|
slack_client client = (slack_client){.curl = curl};
|
||||||
|
|
||||||
|
return client;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
56
src/ui.h
56
src/ui.h
|
@ -136,6 +136,9 @@ typedef struct {
|
||||||
|
|
||||||
void ui_compute_layout(ui_context *cx, size_t element_index);
|
void ui_compute_layout(ui_context *cx, size_t element_index);
|
||||||
|
|
||||||
|
ui_interaction _ui_test_interaction(ui_context *cx, size_t element_index);
|
||||||
|
ui_interaction ui_button(ui_context *cx, string label);
|
||||||
|
|
||||||
#ifdef ED_UI_IMPLEMENTATION
|
#ifdef ED_UI_IMPLEMENTATION
|
||||||
|
|
||||||
ui_context ui_init_context() {
|
ui_context ui_init_context() {
|
||||||
|
@ -235,6 +238,35 @@ size_t ui_element(ui_context *cx, string label, ui_axis axis,
|
||||||
return frame_data.index;
|
return frame_data.index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ui_interaction _ui_test_interaction(ui_context *cx, size_t element_index) {
|
||||||
|
bool hovering = false;
|
||||||
|
bool mouse_is_clicked =
|
||||||
|
cx->last_input.mouse_left_down && !cx->input.mouse_left_down;
|
||||||
|
|
||||||
|
ui_element_frame_data *elm = _elm(element_index);
|
||||||
|
|
||||||
|
if ((cx->input.mouse_x >= elm->size.computed_pos[0] &&
|
||||||
|
cx->input.mouse_x <
|
||||||
|
elm->size.computed_pos[0] + elm->size.computed_size[0]) &&
|
||||||
|
cx->input.mouse_y >= elm->size.computed_pos[1] &&
|
||||||
|
cx->input.mouse_y <
|
||||||
|
elm->size.computed_pos[1] + elm->size.computed_size[1]) {
|
||||||
|
hovering = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (ui_interaction){.hovering = hovering,
|
||||||
|
.clicked = hovering && mouse_is_clicked};
|
||||||
|
}
|
||||||
|
|
||||||
|
ui_interaction ui_button(ui_context *cx, string label) {
|
||||||
|
size_t id = ui_element(cx, label, UI_AXIS_HORIZONTAL,
|
||||||
|
ui_make_size(ui_fit_text, ui_fit_text),
|
||||||
|
UI_FLAG_DRAW_BACKGROUND | UI_FLAG_DRAW_TEXT |
|
||||||
|
UI_FLAG_HOVERABLE | UI_FLAG_CLICKABLE);
|
||||||
|
|
||||||
|
return _ui_test_interaction(cx, id);
|
||||||
|
}
|
||||||
|
|
||||||
static uint32_t _ui_ancestor_size(ui_context *cx, size_t element_index,
|
static uint32_t _ui_ancestor_size(ui_context *cx, size_t element_index,
|
||||||
ui_axis axis) {
|
ui_axis axis) {
|
||||||
if (element_index == SIZE_MAX || _parent(element_index) == SIZE_MAX) {
|
if (element_index == SIZE_MAX || _parent(element_index) == SIZE_MAX) {
|
||||||
|
@ -292,10 +324,11 @@ static void _ui_compute_children_layout(ui_context *cx,
|
||||||
ui_element_frame_data *elm) {
|
ui_element_frame_data *elm) {
|
||||||
uint32_t child_size[2] = {0, 0};
|
uint32_t child_size[2] = {0, 0};
|
||||||
|
|
||||||
// NOTE: the number of fills for the opposite axis of this box needs to be 1
|
// NOTE: the number of fills for the opposite axis of this box needs to
|
||||||
// because it will never get incremented in the loop below and cause a
|
// be 1 because it will never get incremented in the loop below and
|
||||||
// divide by zero and the number of fills for the axis of the box needs to
|
// cause a divide by zero and the number of fills for the axis of the
|
||||||
// start at zero or else it will be n+1 causing incorrect sizes
|
// box needs to start at zero or else it will be n+1 causing incorrect
|
||||||
|
// sizes
|
||||||
uint32_t num_fills[2] = {1, 1};
|
uint32_t num_fills[2] = {1, 1};
|
||||||
num_fills[elm->size.axis] = 0;
|
num_fills[elm->size.axis] = 0;
|
||||||
|
|
||||||
|
@ -476,11 +509,16 @@ void ui_render(ui_context *cx, _ui_render_text_func text_func,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_flags(i, UI_FLAG_DRAW_BACKGROUND)) {
|
if (_flags(i, UI_FLAG_DRAW_BACKGROUND)) {
|
||||||
|
float c = _ui_test_interaction(cx, i).hovering &&
|
||||||
|
_flags(i, UI_FLAG_HOVERABLE)
|
||||||
|
? 0.8
|
||||||
|
: 0.2;
|
||||||
|
|
||||||
rect_func((float[]){(float)elm->size.computed_pos[0],
|
rect_func((float[]){(float)elm->size.computed_pos[0],
|
||||||
(float)elm->size.computed_pos[1]},
|
(float)elm->size.computed_pos[1]},
|
||||||
(float[]){(float)elm->size.computed_size[0],
|
(float[]){(float)elm->size.computed_size[0],
|
||||||
(float)elm->size.computed_size[1]},
|
(float)elm->size.computed_size[1]},
|
||||||
(float[]){1, 1, 1, 0.2});
|
(float[]){c, c, c, 1.0});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -490,13 +528,13 @@ void ui_prune(ui_context *cx) {
|
||||||
if (cx->cached_elements.key_slots[i].key.data != NULL) {
|
if (cx->cached_elements.key_slots[i].key.data != NULL) {
|
||||||
string key = cx->cached_elements.key_slots[i].key;
|
string key = cx->cached_elements.key_slots[i].key;
|
||||||
|
|
||||||
// if this element hasn't been created in the past 5 frames, remove
|
// if this element hasn't been created in the past 5 frames,
|
||||||
// it
|
// remove it
|
||||||
ui_element_cache_data *cached = ht_get(&cx->cached_elements, key);
|
ui_element_cache_data *cached = ht_get(&cx->cached_elements, key);
|
||||||
if (cached &&
|
if (cached &&
|
||||||
cached->last_instantiated_index < cx->frame_index - 5) {
|
cached->last_instantiated_index < cx->frame_index - 5) {
|
||||||
// fprintf(stderr, "removing %.*s from cache, cache index: %zu,
|
// fprintf(stderr, "removing %.*s from cache, cache index:
|
||||||
// frame index: %zu\n", (int)key.len, key.data,
|
// %zu, frame index: %zu\n", (int)key.len, key.data,
|
||||||
// cached->last_instantiated_index, cx->frame_index);
|
// cached->last_instantiated_index, cx->frame_index);
|
||||||
|
|
||||||
ht_remove(&cx->cached_elements, key);
|
ht_remove(&cx->cached_elements, key);
|
||||||
|
|
Loading…
Reference in New Issue