Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
frama-c
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Deploy
Releases
Container Registry
Model registry
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
pub
frama-c
Commits
68742159
Commit
68742159
authored
3 years ago
by
Andre Maroneze
Committed by
Virgile Prevosto
3 years ago
Browse files
Options
Downloads
Patches
Plain Diff
[Makefile] more efficient, OCaml-based, tool to check for trailing newlines
parent
123af596
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
.gitignore
+1
-0
1 addition, 0 deletions
.gitignore
Makefile
+25
-3
25 additions, 3 deletions
Makefile
bin/check_newline.sh
+0
-36
0 additions, 36 deletions
bin/check_newline.sh
bin/check_newlines.ml
+54
-0
54 additions, 0 deletions
bin/check_newlines.ml
with
80 additions
and
39 deletions
.gitignore
+
1
−
0
View file @
68742159
...
@@ -64,6 +64,7 @@ autom4te.cache
...
@@ -64,6 +64,7 @@ autom4te.cache
/devel_tools/fc-time
/devel_tools/fc-time
/devel_tools/fc-memuse
/devel_tools/fc-memuse
/bin/ocamldep_transitive_closure
/bin/ocamldep_transitive_closure
/bin/check_newlines
#share
#share
/share/Makefile.config
/share/Makefile.config
...
...
This diff is collapsed.
Click to expand it.
Makefile
+
25
−
3
View file @
68742159
...
@@ -2141,6 +2141,28 @@ clean:: hdrck-clean
...
@@ -2141,6 +2141,28 @@ clean:: hdrck-clean
CURRENT_HEADERS
?=
open-source
CURRENT_HEADERS
?=
open-source
CURRENT_HEADER_DIRS
?=
$(
addsuffix /
$(
CURRENT_HEADERS
)
,
$(
HEADER_DIRS
))
CURRENT_HEADER_DIRS
?=
$(
addsuffix /
$(
CURRENT_HEADERS
)
,
$(
HEADER_DIRS
))
CHECK_NEWLINES
:=
./bin/check_newlines
$(
EXE
)
$(CHECK_NEWLINES)
:
bin/check_newlines.ml
$(
PRINT_MAKING
)
$@
ifeq
($(OCAMLBEST),opt)
$(
OCAMLOPT
)
unix.cmxa
$<
-o
$@
else
$(
OCAMLC
)
unix.cma
$<
-o
$@
endif
FILES_WITHOUT_NEWLINE
:=
\
VERSION
\
VERSION_CODENAME
\
$(
sort
$(
wildcard ivette/src/dome/doc/template/static/fonts/
*
))
\
$(
sort
$(
wildcard share/
*
.ico share/
*
.png share/theme/
*
/
*
.png
))
TESTS_WITHOUT_NEWLINE
:=
\
tests/spec/unfinished-oneline-acsl-comment.i
\
tests/verisec/suite/programs/apps/SpamAssassin/BID-6679/message_write/test
\
tests/verisec/suite/programs/apps/sendmail/CVE-1999-0047/mime7to8/array_vs_pointer.ods
\
tests/verisec/suite/programs/apps/sendmail/CVE-1999-0047/mime7to8/data_testing.ods
\
# OPEN_SOURCE: set it to 'yes' if you want to check open source headers
# OPEN_SOURCE: set it to 'yes' if you want to check open source headers
# STRICT_HEADERS: set it to 'yes' if you want to consider warnings as errors
# STRICT_HEADERS: set it to 'yes' if you want to consider warnings as errors
# The target check-headers does the following checks:
# The target check-headers does the following checks:
...
@@ -2153,7 +2175,7 @@ CURRENT_HEADER_DIRS?=$(addsuffix /$(CURRENT_HEADERS),$(HEADER_DIRS))
...
@@ -2153,7 +2175,7 @@ CURRENT_HEADER_DIRS?=$(addsuffix /$(CURRENT_HEADERS),$(HEADER_DIRS))
# because identical headers but with different encodings are not exactly
# because identical headers but with different encodings are not exactly
# easy to distinguish
# easy to distinguish
.PHONY
:
check-headers
.PHONY
:
check-headers
check-headers
:
$(HDRCK)
check-headers
:
$(HDRCK)
$(CHECK_NEWLINES)
$(
PRINT
)
"Checking
$(
DISTRIB_HEADERS
)
headers (OPEN_SOURCE=
$(
OPEN_SOURCE
)
, CURRENT_HEADERS=
$(
CURRENT_HEADERS
)
)..."
$(
PRINT
)
"Checking
$(
DISTRIB_HEADERS
)
headers (OPEN_SOURCE=
$(
OPEN_SOURCE
)
, CURRENT_HEADERS=
$(
CURRENT_HEADERS
)
)..."
$(
PRINT
)
"- HEADER_SPEC_FILE=
$(
HEADER_SPEC_FILE
)
"
$(
PRINT
)
"- HEADER_SPEC_FILE=
$(
HEADER_SPEC_FILE
)
"
$(
PRINT
)
"- CURRENT_HEADER_DIRS=
$(
CURRENT_HEADER_DIRS
)
"
$(
PRINT
)
"- CURRENT_HEADER_DIRS=
$(
CURRENT_HEADER_DIRS
)
"
...
@@ -2163,8 +2185,8 @@ check-headers: $(HDRCK)
...
@@ -2163,8 +2185,8 @@ check-headers: $(HDRCK)
$(
file
>
distrib_tests.tmp
)
$(
foreach O,
$(
DISTRIB_TESTS
)
,
$(
file
>>
distrib_tests.tmp,
$O
))
$(
file
>
distrib_tests.tmp
)
$(
foreach O,
$(
DISTRIB_TESTS
)
,
$(
file
>>
distrib_tests.tmp,
$O
))
$(
file
>
header_exceptions.tmp
)
$(
foreach O,
$(
HEADER_EXCEPTIONS
)
,
$(
file
>>
header_exceptions.tmp,
$O
))
$(
file
>
header_exceptions.tmp
)
$(
foreach O,
$(
HEADER_EXCEPTIONS
)
,
$(
file
>>
header_exceptions.tmp,
$O
))
echo
"Checking that distributed files terminate with a newline..."
echo
"Checking that distributed files terminate with a newline..."
bin/check_newline.sh distrib_files.tmp
$(
CHECK_NEWLINES
)
distrib_files.tmp
$(
FILES_WITHOUT_NEWLINE
)
bin/check_newline.sh distrib_tests.tmp
$(
CHECK_NEWLINES
)
distrib_tests.tmp
$(
TESTS_WITHOUT_NEWLINE
)
@
if
command
-v
file
>
/dev/null 2>/dev/null
;
then
\
@
if
command
-v
file
>
/dev/null 2>/dev/null
;
then
\
echo
"Checking that distributed files do not use iso-8859..."
;
\
echo
"Checking that distributed files do not use iso-8859..."
;
\
file
--mime-encoding
-f
distrib_files.tmp
-f
distrib_tests.tmp |
\
file
--mime-encoding
-f
distrib_files.tmp
-f
distrib_tests.tmp |
\
...
...
This diff is collapsed.
Click to expand it.
bin/check_newline.sh
deleted
100755 → 0
+
0
−
36
View file @
123af596
#!/bin/bash -e
# $1: file containing the list of files to check
# prints a warning for each file not finishing with a newline,
# unless it is one of a few well-known exceptions (e.g. VERSION).
# Note: requires the 'file' command-line tool to check which files are text.
if
[
$#
-lt
1
]
;
then
echo
"usage:
$0
file_list.txt"
exit
2
fi
is_likely_text_file
()
{
case
$(
file
-b
--mime-type
- <
"
$1
"
)
in
(
text/
*
)
echo
"1"
esac
}
errors
=
0
IFS
=
''
while
read
file
do
if
[
-n
"
$(
is_likely_text_file
"
$file
"
)
"
]
;
then
x
=
$(
tail
-c
1
"
$file
"
)
if
[
"
$x
"
!=
""
]
&&
[
"
$file
"
!=
"VERSION"
]
&&
[
"
$file
"
!=
"VERSION_CODENAME"
]
;
then
echo
"error: no newline at end of file:
$file
"
errors
=
$((
errors+1
))
fi
fi
done
< <
(
file
-f
"
$1
"
--mime
|
grep
'\btext'
|
cut
-d
:
-f1
)
if
[
$errors
-gt
0
]
;
then
echo
"Found
$errors
file(s) with errors."
exit
1
fi
This diff is collapsed.
Click to expand it.
bin/check_newlines.ml
0 → 100644
+
54
−
0
View file @
68742159
module
StringSet
=
Set
.
Make
(
String
)
(* returns true for empty files *)
let
is_last_byte_newline
filename
=
try
let
ic
=
open_in
filename
in
try
let
fd
=
Unix
.
descr_of_in_channel
ic
in
ignore
(
Unix
.
lseek
fd
(
-
1
)
Unix
.
SEEK_END
);
let
buf
=
Bytes
.
create
1
in
let
n_bytes_read
=
Unix
.
read
fd
buf
0
1
in
close_in
ic
;
n_bytes_read
<=
0
||
Bytes
.
get
buf
0
=
'\n'
with
|
Unix
.
Unix_error
_
->
(* probably an empty file; ignoring *)
close_in
ic
;
true
with
|
Sys_error
_
->
(* possibly a non-existing file (e.g. with spaces); ignoring *)
Format
.
printf
"could not open, ignoring file: %s"
filename
;
true
(* usage: first argument is a file name containing a list of files
(one per line) to be checked; the remaining arguments are a list of
files to be ignored during checking
(i.e. they do not terminate with newlines). *)
let
()
=
if
Array
.
length
Sys
.
argv
<
2
then
begin
Format
.
printf
"usage: %s file_list.txt [ignore1 ignore2 ...]@."
Sys
.
argv
.
(
0
);
exit
0
end
;
let
errors
=
ref
0
in
let
file_list_ic
=
open_in
Sys
.
argv
.
(
1
)
in
let
to_ignore
=
StringSet
.
of_list
(
List
.
tl
(
Array
.
to_list
Sys
.
argv
))
in
begin
try
while
true
;
do
let
filename
=
input_line
file_list_ic
in
if
not
(
StringSet
.
mem
filename
to_ignore
)
&&
not
(
is_last_byte_newline
filename
)
then
begin
incr
errors
;
Format
.
printf
"error: no newline at end of file: %s@."
filename
end
done
with
End_of_file
->
close_in
file_list_ic
end
;
if
!
errors
>
0
then
begin
Format
.
printf
"Found %d file(s) with errors.@."
!
errors
;
exit
1
end
else
exit
0
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment