เซ็ตของการแก้ไข
(สำหรับคำแนะนำเบื้องต้นเกี่ยวกับหลักการทำงานของ Mercurial ลองดู [:ThaiUnderstandingMercurial:ทำความเข้าใจ Mercurial])
เซ็ตของการแก้ไข หรือ changeset (บางครั้งถูกย่อเป็น "cset") คือหน่วยของการแก้ไขที่เกิดขึ้นกับไฟล์หนึ่งหรือหลายไฟล์ใน [:Repository:repository] เซ็ตของการแก้ไขเก็บประวัติของการเปลี่ยนแปลงทั้งหมดที่เกิดขึ้นกับ[:ThaiLocalModifications:ไฟล์ที่ถูกแก้ไขในไดเร็คทอรี่สำหรับใช้ทำงาน]และถูก[:ThaiCommit:คอมมิท]เป็น[:Revision:การแก้ไข]ครั้งใหม่ใน repository
เราสามารถระบุเซ็ตของการแก้ไขได้โดยใช้[:ThaiChangeSetID:รหัสประจำเซ็ตการแก้ไข] นอกจากนั้นใน repository ใด repository หนึ่งคุณสามารถระบุเซ็ตของการแก้ไขได้โดยใช้[:ThaiRevisionNumber:เลขครั้งที่แก้ไข]ได้เช่นกัน
การสร้างเซ็ตของการแก้ไขใหม่นั้นมีชื่อเรียกว่าการ[:ThaiCommit:คอมมิท] หรือเช็คอิน โดยข้อมูลที่ถูกเก็บโดยเซ็ตของการแก้ไขนั้นรวมไปถึง:
[:ThaiNodeid:nodeid] ของ [:ThaiManifest:มานิเฟสต์]
- รายชื่อของไฟล์ที่ถูกแก้ไข
- ข้อมูลเกี่ยวกับคนที่ทำการแก้ไข ("committer") เหตุผลหรือคำอธิบายการแก้ไข และวันที่และเวลาที่ถูกแก้ไข
- ชื่อของ[:Branch:กิ่ง]ที่ถูกทำการแก้ไข (จะใช้ชื่อ "default" ถ้าไม่ได้ระบุกิ่ง)
แต่ละเซ็ตการแก้ไขอาจมี[:ThaiParent:บรรพบุรุษ]ได้หนึ่งหรือสองเซ็ตการแก้ไข เซ็ตการแก้ไขที่เกิดขึ้นจากการ[:ThaiMerge:รวมประวัติการแก้ไข]จะมีบรรพบุรุษสองเซ็ต ถ้าเซ็ตการแก้ไขนั้นไม่มีบรรพบุรุษนั่นหมายความว่าเป็นเซ็ตการแก้ไขรากของ repository ในแต่ละ repository ก็อาจจะมีเซ็ตการแก้ไขรากได้หลายเซ็ต (แต่โดยปกติแล้วมักจะมีแค่เซ็ตเดียว) โดยรากแต่ละเซ็ตคือรากของแต่ละกิ่ง
ถ้าเซ็ตการแก้ไขไม่ใช่[:ThaiHead:ส่วนยอด]ของกิ่ง เซ็ตการแก้ไขนั้นจะมีเซ็ตลูกอย่างน้อยหนึ่งเซ็ต (ซึ่งหมายความว่าเซ็ตการแก้ไขนั้นเป็นบรรพบุรุษของเซ็ตการแก้ไขลูกเหล่านั้นด้วย)
คุณสามารถ[:ThaiUpdate:อัพเดท]เนื้อหาของไฟล์ใน[:ThaiWorkingDirectory:ไดเร็คทอรี่สำหรับใช้ทำงาน]ให้ตรงกับเซ็ตการแก้ไขที่ถูกไปแล้วในอดีตได้ เมื่อคุณทำเช่นนี้เซ็ตการแก้ไขนั้นจะกลายเป็นบรรพบุรุษของไดเร็คทอรี่สำหรับใช้ทำงาน
การ "อัพเดท" ไดเร็คทอรี่สำหรับใช้งานกลับไปที่เซ็ตการแก้ไขที่มีเซ็ตลูกอยู่แล้วและทำการแก้ไขไฟล์และคอมมิท จะทำให้เกิดเซ็ตการแก้ไขลูกใหม่และก็ทำให้เกิดกิ่งใหม่ด้วยเช่นกัน คุณสามารถ[:ThaiNamedBranches:ตั้งชื่อให้กิ่ง]แต่ละกิ่งได้เช่นกัน
ทุกๆเซ็ตการแก้ไขใน repository จะถูกเก็บในสิ่งที่เรียกว่า [:ThaiChangelog:changelog]
นี่คือตัวอย่างว่า Mercurial เก็บข้อมูลของเซ็ตการแก้ไขยังไง:
$ hg debugdata .hg/00changelog.d 1208 1102691ceab8c8f278edecd80f2e3916090082dd <- เลขที่ nodeid ของมานิเฟสต์ mpm@selenic.com <- คนที่คอมมิท 1126146623 25200 <- วันที่คอมมิท นับเป็นวินาทีตั้งแต่ศักราชใหม่และอิงกับเวลา UTC mercurial/commands.py <- รายชื่อของไฟล์ที่ถูกแก้ไข ตามมาด้วยคำอธิบาย Clean up local clone file list We now use an explicit list of files to copy during clone so that we don't copy anything we shouldn't.
หน้าที่เกี่ยวข้อง: ["ChangeSetComments"], ["Design"]
- คำถาม: เซ็ตของการแก้ไขเทียบเท่ากับสภาพของ repository ณ เวลาใดเวลาหนึ่ง (เหมือนเลขที่การแก้ไขในซับเวอร์ชั่น) หรือว่าเทียบเท่ากับการแก้ไขที่เกิดขึ้นกับไฟล์ (เหมือนกับ Darcs patch)?
วิธีการคำนวน hash ของเซ็ตการแก้ไขนั้นบ่งบอกว่าเซ็ตการแก้ไขเหมือนกับสภาพของ repository ณ เวลาใดเวลาหนึ่ง พร้อมๆกับบรรพบุรุษทั้งหมดที่ทำให้เกิดการแก้ไขนั้นๆ (หรือจะเรียกได้ว่าทุกๆเซ็ตการแก้ไขที่นำไปสู่เซ็ตนั้น) ใน Darcs ความหมายนี้เทียบเท่ากับ [http://www.darcs.net/manual/node7.html#SECTION00781000000000000000 tag]