ویژوال استودیو کد (VSCode) یک ویرایشگر کد رایگان است که روی سیستم عاملهای macOS، Linux و Windows اجرا میشود. پشتیبانی از ابزار ظریفی دارد که از توسعه Python و C++، اشکال زدایی بصری، ادغام با git و بسیاری از ویژگی های جالب دیگر پشتیبانی می کند. به دلیل سهولت استفاده و مدیریت برنامه افزودنی، این ویرایشگر عالی برای توسعه TensorFlow IO است. با این حال، مقداری تلاش برای پیکربندی صحیح آن ضروری است. از آنجایی که پیکربندی VSCode بسیار انعطافپذیر است، به توسعهدهندگان اجازه میدهد تا پروژه را با استفاده از bazel کامپایل کرده و کد را تحت اشکالزدای Python و C++ اجرا کنند. تنظیم ابزار پایه ممکن است بر اساس سیستم های عملیاتی متفاوت باشد، اما رویکرد پیکربندی باید مشابه باشد.
برنامه های افزودنی
برای نصب یک برنامه افزودنی، روی نماد نمای افزونه ها (افزونه ها) در نوار کناری کلیک کنید یا از میانبر Ctrl+Shift+X استفاده کنید. سپس کلمه کلیدی زیر را جستجو کنید.
- C/C++ - پسوند رسمی C++ از مایکروسافت
- Python - افزونه رسمی پایتون از مایکروسافت
- بسته برنامه افزودنی پایتون - یکی دیگر از برنامههای افزودنی مفید برای توسعه پایتون
تدوین پروژه ها
TensorFlow IO با استفاده از دستور ساخت bazel کامپایل شده است:
bazel build -s --verbose_failures --compilation_mode dbg //tensorflow_io/...
برای جزئیات در مورد نحوه راه اندازی محیط توسعه در اوبونتو، به فایل پروژه README مراجعه کنید. -compilation_mode پرچم dbg در اینجا نشان می دهد که باینری تولید شده باید دارای نمادهای اشکال زدایی باشد. هنگامی که می توانید پروژه را از خط فرمان کامپایل کنید، می توانید VSCode را نیز پیکربندی کنید تا بتوانید همان فرمان را فراخوانی کنید.
View->Command Pallete ( Ctrl+Shift+P ) را باز کنید و شروع به تایپ کنید: "Tasks: Configure Build Task". اگر برای اولین بار این کار را انجام می دهید، ویرایشگر ایجاد فایل tasks.json را پیشنهاد می کند. هنگامی که آن را دارید، json زیر را Paste کنید:
{
"version": "2.0.0",
"tasks": [
{
"label": "Build TF.IO (Debug)",
"type": "shell",
"command": "bazel build -s --verbose_failures --compilation_mode dbg //tensorflow_io/...",
"group": {
"kind": "build",
"isDefault": true
},
"problemMatcher": []
}
]
}
اکنون می توانید Ctrl+Shift+B را فشار دهید و VSCode از دستور بالا برای ساخت پروژه استفاده می کند. از پنجره ترمینال خود استفاده می کند، جایی که همه پیوندها قابل کلیک هستند. بنابراین هنگامی که یک خطای کامپایل رخ می دهد، فایل مربوطه را باز کرده و تنها با کلیک بر روی پیوند در پنجره ترمینال، به خط هدایت می شوید.
اشکال زدایی پروژه ها
اشکال زدایی کد پایتون بی اهمیت است، اسناد رسمی را دنبال کنید تا بفهمید چگونه VSCode را برای فعال کردن آن پیکربندی کنید: https://code.visualstudio.com/docs/python/debugging
با این حال، اشکال زدایی کد ++C نیاز به نصب GDB بر روی سیستم شما دارد. اگر یک اسکریپت پایتون bq_sample_read.py
دارید که از کتابخانه tensorflow-io
استفاده می کند و معمولاً به روش زیر اجرا می شود:
python3 bq_sample_read.py --gcp_project_id=...
شما می توانید آن را تحت GDB با استفاده از موارد زیر اجرا کنید:
gdb -ex r --args python3 bq_sample_read.py --gcp_project_id=...
اگر برنامه در مرحله کد C++ خراب شد، میتوانید backtrace
در کنسول GDB اجرا کنید تا stacktrace خطا را دریافت کنید.
VSCode همچنین دارای پشتیبانی دیباگر GDB است. این اجازه می دهد تا نقاط شکست را اضافه کنید، مقادیر متغیرها را مشاهده کنید و کد را به صورت گام به گام طی کنید. برای افزودن پیکربندی اشکال زدایی، نماد Debug View (Debug) را در نوار کناری فشار دهید یا از میانبر Ctrl+Shift+D استفاده کنید. در اینجا، فلش کوچک رو به پایین در کنار دکمه پخش را فشار دهید و "Add Configuration..." را انتخاب کنید. اکنون یک فایل launch.json
ایجاد می کند که لطفاً پیکربندی زیر را به آن اضافه کنید:
{
"name": "(gdb) Launch",
"type": "cppdbg",
"request": "launch",
"program": "/usr/bin/python3",
"args": ["bq_sample_read.py", "--gcp_project_id=..."],
"stopAtEntry": false,
"cwd": "${workspaceFolder}",
"environment": [
{
/* path to your bazel-bin folder */
"name": "TFIO_DATAPATH",
"value": "/usr/local/google/home/io/bazel-bin"
},
{
/* other env variables to use */
"name": "GOOGLE_APPLICATION_CREDENTIALS",
"value": "..."
}
],
"externalConsole": false,
"MIMode": "gdb",
"setupCommands": [
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
]
}
اگر همه چیز به درستی پیکربندی شده باشد، باید بتوانید Run -> Start Debugging ( F5 ) یا Run -> Run Without Debugging ( Ctrl + F5 ) را انجام دهید. این کد شما را تحت دیباگر اجرا می کند:
به منظور سادهتر کردن تجربه اشکالزدایی، میتوانید GDB را طوری پیکربندی کنید که از کتابخانههای استاندارد C++ رد شود. این به شما امکان می دهد کدی را که برایتان مهم نیست نادیده بگیرید. برای این کار یک فایل ~/.gdbinit
با محتوای زیر ایجاد کنید:
skip -gfi /usr/include/c++/*/*/*
skip -gfi /usr/include/c++/*/*
skip -gfi /usr/include/c++/*
فرمت کردن فایل ها
همیشه میتوانید فایل C++ یا Python را با کلیک راست -> Format Document ( Ctrl + Shift + I ) دوباره قالببندی کنید، اما VSCode از یک قرارداد سبک متفاوت استفاده میکند. خوشبختانه، تغییر آن آسان است.
برای قالببندی پایتون، به https://donjayamanne.github.io/pythonVSCodeDocs/docs/formatting/ مراجعه کنید.
برای قالب بندی C++، موارد زیر را انجام دهید:
- به تنظیمات -> تنظیمات بروید
- جستجو برای "C_Cpp.clang_format_fallbackStyle"
-
file:setting.json
را مستقیماً با افزودن محتوای زیر تغییر دهید
"C_Cpp.clang_format_fallbackStyle": "{ BasedOnStyle: Google}"