5

我在 Serena Dimensions 中有一个存储库;我需要将它迁移到 Github。我发现我需要使用 git-fast-import,但我面临的问题是 Serena Dimensions repo 的元数据。如何从 Serena 维度导出元数据?

注意:我已经更新了下面的答案,如果你觉得它有用,请点赞。

4

2 回答 2

4

这是红宝石脚本

#!/usr/bin/env ruby

$stdout.binmode
$author = ""
$date = ""

require 'spreadsheet'
book = Spreadsheet.open('Metadata.xls')
sheet1 = book.worksheet('Sheet1') # can use an index or worksheet name
sheet1.each 1 do |row|
break if row[2].nil? # if first cell empty
    $author = row[2] + " <email@domain.com>"
break if row[5].nil?
    $date = row[5]
#puts row.join(',') # looks like it calls "to_s" on each cell's Value
end

$marks = []
def convert_dir_to_mark(dir)
if !$marks.include?(dir)
    $marks << dir
end
($marks.index(dir)+1).to_s
end


def convert_dir_to_date(dir)
if dir == 'current'
    return Time.now().to_i
else
    dir = dir.gsub('back_', '')
    (year, month, day) = dir.split('_')
    return Time.local(year, month, day).to_i
end
end

def export_data(string)
print "data #{string.size}\n#{string}"
end

def inline_data(file, code='M', mode='644')
content = File.read(file)
puts "#{code} #{mode} inline #{file}"
export_data(content)
end

def print_export(dir, last_mark)
date = convert_dir_to_date(dir)
mark = convert_dir_to_mark(dir)

puts 'commit refs/heads/master'
puts "mark :#{mark}"
puts "committer #{ $author } #{ date } -0700"
export_data("imported from #{dir}")
puts "from :#{last_mark}" if last_mark

puts 'deleteall'
Dir.glob("**/*").each do |file|
    next if !File.file?(file)
    inline_data(file)
end
mark
end


# Loop through the directories
last_mark = nil
Dir.chdir(ARGV[0]) do
Dir.glob("*").each do |dir|
    next if File.file?(dir)

    # move into the target directory
    Dir.chdir(dir) do
        last_mark = print_export(dir, last_mark)
    end
end
end

我将Dimensions 元数据导出到名为“Metadata.xls”的电子表格中。然后通过运行脚本从中读取数据并导入 Git。

于 2015-07-31T20:50:12.097 回答
3

还有另一种方法可以做到这一点 - 使用 Git SVN 和 CM SVN Bridge。使用这种方法,您应该能够使用 git 客户端访问Dimensions 服务器。
检查此链接以获取详细信息: CM 14.2 新功能:使用 Git 客户端访问 CM 服务器
此外,Serena 论坛上的此线程可能有用: 将 Dimension repo 迁移到 git

更新

14.3.3 中有一个新功能,可以更简单地完成。

于 2016-04-11T11:38:54.300 回答