Вы можете сделать это довольно легко без git rebase
или git merge --squash
. В этом примере мы раздавим последние 3 коммита.
Если вы хотите записать новое сообщение о фиксации с нуля, это достаточно:
git reset --soft HEAD~3 &&
git commit
Если вы хотите начать редактируя новое сообщение фиксации с помощью конкатенации существующих сообщений фиксации (т. е. похоже на то, что будет запускать список инструкций pick / squash / squash / ... / squash git rebase -i
), тогда вам нужно извлечь эти сообщения и передать их git commit
:
git reset --soft HEAD~3 &&
git commit --edit -m"$(git log --format=%B --reverse HEAD..HEAD@{1})"
Оба этих метода скворуют последние три коммита в один новый коммит таким же образом. Мягкий сброс просто перенаправляет HEAD на последнюю фиксацию, которую вы не хотите раздавить. Ни индекс, ни рабочее дерево не касаются мягкого сброса, оставляя индекс в желаемом состоянии для вашего нового коммита (т. Е. Он уже имеет все изменения от коммитов, которые вы собираетесь «выбросить»).
Да, это возможно в принципе. Ниже приведен пример. Здесь вы можете увидеть выход .
Также читайте здесь список переменных аргументов здесь и здесь
#include <iostream>
#include <cstdarg>
using namespace std;
class AbstractClass{
public:
virtual double average(int num, ... ) = 0;
};
class ConcreteClass : public AbstractClass{
public:
virtual double average(int num, ... )
{
va_list arguments; // A place to store the list of arguments
double sum = 0;
va_start ( arguments, num ); // Initializing arguments to store all values after num
for ( int x = 0; x < num; x++ ) // Loop until all numbers are added
sum += va_arg ( arguments, double ); // Adds the next value in argument list to sum.
va_end ( arguments ); // Cleans up the list
return sum / num; // Returns the average
}
};
int main()
{
AbstractClass* interface = new ConcreteClass();
cout << interface->average( 3 , 20 ,30 , 40 );
return 0;
}