Compare commits
2 Commits
4f4ec2bc91
...
f2b20118e0
Author | SHA1 | Date | |
---|---|---|---|
f2b20118e0 | |||
42d18ccae1 |
@ -20,6 +20,11 @@ indent_size = 4
|
|||||||
indent_style = space
|
indent_style = space
|
||||||
indent_size = 4
|
indent_size = 4
|
||||||
|
|
||||||
|
# Ruby
|
||||||
|
[*.rb]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
# Crystal
|
# Crystal
|
||||||
[{*.cr,shards.yml}]
|
[{*.cr,shards.yml}]
|
||||||
indent_style = space
|
indent_style = space
|
||||||
@ -85,13 +90,16 @@ indent_size = 4
|
|||||||
indent_style = tab
|
indent_style = tab
|
||||||
indent_size = 4
|
indent_size = 4
|
||||||
|
|
||||||
[snipplets/code/Gambas/*]
|
[code/Gambas/*]
|
||||||
indent_size = 2
|
indent_size = 2
|
||||||
|
|
||||||
[snipplets/projects/Solar2D**]
|
[projects/Solar2D/**]
|
||||||
indent_style = unset
|
indent_style = unset
|
||||||
indent_size = unset
|
indent_size = unset
|
||||||
end_of_line = unset
|
end_of_line = unset
|
||||||
charset = unset
|
charset = unset
|
||||||
trim_trailing_whitespace = unset
|
trim_trailing_whitespace = unset
|
||||||
insert_final_newline = unset
|
insert_final_newline = unset
|
||||||
|
|
||||||
|
[projects/CV/haarcascade_frontalface_default.xml]
|
||||||
|
indent_size = unset
|
||||||
|
@ -9,8 +9,7 @@
|
|||||||
char message[] = "Hello there!\n";
|
char message[] = "Hello there!\n";
|
||||||
char buf[sizeof(message)];
|
char buf[sizeof(message)];
|
||||||
|
|
||||||
int main()
|
int main() {
|
||||||
{
|
|
||||||
int sock;
|
int sock;
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
|
|
||||||
|
@ -5,8 +5,7 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
|
|
||||||
int main()
|
int main() {
|
||||||
{
|
|
||||||
int sock, listener;
|
int sock, listener;
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
@ -28,16 +27,17 @@ int main()
|
|||||||
|
|
||||||
listen(listener, 1);
|
listen(listener, 1);
|
||||||
|
|
||||||
while(1) {
|
while (1) {
|
||||||
sock = accept(listener, NULL, NULL);
|
sock = accept(listener, NULL, NULL);
|
||||||
if (sock < 0) {
|
if (sock < 0) {
|
||||||
perror("accept");
|
perror("accept");
|
||||||
exit(3);
|
exit(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
while(1) {
|
while (1) {
|
||||||
bytes_read = recv(sock, buf, 1024, 0);
|
bytes_read = recv(sock, buf, 1024, 0);
|
||||||
if (bytes_read <= 0) break;
|
if (bytes_read <= 0)
|
||||||
|
break;
|
||||||
send(sock, buf, bytes_read, 0);
|
send(sock, buf, bytes_read, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
31
code/C/Parsing/CSV/read_csv.c
Normal file
31
code/C/Parsing/CSV/read_csv.c
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#include <stdio.h> // file handling functions
|
||||||
|
#include <stdlib.h> // atoi
|
||||||
|
#include <string.h> // strtok
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
char buffer[80];
|
||||||
|
FILE *stream = fopen("example.csv", "r");
|
||||||
|
|
||||||
|
while (fgets(buffer, 80, stream)) {
|
||||||
|
char *token = strtok(buffer, ",");
|
||||||
|
|
||||||
|
// If you only need the first column of each row
|
||||||
|
// Если нам нужен только первый столбец каждой строки
|
||||||
|
if (token) {
|
||||||
|
int n = atoi(token);
|
||||||
|
printf("%s\n", n);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If you need all the values in a row
|
||||||
|
// Если нам нужны все значения подряд
|
||||||
|
while (token) {
|
||||||
|
// Just printing each integer here but handle as needed
|
||||||
|
// int n = atoi(token);
|
||||||
|
printf("%s\n", token);
|
||||||
|
|
||||||
|
token = strtok(NULL, ",");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@ -1,13 +1,43 @@
|
|||||||
# C
|
# C
|
||||||
|
|
||||||
## Other
|
## Работа со строками
|
||||||
|
|
||||||
- [seconds_to_minutes_and_hours.c](seconds_to_minutes_and_hours.c) - Преобразование секунд в минуты и часы
|
- [clear_string.c](Strings/clear_string.c) - Очистка строки `char *`
|
||||||
- [get_ram_usage.c](get_ram_usage.c) - Получение используемой приложением RAM
|
- [`strlen()`](Strings/buffer_len.h) - Получить длину строки
|
||||||
## SQLite 3
|
- []() -
|
||||||
|
|
||||||
- [CREATE TABLE](sqlite/sqlite3_create.c)
|
## Преобразования
|
||||||
- [INSERT INTO](sqlite/sqlite3_insert.c)
|
|
||||||
- [SELECT](sqlite/sqlite3_select.c)
|
- [rgbToHex.c](Transform/rgbToHex.c) - Преобразование RGB строки в HEX строку _(#008040)_
|
||||||
- [UPDATE](sqlite/sqlite3_update.c)
|
- [seconds_to_minutes_and_hours.c](Transform/seconds_to_minutes_and_hours.c) - Преобразование секунд в минуты и часы
|
||||||
- [DELETE](sqlite/sqlite3_delete.c)
|
|
||||||
|
## Парсеры
|
||||||
|
|
||||||
|
- [read_csv.c](Parsing/CSV/read_csv.c) - Парсинг CSV файлов
|
||||||
|
|
||||||
|
## Система
|
||||||
|
|
||||||
|
- [get_ram_usage.c](System/get_ram_usage.c) - Получение статистики использования RAM
|
||||||
|
- [`sys/statvfs.h`](System/disk_usage.c) - Получение статиистики использования диска
|
||||||
|
- [`pidof`](System/get-pid-by-process-name.c) - Получение ID процесса по его имени
|
||||||
|
|
||||||
|
## 🗄️ SQLite 3
|
||||||
|
|
||||||
|
- [CREATE TABLE](SQLite/sqlite3_create.c) — Создание таблицы
|
||||||
|
- [INSERT INTO](SQLite/sqlite3_insert.c) — Вставка
|
||||||
|
- [SELECT](SQLite/sqlite3_select.c) — Выбор
|
||||||
|
- [UPDATE](SQLite/sqlite3_update.c) — Обновление
|
||||||
|
- [DELETE](SQLite/sqlite3_delete.c) — Удаление
|
||||||
|
|
||||||
|
## Web
|
||||||
|
|
||||||
|
- [`webui`](Web/webui) - Пример библиотеки [webui](https://webui.me/)
|
||||||
|
- [`ulfius`](Web/ulfius-server) - Пример библиотеки ulfius
|
||||||
|
|
||||||
|
## Другое
|
||||||
|
|
||||||
|
- [`conio.h`](conio.h/README.md) - Описание и работа функций заголовоного файла `conio.h`.
|
||||||
|
- [unixsocket](unixsocket) - Пример работы с сокетами UNIX
|
||||||
|
- [AF_INET_sockets](AF_INET_sockets) - Пример работы с сокетами
|
||||||
|
- [atomic.c](atomic.c) - Пример `atomic`
|
||||||
|
- [thread.c](thread.c) - Пример многопоточности
|
||||||
|
1
code/C/SQLite/.gitignore
vendored
Normal file
1
code/C/SQLite/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
sqlite3_*
|
52
code/C/SQLite/sqlite3_create.c
Normal file
52
code/C/SQLite/sqlite3_create.c
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sqlite3.h>
|
||||||
|
|
||||||
|
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < argc; i++) {
|
||||||
|
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
sqlite3 *db;
|
||||||
|
char *zErrMsg = 0;
|
||||||
|
int rc;
|
||||||
|
char *sql;
|
||||||
|
|
||||||
|
/* Open database */
|
||||||
|
rc = sqlite3_open("test.db", &db);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||||
|
return (0);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Opened database successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create SQL statement */
|
||||||
|
sql = "CREATE TABLE COMPANY("
|
||||||
|
"ID INT PRIMARY KEY NOT NULL,"
|
||||||
|
"NAME TEXT NOT NULL,"
|
||||||
|
"AGE INT NOT NULL,"
|
||||||
|
"ADDRESS CHAR(50),"
|
||||||
|
"SALARY REAL);";
|
||||||
|
|
||||||
|
/* Execute SQL statement */
|
||||||
|
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||||
|
|
||||||
|
if (rc != SQLITE_OK) {
|
||||||
|
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||||
|
sqlite3_free(zErrMsg);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Table created successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_close(db);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
51
code/C/SQLite/sqlite3_delete.c
Normal file
51
code/C/SQLite/sqlite3_delete.c
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sqlite3.h>
|
||||||
|
|
||||||
|
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||||
|
int i;
|
||||||
|
fprintf(stderr, "%s: ", (const char *)data);
|
||||||
|
|
||||||
|
for (i = 0; i < argc; i++) {
|
||||||
|
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
sqlite3 *db;
|
||||||
|
char *zErrMsg = 0;
|
||||||
|
int rc;
|
||||||
|
char *sql;
|
||||||
|
const char *data = "Callback function called";
|
||||||
|
|
||||||
|
/* Open database */
|
||||||
|
rc = sqlite3_open("test.db", &db);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||||
|
return (0);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Opened database successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create merged SQL statement */
|
||||||
|
sql = "DELETE from COMPANY where ID=2; "
|
||||||
|
"SELECT * from COMPANY";
|
||||||
|
|
||||||
|
/* Execute SQL statement */
|
||||||
|
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||||
|
|
||||||
|
if (rc != SQLITE_OK) {
|
||||||
|
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||||
|
sqlite3_free(zErrMsg);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Operation done successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_close(db);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
55
code/C/SQLite/sqlite3_insert.c
Normal file
55
code/C/SQLite/sqlite3_insert.c
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sqlite3.h>
|
||||||
|
|
||||||
|
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < argc; i++) {
|
||||||
|
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
sqlite3 *db;
|
||||||
|
char *zErrMsg = 0;
|
||||||
|
int rc;
|
||||||
|
char *sql;
|
||||||
|
|
||||||
|
/* Open database */
|
||||||
|
rc = sqlite3_open("test.db", &db);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||||
|
return (0);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Opened database successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create SQL statement */
|
||||||
|
sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
|
||||||
|
"VALUES (1, 'Paul', 32, 'California', 20000.00 ); "
|
||||||
|
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
|
||||||
|
"VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); "
|
||||||
|
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)"
|
||||||
|
"VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );"
|
||||||
|
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)"
|
||||||
|
"VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00);";
|
||||||
|
|
||||||
|
/* Execute SQL statement */
|
||||||
|
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
||||||
|
|
||||||
|
if (rc != SQLITE_OK) {
|
||||||
|
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||||
|
sqlite3_free(zErrMsg);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Records created successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_close(db);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
50
code/C/SQLite/sqlite3_select.c
Normal file
50
code/C/SQLite/sqlite3_select.c
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sqlite3.h>
|
||||||
|
|
||||||
|
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||||
|
int i;
|
||||||
|
fprintf(stderr, "%s: ", (const char *)data);
|
||||||
|
|
||||||
|
for (i = 0; i < argc; i++) {
|
||||||
|
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
sqlite3 *db;
|
||||||
|
char *zErrMsg = 0;
|
||||||
|
int rc;
|
||||||
|
char *sql;
|
||||||
|
const char *data = "Callback function called";
|
||||||
|
|
||||||
|
/* Open database */
|
||||||
|
rc = sqlite3_open("test.db", &db);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||||
|
return (0);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Opened database successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create SQL statement */
|
||||||
|
sql = "SELECT * from COMPANY";
|
||||||
|
|
||||||
|
/* Execute SQL statement */
|
||||||
|
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||||
|
|
||||||
|
if (rc != SQLITE_OK) {
|
||||||
|
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||||
|
sqlite3_free(zErrMsg);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Operation done successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_close(db);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
51
code/C/SQLite/sqlite3_update.c
Normal file
51
code/C/SQLite/sqlite3_update.c
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sqlite3.h>
|
||||||
|
|
||||||
|
static int callback(void *data, int argc, char **argv, char **azColName) {
|
||||||
|
int i;
|
||||||
|
fprintf(stderr, "%s: ", (const char *)data);
|
||||||
|
|
||||||
|
for (i = 0; i < argc; i++) {
|
||||||
|
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
sqlite3 *db;
|
||||||
|
char *zErrMsg = 0;
|
||||||
|
int rc;
|
||||||
|
char *sql;
|
||||||
|
const char *data = "Callback function called";
|
||||||
|
|
||||||
|
/* Open database */
|
||||||
|
rc = sqlite3_open("test.db", &db);
|
||||||
|
|
||||||
|
if (rc) {
|
||||||
|
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
||||||
|
return (0);
|
||||||
|
} else {
|
||||||
|
fprintf(stderr, "Opened database successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create merged SQL statement */
|
||||||
|
sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; "
|
||||||
|
"SELECT * from COMPANY";
|
||||||
|
|
||||||
|
/* Execute SQL statement */
|
||||||
|
rc = sqlite3_exec(db, sql, callback, (void *)data, &zErrMsg);
|
||||||
|
|
||||||
|
if (rc != SQLITE_OK) {
|
||||||
|
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
||||||
|
sqlite3_free(zErrMsg);
|
||||||
|
} else {
|
||||||
|
fprintf(stdout, "Operation done successfully\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_close(db);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
9
code/C/Strings/clear_string.c
Normal file
9
code/C/Strings/clear_string.c
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
int main(int argc, char const *argv[]) {
|
||||||
|
char *buffer = malloc(256 + 1);
|
||||||
|
|
||||||
|
buffer[0] = '\0';
|
||||||
|
strcpy(buffer, "");
|
||||||
|
memset(buffer, '\0', sizeof(buffer));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
12
code/C/System/get-pid-by-process-name.c
Normal file
12
code/C/System/get-pid-by-process-name.c
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
pid_t getPIDbyName(char *ps_name) {
|
||||||
|
FILE *fp;
|
||||||
|
char *cmd = (char *)calloc(1, 200);
|
||||||
|
|
||||||
|
sprintf(cmd, "pidof %s", ps_name);
|
||||||
|
|
||||||
|
fp = popen(cmd, "r");
|
||||||
|
fread(cmd, 1, 200, fp);
|
||||||
|
fclose(fp);
|
||||||
|
|
||||||
|
return atoi(cmd);
|
||||||
|
}
|
11
code/C/Transform/rgbToHex.c
Normal file
11
code/C/Transform/rgbToHex.c
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(int argc, char const *argv[]) {
|
||||||
|
int red = 0;
|
||||||
|
int green = 128;
|
||||||
|
int blue = 64;
|
||||||
|
|
||||||
|
printf("#%.2x%.2x%.2x\n", red, green, blue); // #008040
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Before Width: | Height: | Size: 78 KiB After Width: | Height: | Size: 78 KiB |
@ -5,10 +5,9 @@
|
|||||||
atomic_int acnt;
|
atomic_int acnt;
|
||||||
int cnt;
|
int cnt;
|
||||||
|
|
||||||
int f(void* thr_data)
|
int f(void *thr_data) {
|
||||||
{
|
|
||||||
(void)thr_data;
|
(void)thr_data;
|
||||||
for(int n = 0; n < 1000; ++n) {
|
for (int n = 0; n < 1000; ++n) {
|
||||||
++cnt;
|
++cnt;
|
||||||
++acnt;
|
++acnt;
|
||||||
// for this example, relaxed memory order is sufficient, e.g.
|
// for this example, relaxed memory order is sufficient, e.g.
|
||||||
@ -17,12 +16,11 @@ int f(void* thr_data)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
thrd_t thr[10];
|
thrd_t thr[10];
|
||||||
for(int n = 0; n < 10; ++n)
|
for (int n = 0; n < 10; ++n)
|
||||||
thrd_create(&thr[n], f, NULL);
|
thrd_create(&thr[n], f, NULL);
|
||||||
for(int n = 0; n < 10; ++n)
|
for (int n = 0; n < 10; ++n)
|
||||||
thrd_join(thr[n], NULL);
|
thrd_join(thr[n], NULL);
|
||||||
|
|
||||||
printf("The atomic counter is %u\n", acnt);
|
printf("The atomic counter is %u\n", acnt);
|
||||||
|
@ -1,10 +0,0 @@
|
|||||||
int main(int argc, char const *argv[])
|
|
||||||
{
|
|
||||||
char *buffer = malloc(256 + 1);
|
|
||||||
|
|
||||||
buffer[0] = '\0';
|
|
||||||
strcpy(buffer, "");
|
|
||||||
memset(buffer, '\0', sizeof(buffer));
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
files=(
|
|
||||||
"file.c"
|
|
||||||
)
|
|
||||||
|
|
||||||
for file in "${files[@]}"
|
|
||||||
do
|
|
||||||
clang-format -i --style=LLVM --sort-includes=false $file
|
|
||||||
done
|
|
@ -1,6 +0,0 @@
|
|||||||
[{clear,build,format-code}]
|
|
||||||
indent_style = space
|
|
||||||
indent_size = 4
|
|
||||||
|
|
||||||
[{*.c,*.ino}]
|
|
||||||
indent_size = 2
|
|
12
code/C/libserialport/.gitignore
vendored
12
code/C/libserialport/.gitignore
vendored
@ -1,12 +0,0 @@
|
|||||||
# libserialport examples
|
|
||||||
port_info.c
|
|
||||||
list_ports.c
|
|
||||||
send_receive.c
|
|
||||||
|
|
||||||
# binaries
|
|
||||||
port_info
|
|
||||||
list_ports
|
|
||||||
send_receive
|
|
||||||
|
|
||||||
listen
|
|
||||||
abc.txt
|
|
1
code/C/libserialport/Board/.gitignore
vendored
1
code/C/libserialport/Board/.gitignore
vendored
@ -1 +0,0 @@
|
|||||||
3party/
|
|
@ -1,24 +0,0 @@
|
|||||||
/*
|
|
||||||
Author: Alexander Popov
|
|
||||||
License: Unlicense
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "3party/AsyncStream.h"
|
|
||||||
AsyncStream<50> serial(&Serial, '\n');
|
|
||||||
|
|
||||||
void setup() {
|
|
||||||
Serial.begin(9600);
|
|
||||||
}
|
|
||||||
|
|
||||||
void loop() {
|
|
||||||
if (strcmp(serial.buf, "ping") == 0) {
|
|
||||||
Serial.println("PONG");
|
|
||||||
}
|
|
||||||
|
|
||||||
Serial.println("ooooo");
|
|
||||||
// delay(1000);
|
|
||||||
Serial.println("zzzz");
|
|
||||||
// delay(1000);
|
|
||||||
Serial.println("xxx");
|
|
||||||
// delay(1000);
|
|
||||||
}
|
|
@ -1,3 +0,0 @@
|
|||||||
Download `AsyncStream.h` from
|
|
||||||
https://github.com/GyverLibs/AsyncStream
|
|
||||||
and drop in to `3party` folder.
|
|
@ -1,18 +0,0 @@
|
|||||||
Download `libserialport` library.
|
|
||||||
|
|
||||||
```sh
|
|
||||||
git clone git://sigrok.org/libserialport
|
|
||||||
```
|
|
||||||
|
|
||||||
For **build** code use `build` script or build files manually.
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
export C_INCLUDE_PATH=<path/to/libserialport>
|
|
||||||
export LIBRARY_PATH=<path/to/libserialport/.libs>
|
|
||||||
|
|
||||||
gcc -static -Wall -O3 -o <output_filename> <file.c> -lserialport
|
|
||||||
```
|
|
||||||
|
|
||||||
Arduino example project store in `Board` folder.
|
|
@ -1,20 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# build - script for build all files.
|
|
||||||
#
|
|
||||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
|
||||||
|
|
||||||
export C_INCLUDE_PATH=$HOME/Git/libserialport
|
|
||||||
export LIBRARY_PATH=$HOME/Git/libserialport/.libs
|
|
||||||
|
|
||||||
for file in \
|
|
||||||
port_info.c \
|
|
||||||
list_ports.c \
|
|
||||||
send_receive.c \
|
|
||||||
listen.c \
|
|
||||||
|
|
||||||
do
|
|
||||||
echo -ne "[ ] Building $file...\r"
|
|
||||||
gcc -static -Wall -O3 -o ${file%.*} $file -lserialport
|
|
||||||
echo [OK
|
|
||||||
done
|
|
@ -1,20 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# build - script for build all files.
|
|
||||||
#
|
|
||||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
|
||||||
|
|
||||||
export C_INCLUDE_PATH=$HOME/Git/libserialport
|
|
||||||
export LIBRARY_PATH=$HOME/Git/libserialport/.libs
|
|
||||||
|
|
||||||
for file in \
|
|
||||||
port_info.c \
|
|
||||||
list_ports.c \
|
|
||||||
send_receive.c \
|
|
||||||
listen.c \
|
|
||||||
|
|
||||||
do
|
|
||||||
echo -ne "[ ] Building $file...\r"
|
|
||||||
tcc -Wall -O3 -o ${file%.*} -I$C_INCLUDE_PATH $file $LIBRARY_PATH/libserialport.a
|
|
||||||
echo [OK
|
|
||||||
done
|
|
@ -1,17 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# clear - script for delete all builded files.
|
|
||||||
#
|
|
||||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
|
||||||
|
|
||||||
files=(
|
|
||||||
"port_info"
|
|
||||||
"list_ports"
|
|
||||||
"send_receive"
|
|
||||||
"listen"
|
|
||||||
)
|
|
||||||
|
|
||||||
for file in ${files[@]}
|
|
||||||
do
|
|
||||||
rm $file &> /dev/null
|
|
||||||
done
|
|
@ -1,14 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# formt-code - script for beautify code by clang-format.
|
|
||||||
#
|
|
||||||
# Alexander Popov <iiiypuk@fastmail.fm>
|
|
||||||
|
|
||||||
files=(
|
|
||||||
"listen.c"
|
|
||||||
)
|
|
||||||
|
|
||||||
for file in "${files[@]}"
|
|
||||||
do
|
|
||||||
clang-format -i --style=LLVM --sort-includes=false $file
|
|
||||||
done
|
|
@ -1,133 +0,0 @@
|
|||||||
#include <libserialport.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include <signal.h>
|
|
||||||
|
|
||||||
/* Helper function for error handling. */
|
|
||||||
int check(enum sp_return result);
|
|
||||||
void handle_sigint(int sig);
|
|
||||||
|
|
||||||
bool INTERRUPT = false;
|
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
|
||||||
struct sp_port *serial_port;
|
|
||||||
char *port_name;
|
|
||||||
|
|
||||||
const int size = 256;
|
|
||||||
char *buffer = malloc(size + 1);
|
|
||||||
|
|
||||||
const unsigned int timeout = 1000;
|
|
||||||
int result;
|
|
||||||
|
|
||||||
/* Get the port name from the command line. */
|
|
||||||
if (argc != 2) {
|
|
||||||
printf("Usage: %s <port>\n\n", argv[0]);
|
|
||||||
|
|
||||||
struct sp_port **port_list;
|
|
||||||
enum sp_return result = sp_list_ports(&port_list);
|
|
||||||
|
|
||||||
/* Getting the available ports. */
|
|
||||||
if (result != SP_OK) {
|
|
||||||
puts("Getting available ports failed!");
|
|
||||||
} else {
|
|
||||||
puts("Available ports:");
|
|
||||||
|
|
||||||
int i;
|
|
||||||
for (i = 0; port_list[i] != NULL; i++) {
|
|
||||||
/* Get the name of the port. */
|
|
||||||
struct sp_port *port = port_list[i];
|
|
||||||
char *port_name = sp_get_port_name(port);
|
|
||||||
|
|
||||||
printf(" * %s\n", port_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\nAvailable %d ports.\n", i);
|
|
||||||
|
|
||||||
sp_free_port_list(port_list);
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
} else {
|
|
||||||
port_name = argv[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("Connecting to '%s'...\n", port_name);
|
|
||||||
check(sp_get_port_by_name(port_name, &serial_port));
|
|
||||||
check(sp_open(serial_port, SP_MODE_READ_WRITE));
|
|
||||||
|
|
||||||
check(sp_set_baudrate(serial_port, 9600));
|
|
||||||
check(sp_set_bits(serial_port, 8));
|
|
||||||
check(sp_set_parity(serial_port, SP_PARITY_NONE));
|
|
||||||
check(sp_set_stopbits(serial_port, 1));
|
|
||||||
check(sp_set_flowcontrol(serial_port, SP_FLOWCONTROL_NONE));
|
|
||||||
puts("Connected.");
|
|
||||||
|
|
||||||
signal(SIGINT, handle_sigint);
|
|
||||||
|
|
||||||
FILE *output_file;
|
|
||||||
output_file = fopen("./abc.txt", "w");
|
|
||||||
|
|
||||||
/* Reading lines from serial port. */
|
|
||||||
bool reading = true;
|
|
||||||
while (reading && !INTERRUPT) {
|
|
||||||
int pos = 0;
|
|
||||||
|
|
||||||
/* Character-by-character reading. */
|
|
||||||
while (pos < size) {
|
|
||||||
result = check(sp_blocking_read(serial_port, buffer + pos, 1, timeout));
|
|
||||||
|
|
||||||
if (result == -1) {
|
|
||||||
puts("Error reading from serial port");
|
|
||||||
|
|
||||||
reading = false;
|
|
||||||
break;
|
|
||||||
} else if (result == 0) {
|
|
||||||
puts("No more data");
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
if (buffer[pos] == '\n') {
|
|
||||||
buffer[pos] = '\0';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
pos++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
puts(buffer);
|
|
||||||
fputs(buffer, output_file);
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(output_file);
|
|
||||||
free(buffer);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Helper function for error handling. */
|
|
||||||
int check(enum sp_return result) {
|
|
||||||
char *error_message;
|
|
||||||
|
|
||||||
switch (result) {
|
|
||||||
case SP_ERR_ARG:
|
|
||||||
puts("Error: Invalid argument.");
|
|
||||||
abort();
|
|
||||||
case SP_ERR_FAIL:
|
|
||||||
error_message = sp_last_error_message();
|
|
||||||
printf("Error: Failed: %s\n", error_message);
|
|
||||||
sp_free_error_message(error_message);
|
|
||||||
abort();
|
|
||||||
case SP_ERR_SUPP:
|
|
||||||
puts("Error: Not supported.");
|
|
||||||
abort();
|
|
||||||
case SP_ERR_MEM:
|
|
||||||
puts("Error: Couldn't allocate memory.");
|
|
||||||
abort();
|
|
||||||
case SP_OK:
|
|
||||||
default:
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void handle_sigint(int sig) { INTERRUPT = true; }
|
|
@ -1,31 +0,0 @@
|
|||||||
#include <stdio.h> // file handling functions
|
|
||||||
#include <stdlib.h> // atoi
|
|
||||||
#include <string.h> // strtok
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
char buffer[80];
|
|
||||||
FILE *stream = fopen("example.csv", "r");
|
|
||||||
|
|
||||||
while (fgets(buffer, 80, stream)) {
|
|
||||||
char *token = strtok(buffer, ",");
|
|
||||||
|
|
||||||
// If you only need the first column of each row
|
|
||||||
// Если нам нужен только первый столбец каждой строки
|
|
||||||
if (token) {
|
|
||||||
int n = atoi(token);
|
|
||||||
printf("%s\n", n);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If you need all the values in a row
|
|
||||||
// Если нам нужны все значения подряд
|
|
||||||
while (token) {
|
|
||||||
// Just printing each integer here but handle as needed
|
|
||||||
// int n = atoi(token);
|
|
||||||
printf("%s\n", token);
|
|
||||||
|
|
||||||
token = strtok(NULL, ",");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,12 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
int main(int argc, char const *argv[])
|
|
||||||
{
|
|
||||||
int red = 0;
|
|
||||||
int green = 128;
|
|
||||||
int blue = 64;
|
|
||||||
|
|
||||||
printf("#%.2x%.2x%.2x\n", red, green, blue); //#008040
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,52 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sqlite3.h>
|
|
||||||
|
|
||||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
|
||||||
int i;
|
|
||||||
for(i = 0; i<argc; i++) {
|
|
||||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
|
||||||
sqlite3 *db;
|
|
||||||
char *zErrMsg = 0;
|
|
||||||
int rc;
|
|
||||||
char *sql;
|
|
||||||
|
|
||||||
/* Open database */
|
|
||||||
rc = sqlite3_open("test.db", &db);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
|
||||||
return(0);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Opened database successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create SQL statement */
|
|
||||||
sql = "CREATE TABLE COMPANY(" \
|
|
||||||
"ID INT PRIMARY KEY NOT NULL," \
|
|
||||||
"NAME TEXT NOT NULL," \
|
|
||||||
"AGE INT NOT NULL," \
|
|
||||||
"ADDRESS CHAR(50)," \
|
|
||||||
"SALARY REAL);";
|
|
||||||
|
|
||||||
/* Execute SQL statement */
|
|
||||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
|
||||||
|
|
||||||
if (rc != SQLITE_OK) {
|
|
||||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
|
||||||
sqlite3_free(zErrMsg);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Table created successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlite3_close(db);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sqlite3.h>
|
|
||||||
|
|
||||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
|
||||||
int i;
|
|
||||||
fprintf(stderr, "%s: ", (const char*)data);
|
|
||||||
|
|
||||||
for (i = 0; i<argc; i++) {
|
|
||||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
|
||||||
sqlite3 *db;
|
|
||||||
char *zErrMsg = 0;
|
|
||||||
int rc;
|
|
||||||
char *sql;
|
|
||||||
const char* data = "Callback function called";
|
|
||||||
|
|
||||||
/* Open database */
|
|
||||||
rc = sqlite3_open("test.db", &db);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
|
||||||
return(0);
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "Opened database successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create merged SQL statement */
|
|
||||||
sql = "DELETE from COMPANY where ID=2; " \
|
|
||||||
"SELECT * from COMPANY";
|
|
||||||
|
|
||||||
/* Execute SQL statement */
|
|
||||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
|
||||||
|
|
||||||
if (rc != SQLITE_OK) {
|
|
||||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
|
||||||
sqlite3_free(zErrMsg);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Operation done successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlite3_close(db);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,55 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sqlite3.h>
|
|
||||||
|
|
||||||
static int callback(void *NotUsed, int argc, char **argv, char **azColName) {
|
|
||||||
int i;
|
|
||||||
for (i = 0; i<argc; i++) {
|
|
||||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
|
||||||
sqlite3 *db;
|
|
||||||
char *zErrMsg = 0;
|
|
||||||
int rc;
|
|
||||||
char *sql;
|
|
||||||
|
|
||||||
/* Open database */
|
|
||||||
rc = sqlite3_open("test.db", &db);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
|
||||||
return(0);
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "Opened database successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create SQL statement */
|
|
||||||
sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \
|
|
||||||
"VALUES (1, 'Paul', 32, 'California', 20000.00 ); " \
|
|
||||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " \
|
|
||||||
"VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); " \
|
|
||||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
|
|
||||||
"VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );" \
|
|
||||||
"INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)" \
|
|
||||||
"VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00);";
|
|
||||||
|
|
||||||
/* Execute SQL statement */
|
|
||||||
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg);
|
|
||||||
|
|
||||||
if (rc != SQLITE_OK) {
|
|
||||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
|
||||||
sqlite3_free(zErrMsg);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Records created successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlite3_close(db);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,50 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sqlite3.h>
|
|
||||||
|
|
||||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
|
||||||
int i;
|
|
||||||
fprintf(stderr, "%s: ", (const char*)data);
|
|
||||||
|
|
||||||
for (i = 0; i<argc; i++) {
|
|
||||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
|
||||||
sqlite3 *db;
|
|
||||||
char *zErrMsg = 0;
|
|
||||||
int rc;
|
|
||||||
char *sql;
|
|
||||||
const char* data = "Callback function called";
|
|
||||||
|
|
||||||
/* Open database */
|
|
||||||
rc = sqlite3_open("test.db", &db);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
|
||||||
return(0);
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "Opened database successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create SQL statement */
|
|
||||||
sql = "SELECT * from COMPANY";
|
|
||||||
|
|
||||||
/* Execute SQL statement */
|
|
||||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
|
||||||
|
|
||||||
if (rc != SQLITE_OK) {
|
|
||||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
|
||||||
sqlite3_free(zErrMsg);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Operation done successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlite3_close(db);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sqlite3.h>
|
|
||||||
|
|
||||||
static int callback(void *data, int argc, char **argv, char **azColName) {
|
|
||||||
int i;
|
|
||||||
fprintf(stderr, "%s: ", (const char*)data);
|
|
||||||
|
|
||||||
for(i = 0; i<argc; i++) {
|
|
||||||
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
|
|
||||||
}
|
|
||||||
|
|
||||||
printf("\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
|
||||||
sqlite3 *db;
|
|
||||||
char *zErrMsg = 0;
|
|
||||||
int rc;
|
|
||||||
char *sql;
|
|
||||||
const char* data = "Callback function called";
|
|
||||||
|
|
||||||
/* Open database */
|
|
||||||
rc = sqlite3_open("test.db", &db);
|
|
||||||
|
|
||||||
if (rc) {
|
|
||||||
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
|
|
||||||
return(0);
|
|
||||||
} else {
|
|
||||||
fprintf(stderr, "Opened database successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Create merged SQL statement */
|
|
||||||
sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; " \
|
|
||||||
"SELECT * from COMPANY";
|
|
||||||
|
|
||||||
/* Execute SQL statement */
|
|
||||||
rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
|
|
||||||
|
|
||||||
if (rc != SQLITE_OK) {
|
|
||||||
fprintf(stderr, "SQL error: %s\n", zErrMsg);
|
|
||||||
sqlite3_free(zErrMsg);
|
|
||||||
} else {
|
|
||||||
fprintf(stdout, "Operation done successfully\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
sqlite3_close(db);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
Binary file not shown.
Binary file not shown.
@ -36,8 +36,7 @@ int main(int argc, char *argv[]) {
|
|||||||
addr.sun_family = AF_UNIX;
|
addr.sun_family = AF_UNIX;
|
||||||
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
||||||
|
|
||||||
ret = connect (data_socket, (const struct sockaddr *) &addr,
|
ret = connect(data_socket, (const struct sockaddr *)&addr, sizeof(struct sockaddr_un));
|
||||||
sizeof(struct sockaddr_un));
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
fprintf(stderr, "The server is down.\n");
|
fprintf(stderr, "The server is down.\n");
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
@ -53,7 +52,7 @@ int main(int argc, char *argv[]) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Request result. */
|
/* Request result. */
|
||||||
strcpy (buffer, "END");
|
strcpy(buffer, "END");
|
||||||
ret = write(data_socket, buffer, strlen(buffer) + 1);
|
ret = write(data_socket, buffer, strlen(buffer) + 1);
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
perror("write");
|
perror("write");
|
||||||
|
Binary file not shown.
@ -43,8 +43,7 @@ int main(int argc, char *argv[]) {
|
|||||||
addr.sun_family = AF_UNIX;
|
addr.sun_family = AF_UNIX;
|
||||||
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
strncpy(addr.sun_path, SOCKET_NAME, sizeof(addr.sun_path) - 1);
|
||||||
|
|
||||||
ret = bind(listen_socket, (const struct sockaddr *) &addr,
|
ret = bind(listen_socket, (const struct sockaddr *)&addr, sizeof(struct sockaddr_un));
|
||||||
sizeof(struct sockaddr_un));
|
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
perror("bind");
|
perror("bind");
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
@ -71,7 +70,7 @@ int main(int argc, char *argv[]) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
result = 0;
|
result = 0;
|
||||||
for(;;) {
|
for (;;) {
|
||||||
/* Wait for next data packet. */
|
/* Wait for next data packet. */
|
||||||
ret = read(data_socket, buffer, BUFFER_SIZE);
|
ret = read(data_socket, buffer, BUFFER_SIZE);
|
||||||
if (ret == -1) {
|
if (ret == -1) {
|
||||||
|
Loading…
Reference in New Issue
Block a user