Difference between revisions of "He/כלי בניה"

From GnuCash
Jump to: navigation, search
(EDIT LANGUAGE BOX)
(Autotools (הוצא משימוש): fix RTL)
Line 48: Line 48:
 
לאלו שמעוניינים פשוט לבנות את התיעוד מקוד המקור, שלושת הפקודות הבאות יספיקו:
 
לאלו שמעוניינים פשוט לבנות את התיעוד מקוד המקור, שלושת הפקודות הבאות יספיקו:
 
#<code>autogen.sh</code>: בודק שכל החלקים הנדרשים של מערכת הבנייה מותקנים, ואז בונה את תוכנית <code>configure</code> מהמקור שלו <code>configure.ac</code> ואת Makefiles קובצי הביניים <code>Makefile.in</code>, מהמקור שלהם <code>Makefile.am</code>. לאחר מכן, הרצת <code>autogen.sh</code> לאחר שכפול המאגר <code>gnucash-docs.git</code>, בכל פעם שעורכים קובץ <code>Makefile.am</code> או <code>configure.ac</code>, ובכל פעם שמושכים הידורים עם שינויים לקבצים אלו. מאחר שהרצתו ללא כל צורך אינה מזיקה כלל, אנו ממליצים להריץ אותו לאחר כל פקודת <code>git pull</code>.
 
#<code>autogen.sh</code>: בודק שכל החלקים הנדרשים של מערכת הבנייה מותקנים, ואז בונה את תוכנית <code>configure</code> מהמקור שלו <code>configure.ac</code> ואת Makefiles קובצי הביניים <code>Makefile.in</code>, מהמקור שלהם <code>Makefile.am</code>. לאחר מכן, הרצת <code>autogen.sh</code> לאחר שכפול המאגר <code>gnucash-docs.git</code>, בכל פעם שעורכים קובץ <code>Makefile.am</code> או <code>configure.ac</code>, ובכל פעם שמושכים הידורים עם שינויים לקבצים אלו. מאחר שהרצתו ללא כל צורך אינה מזיקה כלל, אנו ממליצים להריץ אותו לאחר כל פקודת <code>git pull</code>.
#(לא נדרש, אך מומלץ)<Syntaxhighlight lang="sh">
+
#(לא נדרש, אך מומלץ)
 +
<Syntaxhighlight lang="debcontrol">
 
mkdir .build
 
mkdir .build
cd .build</Syntaxhighlight>
+
cd .build
 +
</Syntaxhighlight>
 
#;הערה: הפקודות <tt>configure</tt> ו- <tt>make</tt> מורצות מ- {BUILDDIR}$ בעוד שהמקור נערך בספרית האב {SOURCEDIR}$.
 
#;הערה: הפקודות <tt>configure</tt> ו- <tt>make</tt> מורצות מ- {BUILDDIR}$ בעוד שהמקור נערך בספרית האב {SOURCEDIR}$.
 
#<code>configure</code>: תסריט מסוף זה, המחולל על ידי <code>autogen.sh</code> כפי שתואר לעיל, בודק שהמערכת והמשתנים שלה מכסים את דרישות קובצי הביניים <code>Makefile.in</code> ב- <code>Makefile</code> כך שפקודת <code>make</code> תשתמש בהם בפועל כדי לחולול את קבצי התיעוד של המוצר. ניתן לצפות ברשימת הפרמטרים ומשתני הסביבה שכל תכנית <code>configure</code> "מבינה" באמצעות הפקודה <code>configure --help</code>.
 
#<code>configure</code>: תסריט מסוף זה, המחולל על ידי <code>autogen.sh</code> כפי שתואר לעיל, בודק שהמערכת והמשתנים שלה מכסים את דרישות קובצי הביניים <code>Makefile.in</code> ב- <code>Makefile</code> כך שפקודת <code>make</code> תשתמש בהם בפועל כדי לחולול את קבצי התיעוד של המוצר. ניתן לצפות ברשימת הפרמטרים ומשתני הסביבה שכל תכנית <code>configure</code> "מבינה" באמצעות הפקודה <code>configure --help</code>.

Revision as of 15:53, 11 May 2021

שפות אנגלית גרמנית ספרדית עִברִית פורטוגזית צרפתית

כללי

פרויקט גנוקאש משתמש במגוון כלים לבניית התכנית, המסמכים והחבילות יעודיות למערכת ההפעלה.

כלים בסיסיים

כלים אלו שולטים בתהליך הבנייה ברמה נמוכה.

Make

Make הוא כלי בניה אוטומי הבונה יעדים ממקור על ידי פירוש קבצי תסריט (סקריפטים) הנקראים Makefiles המורים לכלי הבניה כיצד להפוך את קובץ או קובצי המקור לקובץ או קובצי היעד. קובצי Makefiles הם קובצי מלל רגילים. Make מטפל היטב בשתי בעיות הקשורות בבנית תוכנה בסביבה מרובת קבצים: א. טיפול בתליויות בין קבצים וספריות, ב. טיפול בשינויים במקצת מהספריות מבלי לבצע בניה מחדש. "סביבות פיתוח משולבות" או "IDEs" רבות משתמשות ב- make (או בן דודו nmake של מיקרוסופט) לביצוע הבנייה. את קובצי Makefiles ניתן לכתוב באופן ידני (כמו במקרה של gnucash-htdocs.git) או ליצור אותם באמצעות Autotools או CMake. ניתן להפעיל את Make באופן רקורסיבי לבניית תוכניות מורכבות ולהשתמש בחותמות זמן של קבצים כדי להדר מחדש רק קבצים וספריות שבהם התלויות השתנו. קובצי Makefiles מציינים בדרך כלל מספר יעדי בניה, אותן ניתן לספק כמשתנים בזמן הקריאה ל- make, כדי לבצע פעולות מסוימות ולייצר פלטים מסויימים.

Ninja

Ninja היא מערכת בנייה קלת משקל ששמה דגש על מהירות ביצועים. היא תוכננה כך שקבצי הקלט שלה נוצרים על ידי מערכת בנייה ברמה גבוהה יותר, והיא נועדה להריץ את תהליך הבנייה במהירות הגבוהה האפשרית.

הערה
פקודות השורה משתנות מ- make [target] ל- ninja [target].
הערה
כמה מהפצות לינוקס שינו את שם הפקודה ל- ninja-build על מנת להבדיל בינה לבין תכנה אחרת בשם ninja.

בקישור הבא ניתן למצוא השוואה של CMake ו- make, להשווה בין הכלים

CMake משמש בשכיחות גבוהה לתיצור קובצי הבניה של ninja: כדי לעשות זאת, יש להעביר את פָּרָמֶטֶר -G Ninja כמשתנה של cmake.

שרשראות כלים

בנוסף, גנוקאש עושה שימוש בשרשראות כלים שונות כדי לשלוט בכלים הבסיסיים שהוזכרו לעיל. התוכנית משתמשת ב- CMake כבסיס לשרשרת הכלים שלה, בעוד שתיעוד המשתמש נעזר ב-Autotools כבסיס לשרשרת הכלים. אתר גנוקאש לעומת זאת, נבנה ישירות באמצעות Make. תיעוד ה- API נוצר מקוד המקור באמצעות Make או Ninja, תלוי באופן התצור של מערכת בניית קוד המקור.

CMake

על מנת להגדיר או לתצר את תוכנית מערכת הבניה, נשתמש ב- CMake. אמור לשמש גם עבור Gnucash-docs.

זוהו יישום תכנה חוצת-מסדות, חופשיהלשימוש ובקוד פתוח, לניהול תהליך בניית התוכנה בשיטה שאינה תלויה במהדר. הוא תומך במבנה ספריות היררכי וביישומים התלויים במספר ספריות. הוא משמש בשילוב עם סביבות בנייה מקומיות כמו, Xcode של אפל, make ו- Visual Studio של מיקרוסופט . יש לו תלויות מזעריות, ודורש רק מהדר ++C במערכת הבנייה העצמית שלו. נכון לעכשיו, CMake משמש בעיקר לתצורת מערכת הבנייה על ידי יצירת קבצי הקלט לתוכניות הבנייה make או ninja שמהדרות ומקשרות את התכנית אל הספריות שלה. כלי עזר אלה שולטים גם בהתקנת התכנית ובספריות. ראו גם CMake#GnuCash Configuration Variables.

Autotools (הוצא משימוש)

בעבר הסתמכנו על GNU Build System כדי לתצר את מערכת הבניה Gnucash-docs. לעיתים קרובות מכונה גם "autotools". התוכנית היא לזנוח כלי זה באופן סופי בגרסת 4.9xx!

זוהי מערכת מורכבת, בעלת היכולת להגדרת תצורה ובנייה של מגוון רחב של פרויקטים על מגוון רחב של מסדות. העמוד באתר The Autotools Mythbuster מספק הדרכה והתייחסות מצוינת לאלו שמעוניינים ללמוד על יצירה ובנייה של פרויקטים באמצעות כלי זה.

לאלו שמעוניינים פשוט לבנות את התיעוד מקוד המקור, שלושת הפקודות הבאות יספיקו:

  1. autogen.sh: בודק שכל החלקים הנדרשים של מערכת הבנייה מותקנים, ואז בונה את תוכנית configure מהמקור שלו configure.ac ואת Makefiles קובצי הביניים Makefile.in, מהמקור שלהם Makefile.am. לאחר מכן, הרצת autogen.sh לאחר שכפול המאגר gnucash-docs.git, בכל פעם שעורכים קובץ Makefile.am או configure.ac, ובכל פעם שמושכים הידורים עם שינויים לקבצים אלו. מאחר שהרצתו ללא כל צורך אינה מזיקה כלל, אנו ממליצים להריץ אותו לאחר כל פקודת git pull.
  2. (לא נדרש, אך מומלץ)
mkdir .build
cd .build
  1. הערה
    הפקודות configure ו- make מורצות מ- {BUILDDIR}$ בעוד שהמקור נערך בספרית האב {SOURCEDIR}$.
  2. configure: תסריט מסוף זה, המחולל על ידי autogen.sh כפי שתואר לעיל, בודק שהמערכת והמשתנים שלה מכסים את דרישות קובצי הביניים Makefile.in ב- Makefile כך שפקודת make תשתמש בהם בפועל כדי לחולול את קבצי התיעוד של המוצר. ניתן לצפות ברשימת הפרמטרים ומשתני הסביבה שכל תכנית configure "מבינה" באמצעות הפקודה configure --help.
  3. make: באמצעות Makefile כתבנית, make מריץ את התכניות והתסריטים השונים הדרושים לביצוע הבנייה. המשתנים שלו הם היעדים אותם יש לבנות; יישנם שני יעדים מסויימים, make check מריץ סדרת בדיקות להבטחת בניית הפרויקט כראוי ו- make install שמעביר את תוצרי הבנייה למיקומים מהם ניתן להשתמש בהמשך בתכנית שנבנתה.

חזרה לעמוד:

בניית גנוקאש