mem, time, fixes

This commit is contained in:
fiplox 2022-01-08 13:54:02 +01:00
parent 792788da0b
commit bc8dc81b8e
13 changed files with 260 additions and 40 deletions

View File

@ -3,7 +3,7 @@ CFLAGS = -Wall -Wextra -Werror -O3
NAME = code-analyzer
AUTHOR = Volodymyr_Patuta
VERSION = 1.0.1
VERSION = 1.1.0
SRCDIR = ./src

View File

@ -46,16 +46,20 @@ header-includes:
- \setbeamercolor{titlelike}{fg=brown}
---
# Programme
# Section heading {bgcolor=red}
Dans quel sens un "programme" ?
Some text
# Exemple d'un programme
* list1
* list2
* list3
## Neovim
# Section heading 2
```sh
$ fd --extension c . 'neovim/' | wc -l
174
$ wc `fd --extension c . 'neovim/'` -l
...
300347 total
```
## subsection
text in subsection

12
prez.md
View File

@ -1,7 +1,11 @@
Mon projet est le projet sous le numero 38 qui est analyse d'un programme.
Mon projet est le projet sous le numero 38 qui est analyse d'un programme. Un
programme au sens de code source d'un programme. Ce code doit etre interpreté
sous forme d'un graphe avec un vecteur de successeur et un graphe a matrice
compacte.
Dans quel sens un "programme" ?
Un programme au sens de code source d'un programme qui comporte plusieurs
fichier et plusieurs centaines / milliers de lignes de code. Ce code doit etre
interpreté sous forme d'un graphe orienté avec un vecteur de successeur et un
graphe a matrice compacte.
Pour exemple, voici un programme avec plusieur fichiers (174) et plusieurs
milliers de lignes de code (300347)

View File

@ -44,6 +44,9 @@ const char *gengetopt_args_info_help[] = {
" --print-mc Print compact matrice graph. (default=off)",
" --cycles-vec Find and print cycles in a vector graph. (default=off)",
" --cycles-mc Find and print cycles in a compact matrice graph.\n (default=off)",
" --mem Print memory usage by graphs. (default=off)",
" --kb Print memory usage by graphs in kylobytes. (default=off)",
" --time Print time taken by graphs operations in seconds.\n (default=off)",
0
};
@ -61,6 +64,8 @@ static int
cmdline_parser_internal (int argc, char **argv, struct gengetopt_args_info *args_info,
struct cmdline_parser_params *params, const char *additional_error);
static int
cmdline_parser_required2 (struct gengetopt_args_info *args_info, const char *prog_name, const char *additional_error);
static char *
gengetopt_strdup (const char *s);
@ -78,6 +83,9 @@ void clear_given (struct gengetopt_args_info *args_info)
args_info->print_mc_given = 0 ;
args_info->cycles_vec_given = 0 ;
args_info->cycles_mc_given = 0 ;
args_info->mem_given = 0 ;
args_info->kb_given = 0 ;
args_info->time_given = 0 ;
}
static
@ -94,6 +102,9 @@ void clear_args (struct gengetopt_args_info *args_info)
args_info->print_mc_flag = 0;
args_info->cycles_vec_flag = 0;
args_info->cycles_mc_flag = 0;
args_info->mem_flag = 0;
args_info->kb_flag = 0;
args_info->time_flag = 0;
}
@ -112,6 +123,9 @@ void init_args_info(struct gengetopt_args_info *args_info)
args_info->print_mc_help = gengetopt_args_info_help[7] ;
args_info->cycles_vec_help = gengetopt_args_info_help[8] ;
args_info->cycles_mc_help = gengetopt_args_info_help[9] ;
args_info->mem_help = gengetopt_args_info_help[10] ;
args_info->kb_help = gengetopt_args_info_help[11] ;
args_info->time_help = gengetopt_args_info_help[12] ;
}
@ -255,6 +269,12 @@ cmdline_parser_dump(FILE *outfile, struct gengetopt_args_info *args_info)
write_into_file(outfile, "cycles-vec", 0, 0 );
if (args_info->cycles_mc_given)
write_into_file(outfile, "cycles-mc", 0, 0 );
if (args_info->mem_given)
write_into_file(outfile, "mem", 0, 0 );
if (args_info->kb_given)
write_into_file(outfile, "kb", 0, 0 );
if (args_info->time_given)
write_into_file(outfile, "time", 0, 0 );
i = EXIT_SUCCESS;
@ -350,9 +370,36 @@ cmdline_parser2 (int argc, char **argv, struct gengetopt_args_info *args_info, i
int
cmdline_parser_required (struct gengetopt_args_info *args_info, const char *prog_name)
{
FIX_UNUSED (args_info);
FIX_UNUSED (prog_name);
return EXIT_SUCCESS;
int result = EXIT_SUCCESS;
if (cmdline_parser_required2(args_info, prog_name, 0) > 0)
result = EXIT_FAILURE;
if (result == EXIT_FAILURE)
{
cmdline_parser_free (args_info);
exit (EXIT_FAILURE);
}
return result;
}
int
cmdline_parser_required2 (struct gengetopt_args_info *args_info, const char *prog_name, const char *additional_error)
{
int error_occurred = 0;
FIX_UNUSED (additional_error);
/* checks for required options */
/* checks for dependences among options */
if (args_info->kb_given && ! args_info->mem_given)
{
fprintf (stderr, "%s: '--kb' option depends on option 'mem'%s\n", prog_name, (additional_error ? additional_error : ""));
error_occurred = 1;
}
return error_occurred;
}
@ -512,6 +559,9 @@ cmdline_parser_internal (
{ "print-mc", 0, NULL, 0 },
{ "cycles-vec", 0, NULL, 0 },
{ "cycles-mc", 0, NULL, 0 },
{ "mem", 0, NULL, 0 },
{ "kb", 0, NULL, 0 },
{ "time", 0, NULL, 0 },
{ 0, 0, 0, 0 }
};
@ -624,6 +674,42 @@ cmdline_parser_internal (
additional_error))
goto failure;
}
/* Print memory usage by graphs.. */
else if (strcmp (long_options[option_index].name, "mem") == 0)
{
if (update_arg((void *)&(args_info->mem_flag), 0, &(args_info->mem_given),
&(local_args_info.mem_given), optarg, 0, 0, ARG_FLAG,
check_ambiguity, override, 1, 0, "mem", '-',
additional_error))
goto failure;
}
/* Print memory usage by graphs in kylobytes.. */
else if (strcmp (long_options[option_index].name, "kb") == 0)
{
if (update_arg((void *)&(args_info->kb_flag), 0, &(args_info->kb_given),
&(local_args_info.kb_given), optarg, 0, 0, ARG_FLAG,
check_ambiguity, override, 1, 0, "kb", '-',
additional_error))
goto failure;
}
/* Print time taken by graphs operations in seconds.. */
else if (strcmp (long_options[option_index].name, "time") == 0)
{
if (update_arg((void *)&(args_info->time_flag), 0, &(args_info->time_given),
&(local_args_info.time_given), optarg, 0, 0, ARG_FLAG,
check_ambiguity, override, 1, 0, "time", '-',
additional_error))
goto failure;
}
break;
@ -639,7 +725,10 @@ cmdline_parser_internal (
FIX_UNUSED(check_required);
if (check_required)
{
error_occurred += cmdline_parser_required2 (args_info, argv[0], additional_error);
}
cmdline_parser_release (&local_args_info);

View File

@ -1,4 +1,4 @@
version "1.0.1"
version "1.1.0"
package "code-analyzer"
purpose "Analyze source code in a form of a graph.
@ -12,3 +12,6 @@ option "print-vec" - "Print vector graph." flag off
option "print-mc" - "Print compact matrice graph." flag off
option "cycles-vec" - "Find and print cycles in a vector graph." flag off
option "cycles-mc" - "Find and print cycles in a compact matrice graph." flag off
option "mem" - "Print memory usage by graphs." flag off
option "kb" - "Print memory usage by graphs in kylobytes." flag off dependon="mem"
option "time" - "Print time taken by graphs operations in seconds." flag off

View File

@ -31,7 +31,7 @@ extern "C" {
#ifndef CMDLINE_PARSER_VERSION
/** @brief the program version */
#define CMDLINE_PARSER_VERSION "1.0.1"
#define CMDLINE_PARSER_VERSION "1.1.0"
#endif
/** @brief Where the command line options are stored */
@ -57,6 +57,12 @@ struct gengetopt_args_info
const char *cycles_vec_help; /**< @brief Find and print cycles in a vector graph. help description. */
int cycles_mc_flag; /**< @brief Find and print cycles in a compact matrice graph. (default=off). */
const char *cycles_mc_help; /**< @brief Find and print cycles in a compact matrice graph. help description. */
int mem_flag; /**< @brief Print memory usage by graphs. (default=off). */
const char *mem_help; /**< @brief Print memory usage by graphs. help description. */
int kb_flag; /**< @brief Print memory usage by graphs in kylobytes. (default=off). */
const char *kb_help; /**< @brief Print memory usage by graphs in kylobytes. help description. */
int time_flag; /**< @brief Print time taken by graphs operations in seconds. (default=off). */
const char *time_help; /**< @brief Print time taken by graphs operations in seconds. help description. */
unsigned int help_given ; /**< @brief Whether help was given. */
unsigned int version_given ; /**< @brief Whether version was given. */
@ -68,6 +74,9 @@ struct gengetopt_args_info
unsigned int print_mc_given ; /**< @brief Whether print-mc was given. */
unsigned int cycles_vec_given ; /**< @brief Whether cycles-vec was given. */
unsigned int cycles_mc_given ; /**< @brief Whether cycles-mc was given. */
unsigned int mem_given ; /**< @brief Whether mem was given. */
unsigned int kb_given ; /**< @brief Whether kb was given. */
unsigned int time_given ; /**< @brief Whether time was given. */
} ;

View File

@ -1,3 +1,5 @@
#include "cparse.h"
#include "letemps.h"
#include <dirent.h>
#include <errno.h>
#include <regex.h>
@ -5,9 +7,8 @@
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "cparse.h"
void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc)
void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc, double *tv, double *tmc)
{
FILE *fp;
regex_t fdre, fcre;
@ -16,7 +17,6 @@ void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc)
char *token;
regmatch_t rm[2];
bool in;
(void)gmc;
const char *re_func_decl = "^(\\**\\w+\\s+?\\ ?\\ ?){1,}\\([^!@#$+%^]+?\\)\\s+";
const char *re_func_call = "([a-zA-Z_0-9]+)\\(.*\\)";
@ -53,26 +53,40 @@ void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc)
if (strcmp(token, "defined") == 0)
continue;
// printf("%.*s\n", (int)(rm[1].rm_eo - rm[1].rm_so), line + rm[1].rm_so);
if ((index = vis_in(*gv, token)) > -1) {
initTemps();
index = vis_in(*gv, token);
*tv += getTemps() / 100;
initTemps();
index = mcis_in(*gmc, token);
*tmc += getTemps() / 100;
if (index > -1) {
initTemps();
if (gv->node[cur_node]->nbs == gv->node[cur_node]->cap)
gv->node[cur_node]->succ =
realloc(gv->node[cur_node]->succ, (gv->node[cur_node]->cap += 5) * sizeof(nodept));
realloc(gv->node[cur_node]->succ, (gv->node[cur_node]->cap += 128) * sizeof(nodept));
gv->node[cur_node]->succ[gv->node[cur_node]->nbs] = gv->node[index];
gv->node[cur_node]->nbs++;
gv->node[index]->call = true;
*tv += getTemps() / 100;
initTemps();
mcinsert_edge(gmc, cur_node, index);
*tmc += getTemps() / 100;
} else {
initTemps();
vinsert_node(gv, token);
if (gv->node[cur_node]->nbs == gv->node[cur_node]->cap)
gv->node[cur_node]->succ =
realloc(gv->node[cur_node]->succ, (gv->node[cur_node]->cap += 5) * sizeof(nodept));
realloc(gv->node[cur_node]->succ, (gv->node[cur_node]->cap += 128) * sizeof(nodept));
gv->node[cur_node]->succ[gv->node[cur_node]->nbs] = gv->node[gv->n];
gv->node[cur_node]->nbs++;
gv->node[gv->n]->call = true;
*tv += getTemps() / 100;
initTemps();
mcinsert_func(gmc, token);
mcinsert_edge(gmc, cur_node, -1);
*tmc += getTemps() / 100;
}
}
} else if (regexec(&fdre, line, 2, rm, 0) == 0) { // function definition
@ -86,9 +100,12 @@ void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc)
if ((index = vis_in(*gv, token)) > -1) {
cur_node = index;
} else {
// printf("%s\n", token);
initTemps();
vinsert_node(gv, token);
*tv += getTemps() / 100;
initTemps();
mcinsert_func(gmc, token);
*tmc += getTemps() / 100;
cur_node = gv->n;
}
in = true;
@ -104,7 +121,7 @@ void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc)
fclose(fp);
}
void findAndParse(const char *path, graph_vec *gv, graph_mco *gmc)
void findAndParse(const char *path, graph_vec *gv, graph_mco *gmc, double *tv, double *tmc)
{
char p[1024];
struct dirent *dp;
@ -118,14 +135,14 @@ void findAndParse(const char *path, graph_vec *gv, graph_mco *gmc)
if (strncmp(dp->d_name, ".", 1) == 0)
continue;
snprintf(p, sizeof(p), "%s/%s", path, dp->d_name);
findAndParse(p, gv, gmc);
findAndParse(p, gv, gmc, tv, tmc);
} else {
char *f = strrchr(dp->d_name, '.');
if (f) {
if (strncmp(f, ".c", 2) == 0) {
char pa[512];
sprintf(pa, "%s/%s", path, dp->d_name);
find_funcs(pa, gv, gmc);
find_funcs(pa, gv, gmc, tv, tmc);
}
}
}

View File

@ -5,8 +5,8 @@
#include "vec.h"
#include "matcom.h"
void findAndParse(const char *path, graph_vec *gv, graph_mco *gmc);
void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc);
void findAndParse(const char *path, graph_vec *gv, graph_mco *gmc, double *tv, double *tmc);
void find_funcs(const char *path, graph_vec *gv, graph_mco *gmc, double *tv, double *tmc);
#endif /* end of include guard: CPARSE_H */

23
src/letemps.c Normal file
View File

@ -0,0 +1,23 @@
/* letemps.c --
* Fares Belhadj -
* amsi@ai.univ-paris8.fr
* 03/11/2004
*/
#include <stdlib.h>
#include <stdio.h>
#include <sys/time.h>
#include "letemps.h"
static struct timeval ti;
extern void initTemps(void) {
gettimeofday(&ti, (struct timezone*) 0);
}
double getTemps(void) {
struct timeval t;
double diff;
gettimeofday(&t, (struct timezone*) 0);
diff = (t.tv_sec - ti.tv_sec) * 1000000
+ (t.tv_usec - ti.tv_usec);
return diff/1000000.;
}

10
src/letemps.h Normal file
View File

@ -0,0 +1,10 @@
/* letemps.h --
* Fares Belhadj -
* amsi@ai.univ-paris8.fr
* 03/11/2004
*/
#ifndef LETEMPS_H
#define LETEMPS_H
void initTemps(void);
extern double getTemps(void);
#endif /* LETEMPS_H */

View File

@ -17,11 +17,13 @@
#include "cmdline.h"
#include "colors.h"
#include "cparse.h"
#include "letemps.h"
#include "matcom.h"
#include "vec.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
@ -30,6 +32,9 @@ int main(int argc, char *argv[])
graph_vec gv;
graph_mco gmc;
int i, n;
double tmc, tv;
tmc = tv = 0.0;
if (cmdline_parser(argc, argv, &ai) != 0) {
exit(1);
@ -43,16 +48,25 @@ int main(int argc, char *argv[])
exit(2);
}
initTemps();
gv = vnew_graph();
tv += getTemps() / 100;
initTemps();
gmc = mcgragh();
tmc += getTemps() / 100;
if (access("graph.dot", F_OK) == 0) {
remove("graph.dot");
}
if (ai.path_given) {
path = ai.path_arg;
findAndParse(path, &gv, &gmc);
findAndParse(path, &gv, &gmc, &tv, &tmc);
}
if (ai.file_given) {
path = ai.file_arg;
find_funcs(path, &gv, &gmc);
find_funcs(path, &gv, &gmc, &tv, &tmc);
}
if (ai.print_vec_flag) {
@ -85,10 +99,57 @@ int main(int argc, char *argv[])
}
}
if (ai.cycles_mc_flag)
if (ai.cycles_mc_flag) {
initTemps();
mcfind_cycles(&gmc);
if (ai.cycles_vec_flag)
tmc += getTemps() / 100;
}
if (ai.cycles_vec_flag) {
initTemps();
vfind_cycles(&gv);
tv += getTemps() / 100;
}
if (ai.mem_flag) {
int vmem = 0;
for (i = 0; i <= gv.n; ++i) {
vmem += gv.node[i]->nbs * (sizeof(void *) + sizeof(int));
}
int mcmem = gmc.nba * sizeof(struct edge);
int vmem_names = vmem + gv.n * sizeof(fix_str);
int mcmem_names = gmc.nba * sizeof(struct edge) + gmc.nbs * sizeof(fix_str);
if (ai.kb_flag) {
vmem /= 1024;
vmem_names /= 1024;
mcmem /= 1024;
mcmem_names /= 1024;
}
if (ai.color_flag) {
printf(GREEN "%-45s " RESET_COLOR RED "%d %s\n" RESET_COLOR, "Vector memory with func names:", vmem_names,
ai.kb_flag ? "kB" : "B");
printf(GREEN "%-45s " RESET_COLOR RED "%d %s\n" RESET_COLOR,
"Compact matrice memory with func names:", mcmem_names, ai.kb_flag ? "kB" : "B");
printf(GREEN "%-45s " RESET_COLOR RED "%d %s\n" RESET_COLOR, "Vector memory without func names:", vmem,
ai.kb_flag ? "kB" : "B");
printf(GREEN "%-45s " RESET_COLOR RED "%d %s\n" RESET_COLOR,
"Compact matrice memory without func names:", mcmem, ai.kb_flag ? "kB" : "B");
} else {
printf("%-45s %d %s\n", "Vector memory with func names:", vmem_names, ai.kb_flag ? "kB" : "B");
printf("%-45s %d %s\n", "Compact matrice memory with func names:", mcmem_names, ai.kb_flag ? "kB" : "B");
printf("%-45s %d %s\n", "Vector memory without func names:", vmem, ai.kb_flag ? "kB" : "B");
printf("%-45s %d %s\n", "Compact matrice memory without func names:", mcmem, ai.kb_flag ? "kB" : "B");
}
}
if (ai.time_flag) {
if (ai.color_flag) {
printf(GREEN "%-45s " RESET_COLOR RED "%lf s\n" RESET_COLOR, "Vector time:", tv);
printf(GREEN "%-45s " RESET_COLOR RED "%lf s\n" RESET_COLOR, "Compact matrice time:", tmc);
} else {
printf("Time vec: %lfs\n", tv);
printf("Time mc: %lfs\n", tmc);
}
}
vdot_graph(gv, ai.main_graph_flag);
mcdot_graph(&gmc, ai.main_graph_flag);

View File

@ -74,9 +74,9 @@ void mcdelete_graph(graph_mco *g)
int mcis_in(graph_mco g, fix_str func)
{
int i;
if (g.nba == 0)
if (g.nbs < 0)
return -1;
for (i = 0; i <= g.nba; i++) {
for (i = 0; i <= g.nbs; i++) {
if (strcmp(g.func[i], func) == 0) {
return i;
}

View File

@ -14,7 +14,7 @@ graph_vec vnew_graph(void)
g.n = -1;
g.n = -1;
g.cap = 10;
g.node = malloc(10 * sizeof(nodept));
g.node = malloc(1024 * sizeof(nodept));
assert(g.node);
return g;
}
@ -23,7 +23,7 @@ void vinsert_node(graph_vec *g, fix_str str)
{
++g->n;
if (g->n == g->cap)
g->node = realloc(g->node, (g->cap += 128) * sizeof(nodept));
g->node = realloc(g->node, (g->cap += 1024) * sizeof(nodept));
struct node *n = malloc(sizeof(struct node));
assert(n);
n->num = g->n;
@ -31,7 +31,7 @@ void vinsert_node(graph_vec *g, fix_str str)
n->vu = 0;
n->cap = 5;
n->call = false;
n->succ = malloc(5 * sizeof(nodept));
n->succ = malloc(128 * sizeof(nodept));
strcpy(n->func, str);
g->node[g->n] = n;
}