-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathprepare.py
52 lines (44 loc) · 1.38 KB
/
prepare.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import re
import glob
from subprocess import Popen, PIPE, STDOUT
from os import walk
import os
import glob
from src import preprocess as pp
import pdb
class Prepare:
def __init__(self):
self._data = []
def generate_data(text, self):
maxlen = 50
sentences = []
next_chars = []
for i in range(0, len(text) - maxlen - 1):
sentences.append(text[i: i + maxlen])
next_chars.append(text[i + maxlen])
sentences[i] = re.sub(r'[\n\t]',' ', sentences[i])
next_chars[i] = re.sub(r'[\n\t]',' ', next_chars[i])
self._data.append(sentences[i] + "\t" + next_chars[i])
print(self._data)
def prepare(seed_path):
p = Prepare()
files = []
valid_count = 0
for root, d_names, f_names in os.walk(seed_path):
for f in f_names:
files.append(os.path.join(root, f))
for file in files:
if ('nocomment' in file or 'nospace' in file or 'nomacro' in file or 'raw' in file):
command = 'rm ' + file
p = Popen(command, shell=True, stdin=PIPE, stdout=PIPE, stderr=STDOUT, close_fds=True)
if (not file.endswith('.c') and not file.endswith('.h') and not file.endswith('.C')):
continue
text = open(file, 'r', encoding='iso-8859-1').read()
text = pp.remove_comment(text)
text = pp.replace_macro(text, file)
text = pp.remove_space(text)
is_valid = pp.verify_correctness(text, file, 'nospace')
if (is_valid):
valid_count += 1
p.generate_data(text)
print(valid_count)