#!/usr/bin/python
#python code practice for include discovery
import os
pre = "#include"
def compact(str):
#local variable assignment before referenced
l = len(str)
i = 0
res = ""
while i < l:
if str != ' ' and str != '\n':
res += str
i = i + 1
return res
def geth_in_str(str):
res = set()#init set
l0 = len(str)
l1 = len(pre)
i = 0
while i + l1 + 2 <= l0:
c = 'x'
if str[i + l1] == '"':
c = '"'
elif str[i + l1] == '<':
c = '>'
else:
i = i + 1
continue
if str[i : i + l1] == pre:
#substr[i, i + l1)
j = i + l1 + 1
while j < l0:
if str[j] == c:
res.add(str[i + l1 + 1 : j])
break
j = j + 1
if j < l0:
i = j
i = i + 1
return res
def geth_in_file(fn):
fd = open(fn, "r")
text = fd.read()
text = compact(text)
res = geth_in_str(text)
fd.close()
return res
def print_hset(hs):
for e in hs:
print e
def hroot(dn):
all = set()
ex_all = set()
tp = os.walk(dn).next()
#to generates tuples (parent, dirnames, filenames),
#and .next() to get the first
for file in tp[2]:
l = len(file)
if l > 1 and file[l - 1] == 'h' and file[l - 2] == '.':
all.add(file)
ex_all = ex_all | geth_in_file(file)
#set operation
print ex_all
res = all - ex_all
return res
def main():
print "h helper begin...."
while True:
cmd = raw_input("input cmd:\n")
#raw_input a string, and input a int or float
if cmd == "q" or cmd == "quit":
break
if cmd == "root":
#show .hs in the dir of which is not included
dn = raw_input("input dir:\n")
print
res = hroot(dn)
print_hset(res)
elif cmd == "allh":
#show .hs included by the file
fn = raw_input("input file:\n")
print
res = geth_in_file(fn)
print_hset(res)
print