-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit.py
80 lines (68 loc) · 2.54 KB
/
init.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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import os
from glob import glob1
import sys
from shutil import copyfile
import requests
from datetime import date
import logging
from argparse import ArgumentParser
logging.basicConfig(
level=logging.INFO, format="%(levelname)-8s %(funcName)s: %(message)s",
)
logger = logging.getLogger(__name__)
parser = ArgumentParser()
parser.add_argument("-d", "--day", default=date.today().day, type=int)
parser.add_argument("-y", "--year", default=date.today().year, type=int)
parser.add_argument("-l", "--language", default=["py"], nargs="+")
parser.add_argument("--no-download", dest="skip_download", action="store_true")
args = parser.parse_args()
lang_files = {
"cpp": ["*.cpp", "*.hpp", "*.h", "Makefile"],
}
def setup_dir():
newdir = "day{}".format(args.day)
if not os.path.exists(newdir):
os.mkdir(newdir)
logger.info("created a new directory {}".format(newdir))
for lang in args.language:
# check if there are multiple filetypes for that language, otherwise
# we just copy everything that matches *.lang
wildcards = lang_files.get(lang, [f"*.{lang}"])
for wc in wildcards:
for t in glob1("templates", wc):
if t in os.listdir(newdir):
logger.warning(f"{newdir} already contains {t}, skipping")
else:
copyfile(os.path.join("templates", t), os.path.join(newdir, t))
logger.info(f"done copying templates to {newdir}")
def get_input():
if not "AOC_SESSION" in os.environ:
logger.warning("no environment variable 'AOC_SESSION' found! skipping download")
return
else:
cookie = os.environ["AOC_SESSION"]
url = "https://adventofcode.com/{}/day/{}/input".format(args.year, args.day)
if "input.txt" in os.listdir(f"day{args.day}"):
logger.warning(f"day{args.day}/input.txt already exists, skip download")
return
logger.info("download input from {}... ".format(url))
try:
response = requests.get(
url=url,
cookies={"session": cookie},
headers={"User-Agent": "get_input_script"},
)
if response.ok:
data = response.text
f = open(os.path.join(f"day{args.day}", "input.txt"), "w+")
f.write(data.rstrip("\n"))
f.close()
logger.info("... done!")
else:
logger.error("server response not ok")
except:
logger.error("something went wrong")
if __name__ == "__main__":
setup_dir()
if not args.skip_download:
get_input()